/* ============================================================= *
   Phronon umbrella site — visual system
   Palette: navy #0F1B2D · olive #6B7A52 · gold #C49A3A · paper #F2F2F0
   Type:    Source Serif 4 (display) · Source Sans 3 (text)
 * ============================================================= */
:root{
  --navy:#0F1B2D; --navy-2:#16263d; --olive:#6B7A52; --gold:#C49A3A;
  --paper:#F2F2F0; --ink:#0F1B2D; --muted:#5b6573; --line:#e2e3df;
  --max:1140px; --radius:14px;
  --serif:"Source Serif 4",Georgia,serif;
  --sans:"Source Sans 3",system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);font-weight:400;color:var(--ink);
  background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;margin:0 0 .5em}
a{color:var(--olive);text-decoration:none}
a:hover{text-decoration:underline}
em{font-style:italic}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.accent{color:var(--gold)}
.section-head{max-width:720px;margin:0 0 36px}
.section-head h2{font-size:clamp(1.7rem,3vw,2.4rem)}
.section-head p{color:var(--muted);font-size:1.08rem;margin:0}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-family:var(--sans);font-weight:600;font-size:1rem;
  padding:13px 24px;border-radius:8px;border:2px solid transparent;cursor:pointer;
  transition:.15s ease;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-gold{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn-gold:hover{background:#b9902f}
.btn-ghost{background:transparent;color:currentColor;border-color:currentColor}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn.full{width:100%;text-align:center}
.btn.small{padding:8px 14px;font-size:.9rem}

/* ---------- brand lockup + toggle mark ---------- */
.brand-lockup{display:inline-flex;align-items:center;gap:12px;color:inherit;text-decoration:none}
.brand-lockup:hover{text-decoration:none}
.brand-word{font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:.01em}
.brand-lockup.small .brand-word{font-size:1.25rem}
.brand-lockup.center{justify-content:center}
.toggle-mark{height:30px;width:auto;color:inherit}
.brand-lockup.small .toggle-mark{height:26px}
.tm-letter{font-family:var(--serif);font-weight:600;font-size:24px;fill:currentColor}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:20;background:var(--navy);color:var(--paper);
  border-bottom:1px solid rgba(255,255,255,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.site-nav{display:flex;align-items:center;gap:26px}
.site-nav a{color:rgba(242,242,240,.82);font-weight:500;font-size:.98rem}
.site-nav a:hover{color:#fff;text-decoration:none}
.site-nav .nav-cta{color:var(--navy);background:var(--gold);padding:8px 16px;border-radius:7px;font-weight:600}
.site-nav .nav-cta:hover{background:#b9902f}

/* ---------- hero ---------- */
.hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-2) 100%);color:var(--paper)}
.hero-inner{padding:84px 24px 92px;max-width:860px}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;font-weight:600;
  color:var(--gold);margin:0 0 18px}
.hero-title{font-size:clamp(2.4rem,6vw,4rem);margin:0 0 22px;color:#fff}
.hero-lede{font-size:1.22rem;color:rgba(242,242,240,.86);max-width:680px;margin:0 0 32px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn-ghost{color:var(--paper)}

/* ---------- philosophy ---------- */
.philosophy{padding:80px 0;border-bottom:1px solid var(--line)}
.philo-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:start}
.philo-text h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:.6em}
.philo-text p{font-size:1.1rem;margin:0 0 1.1em}
.philo-card{background:var(--navy);color:var(--paper);border-radius:var(--radius);padding:30px 30px 34px}
.philo-card h3{color:#fff;font-size:1.3rem}
.ticks{list-style:none;padding:0;margin:0}
.ticks li{position:relative;padding:9px 0 9px 30px;border-bottom:1px solid rgba(255,255,255,.1);
  color:rgba(242,242,240,.9)}
.ticks li:last-child{border-bottom:0}
.ticks li::before{content:"";position:absolute;left:4px;top:16px;width:9px;height:9px;
  border-radius:50%;background:var(--gold)}

/* ---------- tools ---------- */
.tools{padding:80px 0;background:#fbfbf9;border-bottom:1px solid var(--line)}
.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:22px}
.tool-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 26px 22px;display:flex;flex-direction:column;transition:.18s ease}
.tool-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px -18px rgba(15,27,45,.4);
  border-color:#d3d5ce}
.tool-name{font-size:1.35rem;margin-bottom:.15em}
.tool-lede{font-weight:600;color:var(--olive);margin:0 0 .7em}
.tool-blurb{color:var(--muted);margin:0 0 18px;flex:1}
.tool-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.chip{font-size:.78rem;font-weight:600;color:var(--navy);background:#eef0e8;
  padding:4px 11px;border-radius:30px}
.tool-link{font-weight:600;color:var(--navy)}
.tool-link:hover{color:var(--olive)}

/* ---------- pricing ---------- */
.pricing{padding:80px 0}
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.price-card{border:1px solid var(--line);border-radius:var(--radius);padding:28px;background:#fff}
.price-card.featured{border-color:var(--olive);box-shadow:0 0 0 1px var(--olive) inset}
.price-card h3{font-size:1.4rem;margin-bottom:.2em}
.price-includes{color:var(--muted);margin:0 0 18px;min-height:2.6em}
.price-rows{list-style:none;padding:0;margin:0}
.price-rows li{display:flex;justify-content:space-between;padding:9px 0;border-top:1px dashed var(--line)}
.price-rows li span{color:var(--muted)}
.price-rows li strong{font-family:var(--serif)}
.price-note{margin-top:24px;color:var(--muted)}

/* ---------- cta band ---------- */
.cta-band{background:var(--olive);color:#fff}
.cta-inner{padding:64px 24px;text-align:center;max-width:720px}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem)}
.cta-band p{color:rgba(255,255,255,.9);font-size:1.1rem;margin:0 0 26px}

/* ---------- footer ---------- */
.site-footer{background:var(--navy);color:rgba(242,242,240,.8)}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding:60px 24px 34px}
.footer-brand .brand-word{color:#fff}
.footer-tagline{margin:14px 0 10px;color:rgba(242,242,240,.85)}
.footer-philo{font-family:var(--serif);font-style:italic;color:rgba(242,242,240,.6);font-size:.98rem}
.footer-links h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.footer-links a{display:block;color:rgba(242,242,240,.78);padding:5px 0;font-size:.96rem}
.footer-links a:hover{color:#fff;text-decoration:none}
.footer-base{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  padding:18px 24px;border-top:1px solid rgba(255,255,255,.1);font-size:.88rem;color:rgba(242,242,240,.6)}
.footer-base a{color:rgba(242,242,240,.7)}

/* ---------- legal ---------- */
.legal{padding:60px 0}
.legal-wrap{max-width:780px}
.legal h1{font-size:2.2rem;margin-bottom:.4em}
.legal h2{font-size:1.4rem;margin:1.6em 0 .4em;padding-top:.4em;border-top:1px solid var(--line)}
.legal h3{font-size:1.1rem;margin:1.2em 0 .3em}
.legal p{color:#37414e;margin:0 0 1em}
.legal-scope{color:var(--muted);font-size:.98rem}
.legal-address{font-style:normal;background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:18px 20px;line-height:1.8;margin:0 0 1em}
.legal-disclaimer{background:#fbf6ea;border:1px solid #ecdcb4;border-radius:10px;padding:14px 18px;
  color:#6b5a2e;font-size:.95rem}
.legal-wrap section{scroll-margin-top:84px;margin-bottom:8px}
.legal-nav{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 22px;
  margin:8px 0 30px;display:grid;grid-template-columns:1fr 1fr;gap:6px 24px}
.legal-nav a{font-weight:500}
.legal-callout{background:#eef0e8;border:1px solid #dfe3d4;border-radius:10px;padding:14px 18px;color:#3c4636}
.legal-indent{margin-left:18px}
.legal ul{margin:0 0 1em;padding-left:22px}
.legal li{margin-bottom:.4em;color:#37414e}
.legal-footer-note{margin-top:30px;padding-top:18px;border-top:1px solid var(--line);
  color:var(--muted);font-size:.92rem;text-align:center}
@media (max-width:560px){.legal-nav{grid-template-columns:1fr}}

/* ---------- admin ---------- */
.admin-body{background:#eef0ee}
.admin-auth{min-height:calc(100vh - 68px);display:flex;align-items:center;justify-content:center;padding:40px 20px}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:38px 34px;
  width:100%;max-width:380px;box-shadow:0 20px 50px -30px rgba(15,27,45,.5)}
.auth-card h1{text-align:center;font-size:1.5rem;margin:18px 0 20px}
.auth-form{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.auth-form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.9rem;color:var(--navy)}
.auth-form input{font-family:var(--sans);font-size:1rem;padding:11px 13px;border:1px solid #cfd2cb;border-radius:8px}
.auth-form input:focus{outline:2px solid var(--olive);border-color:var(--olive)}
.auth-back{display:block;text-align:center;color:var(--muted);font-size:.9rem}
.center{justify-content:center}

.admin{padding:36px 0 70px}
.admin-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:8px}
.admin-top h1{font-size:1.9rem;margin:0}
.admin-top-actions{display:flex;align-items:center;gap:14px}
.admin-user{color:var(--muted);font-size:.92rem}
.admin-note{color:var(--muted);max-width:760px;margin:6px 0 26px}
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px 22px}
.kpi-num{display:block;font-family:var(--serif);font-weight:600;font-size:2.1rem;color:var(--navy)}
.kpi-label{color:var(--muted);font-size:.9rem}
.admin-panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 26px;margin-bottom:22px}
.admin-panel h2{font-size:1.25rem;margin-bottom:.6em}
.admin-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.admin-table{width:100%;border-collapse:collapse;font-size:.94rem}
.admin-table th{text-align:left;color:var(--muted);font-weight:600;font-size:.82rem;
  text-transform:uppercase;letter-spacing:.05em;padding:8px 10px;border-bottom:2px solid var(--line)}
.admin-table td{padding:10px;border-bottom:1px solid var(--line)}
.admin-table.compact td,.admin-table.compact th{padding:7px 8px}
.admin-table code{background:#eef0e8;padding:2px 6px;border-radius:5px;font-size:.85rem}
.pill{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:20px}
.pill.ok{background:#e4ecdb;color:#46583a}
.soon{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;background:var(--gold);
  color:var(--navy);padding:2px 8px;border-radius:20px;vertical-align:middle;margin-left:8px;font-family:var(--sans)}
.stub{color:var(--muted)}
.warn{background:#fbf6ea;border:1px solid #ecdcb4;color:#6b5a2e;padding:12px 16px;border-radius:10px;margin-bottom:18px}
.warn code,.admin-note code{background:#eadfc2;padding:1px 6px;border-radius:5px}
.error{background:#fdeceb;border:1px solid #f3c0bd;color:#8a2a23;padding:10px 14px;border-radius:8px;text-align:center}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .philo-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
  .admin-grid-2{grid-template-columns:1fr}
  .site-nav{gap:16px}
  .site-nav a:not(.nav-cta){display:none}
}
@media (max-width:560px){
  .footer-inner{grid-template-columns:1fr}
  .hero-inner{padding:60px 24px 66px}
}
