/* ===========================================================
   Fiorentis — editorial "Renaissance" B2B data platform
   Playfair Display (display) · Inter (body) · warm ivory + ink
   =========================================================== */
:root{
  --bg:#FBF8F1; --surface:#FFFFFF; --surface-2:#FFFDF8;
  --ink:#171311; --ink-soft:#4A423B; --muted:#6F665A;
  --line:#EAE3D5; --line-strong:#DDD3C0;
  --accent:#8B3A2F; --accent-bg:#F4E9E5;
  --gold:#A87C2B; --gold-soft:#E9C877; --gold-hi:#cda23f; --ink-hi:#1a1208;
  --green:#3C6A45; --green-bg:#EDF3ED;
  --amber:#8C6314; --amber-bg:#F8F0DC;
  --red:#9B3B33; --red-bg:#F7E8E5;
  --radius:14px; --maxw:1120px;
  --serif:"Newsreader","Iowan Old Style",Georgia,"Times New Roman",serif;
  --sans:"Helvetica Neue","Helvetica","Inter",Arial,sans-serif;
  --hero-img:url("/static/img/school-of-athens.jpg");
}
*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{margin:0;background:var(--bg);color:var(--ink);overflow-x:hidden;
  font-family:var(--sans);
  font-size:16px;line-height:1.55}
h1,h2,h3{font-family:var(--sans);font-weight:700;letter-spacing:-0.025em;color:var(--ink)}
.serif{font-family:var(--serif)}
.ren{font-family:var(--serif);font-style:italic;font-weight:500;letter-spacing:0}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
.muted{color:var(--muted)} .center{text-align:center}
img{max-width:100%}

/* ---- header / nav ---- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .35s ease}
.topbar .brand{color:#FBF8F1}
.topbar .navlink{color:rgba(251,248,241,.9)}
.topbar .navlink:hover{color:#fff}
.topbar .btn{background:#FBF8F1;color:var(--ink);border-color:#FBF8F1}
.topbar.show{background:rgba(251,248,241,.95);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar.show .brand{color:var(--ink)}
.topbar.show .navlink{color:var(--ink-soft)}
.topbar.show .navlink:hover{color:var(--ink)}
.topbar.show .btn{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;
  max-width:var(--maxw);margin:0 auto;padding:15px 24px}
body.no-hero main{padding-top:72px}
.brand{font-family:var(--sans);font-weight:700;font-size:24px;letter-spacing:-0.03em;color:var(--ink)}
.brand:hover{text-decoration:none}
.topbar nav{display:flex;gap:26px;align-items:center}
.navlink{color:var(--ink-soft);font-size:14.5px;font-weight:500;padding:9px 2px}
.navlink:hover{color:var(--ink);text-decoration:none}
@media(max-width:760px){.topbar nav{gap:14px}.navlink{font-size:13px}.brand{font-size:21px}}
@media(max-width:380px){.topbar nav{gap:10px}.navlink{font-size:12.5px}}

/* ---- buttons ---- */
.btn{display:inline-block;background:var(--ink);color:var(--bg);border:1px solid var(--ink);
  border-radius:10px;padding:13px 22px;font-size:15px;font-weight:600;cursor:pointer;
  font-family:inherit;transition:transform .04s ease,opacity .15s ease;margin-top:0}
.btn:hover{opacity:.88;text-decoration:none}.btn:active{transform:translateY(1px)}
.btn-big{padding:15px 26px;font-size:16px}
.btn-block{width:100%;text-align:center;margin-top:18px;padding:15px}
.btn-small{padding:12px 17px;font-size:13px}
.btn-light{background:var(--bg);color:var(--ink);border-color:var(--bg)}
.btn-outline{background:transparent;color:#FBF8F1;border-color:rgba(251,248,241,.55)}
.btn-outline:hover{background:rgba(251,248,241,.1);opacity:1}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px 80px}
.pad-top{padding-top:48px}
.eyebrow{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);font-weight:700;margin:0 0 16px}
.sub,.lead{color:var(--ink-soft)}
.lead{font-size:19px;max-width:660px;font-family:var(--serif);font-weight:400;line-height:1.45}

/* ---- hero with renaissance painting ---- */
.hero-art{position:relative;width:100vw;margin-left:calc(50% - 50vw);margin-top:0;
  background:image-set(url("/static/img/school-of-athens.avif") type("image/avif"),url("/static/img/school-of-athens.webp") type("image/webp"),url("/static/img/school-of-athens.jpg") type("image/jpeg")) center 28%/cover no-repeat,#15110d;
  color:#FBF8F1;display:flex;align-items:center;min-height:92vh}
.hero-art::before{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(11,8,5,.84),rgba(11,8,5,.6) 55%,rgba(11,8,5,.36)),
             linear-gradient(180deg,rgba(11,8,5,.34),rgba(11,8,5,.52))}
.hero-art .inner{position:relative;width:100%;max-width:var(--maxw);margin:0 auto;padding:90px 24px}
.hero-panel{width:100%;max-width:660px;border:1px solid rgba(251,248,241,.30);
  background:rgba(14,10,6,.42);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  padding:44px 46px;border-radius:2px}
.hero-brand{font-family:var(--sans);font-weight:700;font-size:15px;letter-spacing:.02em;
  color:#FBF8F1;margin-bottom:22px}
.hero-art .eyebrow{color:var(--gold-soft)}
.hero-art h1{color:#FBF8F1;font-size:clamp(44px,7vw,90px);line-height:0.98;margin:0 0 20px;max-width:15ch;font-weight:700;letter-spacing:-0.035em}
.hero-art .lead{color:rgba(251,248,241,.92);font-size:clamp(18px,2vw,23px);max-width:660px;font-family:var(--serif);font-weight:400}
.hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-stats{display:flex;gap:40px;margin-top:46px;flex-wrap:wrap}
.hero-stats .n{font-family:var(--serif);font-size:34px;font-weight:700;color:#fff;line-height:1}
.hero-stats .l{font-size:13px;color:rgba(251,248,241,.7);letter-spacing:.04em}
.hero-counter{margin-top:42px}
.hc-n{font-family:var(--sans);font-weight:700;color:#fff;line-height:1;letter-spacing:-.03em;
  font-size:clamp(44px,7vw,76px);font-variant-numeric:tabular-nums}
.hc-l{font-size:12.5px;color:rgba(251,248,241,.78);letter-spacing:.06em;margin-top:10px;text-transform:uppercase}

/* ---- sections ---- */
.section{padding:66px 0;border-top:1px solid var(--line)}
.section h2{font-size:clamp(28px,4vw,46px);margin:0 0 14px}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.feature{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.feature .k{font-family:var(--serif);font-size:26px;color:var(--gold);font-weight:600;margin-bottom:10px}
.feature h3{font-size:18px;margin:0 0 6px}
.feature p{margin:0;color:var(--muted);font-size:14.5px}

/* steps */
.steps{display:grid;gap:16px;margin-top:34px}
.step{display:flex;gap:22px;align-items:flex-start;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.step .n{font-family:var(--serif);font-size:30px;color:var(--gold);line-height:1;min-width:44px;font-weight:600;align-self:center}
.step h3{margin:0 0 4px;font-size:19px}.step p{margin:0;color:var(--ink-soft)}

/* pricing */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.plan{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:30px;display:flex;flex-direction:column}
.plan.featured{border:1.5px solid var(--ink);box-shadow:0 24px 60px -34px rgba(0,0,0,.45)}
.plan{transition:transform .2s cubic-bezier(.2,.7,.2,1),box-shadow .2s ease,border-color .2s ease}
.plan:hover{transform:translateY(-6px);box-shadow:0 30px 64px -30px rgba(20,15,9,.42);border-color:var(--gold);z-index:5}
.plan:has(.info:hover),.plan:has(.info:focus){z-index:30}
.plan .tier{font-weight:600;color:var(--ink-soft)}
.plan .price{font-family:var(--serif);font-size:46px;font-weight:700;margin:8px 0 2px}
.plan .price small{font-size:15px;color:var(--muted);font-family:"Inter",sans-serif;font-weight:500}
.plan ul{list-style:none;padding:0;margin:18px 0 22px}
.plan li{padding:9px 0;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--ink-soft)}
.plan li::before{content:"— ";color:var(--gold)}
.plan .btn{margin-top:auto}

/* cta band */
.cta-band{background:var(--ink);color:var(--bg);border-radius:20px;padding:54px 40px;text-align:center;margin-top:66px}
.cta-band h2{color:var(--bg);margin:0 0 10px}
.cta-band p{color:rgba(251,248,241,.8);max-width:520px;margin:0 auto 22px}

/* black, full-width comparison table (pricing page) */
.compare-table{width:100%;border-collapse:collapse;background:var(--ink);color:var(--bg);
  border-radius:18px;overflow:hidden;margin-top:26px;font-size:clamp(15px,1.6vw,18px)}
.compare-table th,.compare-table td{padding:21px 30px;border-bottom:1px solid rgba(251,248,241,.12);text-align:left}
.compare-table thead th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  color:rgba(251,248,241,.55);font-weight:600}
.compare-table td:last-child,.compare-table th:last-child{text-align:right;font-variant-numeric:tabular-nums}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-table .hi td{background:var(--gold-hi);color:var(--ink-hi);font-weight:600;font-size:1.05em}
.compare-table .hi td strong{color:var(--ink-hi)}
.compare-table .hi td:last-child{color:var(--ink-hi);font-weight:800}

/* forms / cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.card.narrow{max-width:480px;margin:40px auto}
.finder{box-shadow:0 12px 50px -30px rgba(23,19,17,.4)}
.finder .row{display:flex;gap:18px}.finder .row label{flex:1}
label{display:block;font-weight:600;font-size:13px;color:var(--ink-soft);margin:16px 0 6px}
.hint{color:var(--muted);font-weight:400;font-size:13px}
input,select,textarea{width:100%;padding:13px 14px;font-size:15px;color:var(--ink);background:var(--surface-2);
  border:1px solid var(--line-strong);border-radius:9px;font-family:inherit}
textarea{min-height:150px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.byo{margin-top:14px}.byo summary{cursor:pointer;color:var(--accent);font-size:14px}

/* searchable combobox */
.combo{position:relative}
.combo-list{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:40;display:none;
  max-height:280px;overflow:auto;background:#fff;border:1px solid var(--line-strong);border-radius:9px;
  box-shadow:0 18px 44px -22px rgba(0,0,0,.35)}
.combo-list.open{display:block}
.combo-opt{padding:10px 13px;cursor:pointer;font-size:14.5px}
.combo-opt:hover{background:var(--surface-2)}
.combo.err .combo-input{border-color:var(--red);box-shadow:0 0 0 3px var(--red-bg)}

/* info "i" icon + tooltip */
.info{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border-radius:50%;
  background:transparent;border:1.5px solid var(--gold);color:var(--gold);font-size:10px;font-style:italic;font-weight:700;
  cursor:help;position:relative;vertical-align:middle;margin-left:7px;outline:none}
.info::after{content:attr(data-tip);position:absolute;bottom:165%;left:0;
  width:262px;max-width:72vw;background:#15110b;color:#ece6d8;padding:13px 15px;border-radius:12px;
  border:1px solid rgba(205,162,63,.28);font-family:var(--sans);font-size:12.5px;font-style:normal;font-weight:400;line-height:1.5;letter-spacing:0;
  opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity .16s ease,transform .16s ease;z-index:70;
  box-shadow:0 18px 44px -18px rgba(20,15,9,.6)}
.info:hover::after,.info:focus::after{opacity:1;visibility:visible;transform:translateY(0)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start;margin-top:30px}
.success{background:var(--green-bg);border:1px solid #cfe0d0;color:var(--green);padding:14px 16px;border-radius:10px;margin-bottom:16px}

/* alerts */
.alert{background:var(--accent-bg);border:1px solid #E6CFC8;color:var(--accent);padding:13px 16px;border-radius:10px;margin:18px 0;font-size:14px}
.alert.demo{background:var(--amber-bg);border-color:#ECD9AE;color:var(--amber)}

/* results */
.crumbs{margin:0 0 10px;font-size:14px;padding-top:8px}
.results-h{font-size:clamp(26px,4vw,40px);margin:6px 0}
.results-h .muted{font-style:italic;font-weight:400}
table.leads{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;font-size:14.5px;margin-top:8px}
.leads th,.leads td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:top}
.leads th{font-family:"Inter",sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;background:var(--surface-2)}
.leads tr:last-child td{border-bottom:none}
.snip{color:var(--muted)} .ev{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--ink-soft)}
tr.band-green{box-shadow:inset 3px 0 0 var(--green)}
tr.band-yellow{box-shadow:inset 3px 0 0 var(--amber)}
tr.band-red{box-shadow:inset 3px 0 0 var(--line-strong)}
tr.excluded{opacity:.5}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px}
.dot-green{background:var(--green)}.dot-yellow{background:var(--amber)}.dot-red{background:var(--red)}
.pill{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid var(--line-strong)}
.pill-green{background:var(--green-bg);color:var(--green);border-color:#CFE0D0}
.locked{margin-top:26px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:32px;text-align:center}
.locked h2{font-size:23px;margin:0 0 8px}.locked p{color:var(--ink-soft);max-width:470px;margin:0 auto 8px}
.ghost-rows .leads{filter:blur(3px);opacity:.5;pointer-events:none}
.deepform{margin-top:22px;display:flex;gap:18px;align-items:center}
.inline{display:inline-flex;gap:8px;align-items:center;margin:0;font-weight:400;color:var(--ink-soft)}

/* footer */
.foot{border-top:1px solid var(--line);margin-top:60px;background:var(--surface-2)}
.foot-cols{max-width:var(--maxw);margin:0 auto;padding:46px 24px 26px;display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
.foot-brand .brand{font-family:var(--sans);font-weight:700;font-size:22px;letter-spacing:-0.03em;color:var(--ink)}
.foot-brand p{color:var(--muted);font-size:13.5px;max-width:280px;margin:10px 0 0;line-height:1.6}
.foot-col h4{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:2px 0 12px}
.foot-col a{display:block;color:var(--ink-soft);font-size:14px;padding:8px 0}
.foot-col a:hover{color:var(--ink)}
.foot-bottom{max-width:var(--maxw);margin:0 auto;padding:16px 24px 30px;display:flex;justify-content:space-between;
  gap:16px;flex-wrap:wrap;border-top:1px solid var(--line);color:var(--muted);font-size:12.5px}
.foot-bottom a{color:var(--muted)}

/* trust strip */
.trust-strip{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;
  padding:14px 0;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--ink-soft)}
.trust-strip span{display:inline-flex;align-items:center;font-weight:500}
.trust-strip span::before{content:"✓";color:var(--green);font-weight:700;margin-right:7px}

/* sample table (landing) */
.sample-table{margin-top:18px}
.sample-table td{font-size:13.5px}

/* prose (about / legal / blog / seo content) */
.prose{max-width:680px}
.prose p{margin:0 0 16px;color:var(--ink-soft)}
.prose h2{font-size:22px;margin:30px 0 10px;color:var(--ink)}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.prose .lead{color:var(--ink)}

/* FAQ */
.faqlist{max-width:760px;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{cursor:pointer;padding:18px 2px;font-weight:600;font-size:17px;list-style:none;
  display:flex;justify-content:space-between;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--gold);font-size:22px;font-weight:400}
.faq-item[open] summary::after{content:"–"}
.faq-item p{margin:0 0 18px;color:var(--ink-soft);max-width:680px}

/* testimonials */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:24px}
.quote{margin:0;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:24px}
.quote p{font-family:var(--serif);font-size:19px;line-height:1.4;margin:0 0 14px;color:var(--ink)}
.quote cite{font-style:normal;font-size:13px;color:var(--muted);font-weight:600}

/* blog list */
.post-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.post-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:26px;
  color:var(--ink);transition:box-shadow .15s ease,transform .04s ease}
.post-card:hover{text-decoration:none;box-shadow:0 18px 44px -28px rgba(0,0,0,.35)}
.post-date{font-size:12px;color:var(--muted);letter-spacing:.03em}
.post-card h2{font-size:21px;margin:8px 0 8px}
.post-card p{color:var(--muted);font-size:14.5px;margin:0 0 14px}
.post-card .readmore{color:var(--accent);font-weight:600;font-size:14px}

/* hero microcopy, 'most popular' badge, changelog */
.hero-micro{margin-top:14px;font-size:13px;color:rgba(251,248,241,.75);letter-spacing:.01em}
.plan{position:relative}
.popular{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 13px;border-radius:20px;white-space:nowrap}
.changelog{max-width:720px}
.cl-entry{display:grid;grid-template-columns:140px 1fr;gap:20px;padding:22px 0;border-top:1px solid var(--line)}
.cl-date{font-weight:600;color:var(--muted);font-size:14px}
.cl-entry ul{margin:0;padding-left:18px}
.cl-entry li{margin:6px 0;color:var(--ink-soft);font-size:15px}
@media(max-width:600px){.cl-entry{grid-template-columns:1fr;gap:6px}}

/* admin */
.admin-head{display:flex;justify-content:space-between;align-items:center;padding-top:8px}
.kpis{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin:10px 0 22px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;text-align:center}
.kpi-n{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--ink)}
.kpi-l{font-size:11.5px;color:var(--muted);margin-top:3px}
.card h2{margin:0 0 12px;font-size:20px}.card+.card{margin-top:18px}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}.cols2 .card{margin-top:0}
.bars{display:flex;align-items:flex-end;gap:7px;height:120px;padding-top:8px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.bar{width:64%;background:var(--gold);border-radius:3px 3px 0 0;min-height:2px;opacity:.85}
.bar-x{font-size:10px;color:var(--muted);margin-top:5px;transform:rotate(-45deg);white-space:nowrap}

@media(max-width:820px){.features{grid-template-columns:1fr}.plans{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(3,1fr)}.cols2{grid-template-columns:1fr}
  .foot-cols{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-cols{grid-template-columns:1fr}}
@media(max-width:640px){.finder .row,.deepform{flex-direction:column}.hero-stats{gap:24px}}

/* ---- Pro advanced panel on search ---- */
.adv{margin-top:18px;border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden}
.adv>summary{cursor:pointer;padding:14px 18px;font-weight:600;list-style:none;display:flex;align-items:center;gap:10px}
.adv>summary::-webkit-details-marker{display:none}
.adv>summary::before{content:"+";font-weight:700;color:var(--gold);font-size:18px;line-height:1}
.adv[open]>summary::before{content:"–"}
.adv-body{padding:4px 18px 20px;display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--line)}
.adv-body textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font:inherit;resize:vertical}
.adv-toggles{gap:18px}
.adv-locked{margin-top:18px;padding:14px 18px;border:1px dashed var(--line);border-radius:14px;color:var(--muted);font-size:14px}
.adv-locked strong{color:var(--ink)}
.adv-locked a{margin-left:6px;color:var(--gold);font-weight:600;white-space:nowrap}
.band-grey td{opacity:.72}
.dot-grey{background:#b9b3a7}

/* ---- Apollo-style impact band ---- */
.impact{margin:0;padding:62px 0 8px}
.impact-quote{margin:0 auto;font-family:var(--serif);font-size:clamp(24px,3.4vw,40px);line-height:1.18;letter-spacing:-.01em;max-width:30ch;text-align:center}
.impact-by{margin-top:16px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-align:center}
.impact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.impact-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px 22px 26px;display:flex;flex-direction:column;justify-content:space-between;min-height:190px}
.impact-card .ic-top{display:flex;justify-content:space-between;align-items:flex-start;color:var(--muted);font-size:14px;gap:10px}
.impact-card .ic-tag{font-weight:600;color:var(--ink);white-space:nowrap}
.impact-card .ic-big{font-size:clamp(40px,5vw,64px);font-weight:700;letter-spacing:-.02em;color:var(--ink);line-height:1}
@media(max-width:820px){.impact-cards{grid-template-columns:1fr}}

/* ---- auth + account ---- */
.auth-wrap{max-width:560px}
.auth-card{margin-top:20px;display:flex;flex-direction:column;gap:14px}
.auth-card input{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font:inherit}
.acct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}
.acct-card h3{margin:0 0 8px;font-size:15px}
.acct-plan{font-family:var(--serif);font-size:34px;line-height:1;margin:0 0 6px}
.acct-sub{font-size:18px;color:var(--muted)}
.btn-ghost{background:transparent;border:1px solid var(--ink);color:var(--ink)}
@media(max-width:820px){.acct-grid{grid-template-columns:1fr}}
.nav-avatar{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;
  background:var(--gold);color:var(--ink-hi);font-weight:700;font-size:15px;text-decoration:none;flex:none}
.nav-avatar:hover{filter:brightness(1.05)}
.qpeek{margin-top:14px;max-width:440px;background:#16110a;border-radius:12px;padding:8px 14px;
  font:13px/1 ui-monospace,Menlo,Consolas,monospace}
.qrow{display:flex;justify-content:space-between;gap:16px;padding:8px 2px;color:#e9e2d2;border-bottom:1px solid rgba(255,255,255,.07)}
.qrow b{color:var(--gold);font-weight:600}
.qrow b::before{content:"["}.qrow b::after{content:"]"}
.qmore{padding:9px 2px 4px;color:#9a917f}
.blur{filter:blur(3.5px);-webkit-user-select:none;user-select:none;pointer-events:none}
.ent-card{margin-top:22px;background:#15110b;color:#ece6d8;border-radius:20px;overflow:hidden}
.ent-art{height:150px;background:#2a2118 center 32%/cover no-repeat;
  background-image:linear-gradient(180deg,rgba(21,17,11,0) 55%,rgba(21,17,11,.95)),
  image-set(url('/static/img/primavera.avif') type('image/avif'),url('/static/img/primavera.webp') type('image/webp'),url('/static/img/primavera.jpg') type('image/jpeg'))}
.ent-inner{padding:clamp(24px,3vw,36px);display:grid;grid-template-columns:1fr 1.1fr;gap:30px;align-items:center}
.ent-card .tier{font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--gold)}
.ent-price{font-family:var(--sans);font-size:clamp(34px,5vw,52px);font-weight:700;letter-spacing:-.02em;line-height:1;margin:8px 0 12px}
.ent-card p{color:#b8b09c;margin:0 0 20px;max-width:34ch}
.ent-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:11px 24px}
.ent-list li{position:relative;padding-left:24px;font-size:14.5px}
.ent-list li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}
@media(max-width:760px){.ent-inner{grid-template-columns:1fr}.ent-list{grid-template-columns:1fr}}

/* ---- scroll-reveal animations (site-wide) ---- */
.reveal{opacity:0;transform:translateY(22px) scale(.986);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
/* ---- painting accents (more Renaissance art) ---- */
html,body{overflow-x:hidden}
.sec-art{height:170px;border-radius:18px;margin-bottom:28px;background:#2a2118 center 46%/cover no-repeat}
/* full-bleed dark sections for contrast + drama */
.dark-section{margin:64px calc(50% - 50vw) 64px;padding:74px calc(50vw - 50%);background:#15110b;color:#ece6d8;border-top:none}
.dark-section .eyebrow{color:var(--gold)}
.dark-section h1,.dark-section h2,.dark-section h3{color:#fff}
.dark-section p,.dark-section .lead{color:#b8b09c}
.dark-section a{color:var(--gold)}
.dark-section .step{border-color:rgba(255,255,255,.12)}
.dark-section .n{color:var(--gold)}
.dark-section.art{background-image:linear-gradient(rgba(21,17,11,.9),rgba(21,17,11,.965)),image-set(url('/static/img/school-of-athens.avif') type('image/avif'),url('/static/img/school-of-athens.webp') type('image/webp'),url('/static/img/school-of-athens.jpg') type('image/jpeg'));background-size:cover;background-position:center}
.cta-band{background-image:linear-gradient(rgba(20,15,9,.84),rgba(20,15,9,.92)),image-set(url('/static/img/creation-of-adam.avif') type('image/avif'),url('/static/img/creation-of-adam.webp') type('image/webp'),url('/static/img/creation-of-adam.jpg') type('image/jpeg'));background-size:cover;background-position:center 22%}

/* ---- interlink hubs ---- */
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 26px;margin-top:26px}
.hub-item{padding:12px 0;border-bottom:1px solid var(--line)}
.hub-main{font-weight:600;display:block}
.hub-subs{margin-top:4px;display:flex;flex-wrap:wrap;gap:10px}
.hub-subs a{font-size:12px;color:var(--muted)}
@media(max-width:820px){.hub-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.hub-grid{grid-template-columns:1fr}}

/* ---- sign-in modal floating over a blurred search page ---- */
.login-modal{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(23,19,17,.46);
  -webkit-backdrop-filter:blur(9px) saturate(1.05);backdrop-filter:blur(9px) saturate(1.05);
  animation:loginFade .22s ease both}
@keyframes loginFade{from{opacity:0}to{opacity:1}}
.login-modal-card{position:relative;width:100%;max-width:456px;background:var(--surface);
  border:1px solid var(--line);border-radius:20px;padding:44px 42px 36px;text-align:left;
  box-shadow:0 36px 90px rgba(20,15,8,.40);animation:loginRise .3s cubic-bezier(.2,.7,.3,1) both}
@keyframes loginRise{from{transform:translateY(16px) scale(.985);opacity:0}to{transform:none;opacity:1}}
.login-modal-card .eyebrow{color:var(--gold);font-size:12px;letter-spacing:.12em;margin:0 0 18px}
.login-modal-card h2{font-family:var(--serif);font-size:31px;line-height:1.12;letter-spacing:-.01em;margin:0 0 14px;color:var(--ink)}
.login-modal-card .sub{color:var(--ink-soft);margin:0 0 26px;font-size:15.5px;line-height:1.55}
.login-form{display:flex;flex-direction:column;gap:16px}
.login-form .btn-block{margin-top:6px}
.login-input{width:100%;padding:15px 16px;font-size:16px;font-family:inherit;color:var(--ink);
  border:1px solid var(--line-strong);border-radius:12px;background:var(--surface-2)}
.login-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(168,124,43,.16)}
.login-modal-card .hint a{color:var(--accent)}
.login-close{position:absolute;top:12px;right:14px;font-size:26px;line-height:1;color:var(--muted);
  text-decoration:none;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:9px}
.login-close:hover{color:var(--ink);background:var(--bg)}
@media(max-width:520px){.login-modal-card{padding:34px 24px 28px}.login-modal-card h2{font-size:27px}}

/* ---- account: recent searches ---- */
.hist{display:flex;flex-direction:column;margin-top:4px}
.hist-row{display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:12px 2px;border-bottom:1px solid var(--line);color:var(--ink);font-size:15px}
.hist-row:last-child{border-bottom:none}
.hist-row:hover{text-decoration:none}
.hist-row:hover .hist-go{text-decoration:underline}
.hist-go{color:var(--accent);font-size:13px;font-weight:600;white-space:nowrap}

/* ---- button loading state + spinner ---- */
.btn.is-loading{pointer-events:none;opacity:.94}
.spin{display:inline-block;width:14px;height:14px;margin-right:9px;vertical-align:-2px;
  border:2px solid currentColor;border-right-color:transparent;border-radius:50%;
  animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.spin{animation-duration:1.5s}}

/* ---- keyboard focus rings (accessibility) ---- */
a:focus-visible,.btn:focus-visible,button:focus-visible,summary:focus-visible,.combo-input:focus-visible{
  outline:2px solid var(--gold);outline-offset:2px;border-radius:6px}
.btn:focus-visible{outline-offset:3px}

/* ---- wide tables scroll instead of breaking on small screens ---- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:640px){
  .table-wrap .leads,.table-wrap .sample-table{min-width:560px}
  .table-wrap{margin-inline:-4px;padding-inline:4px}
}

/* ---- empty results state ---- */
.empty-state{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);
  padding:40px 28px;text-align:center;margin-top:10px}
.empty-state h2{font-size:22px;margin:0 0 8px}
.empty-state p{color:var(--ink-soft);max-width:440px;margin:0 auto 16px}

/* ---- editorial stat band (replaces the identical stat cards) ---- */
.stat-row{display:flex;flex-wrap:wrap;justify-content:center;margin-top:34px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{flex:1;min-width:190px;text-align:center;padding:30px 20px;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat-n{display:block;font-family:var(--serif);font-size:clamp(32px,4.4vw,46px);font-weight:700;
  color:var(--ink);line-height:1;letter-spacing:-.01em}
.stat-l{display:block;font-size:13px;color:var(--muted);margin:10px auto 0;max-width:24ch;line-height:1.45}
@media(max-width:560px){.stat{flex-basis:100%;border-left:none;border-top:1px solid var(--line);padding:22px}
  .stat:first-child{border-top:none}}

/* phones get the 800w hero (image-optimization pass) */
@media (max-width:760px){.hero-art{background-image:image-set(url("/static/img/school-of-athens-800.avif") type("image/avif"),url("/static/img/school-of-athens-800.webp") type("image/webp"),url("/static/img/school-of-athens-800.jpg") type("image/jpeg")),linear-gradient(#15110d,#15110d);}}

/* self-hosted fonts (Newsreader + Inter, latin/latin-ext) */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/inter-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/inter-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/inter-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/inter-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/inter-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/inter-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/newsreader-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/newsreader-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/newsreader-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/newsreader-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/newsreader-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/newsreader-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/newsreader-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/newsreader-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
