/* ============================================================
   LYCEUM MUNDI — Public marketing site (brochure) stylesheet.
   Self-contained: loaded ONLY by the public pages (index, how,
   curriculum, florida, pricing, start). The signed-in app uses
   brand.css + site.css instead, so there is no class collision.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --navy:#1B2A4A; --navy7:#24365C; --navy9:#0F1A30;
  --gold:#C2A14D; --gold-l:#D9BE73; --gold-d:#9A7E33;
  --ivory:#FAF6EC; --paper:#fff; --ink:#1E2330; --stone:#6B6E76; --line:#E4DCC8;
  --display:'Cormorant Garamond',Georgia,serif;
  --body:'EB Garamond',Georgia,serif;
  --ui:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--ivory);color:var(--ink);font-family:var(--body);font-size:18px;line-height:1.62;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);color:var(--navy);font-weight:600;line-height:1.08;letter-spacing:.005em;margin:0}
h1{font-size:60px} h2{font-size:40px} h3{font-size:25px} h4{font-size:20px}
p{margin:0 0 1em}
a{color:var(--navy)}
.wrap{max-width:1120px;margin:0 auto;padding:0 40px}
.eyebrow{font-family:var(--ui);font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-d)}
.eyebrow.on-navy{color:var(--gold-l)}
.lede{font-size:21px;color:var(--stone)}
.gold-rule{width:54px;height:3px;background:var(--gold);border:0;margin:18px 0 26px}
.center{text-align:center}
.center .gold-rule{margin-left:auto;margin-right:auto}

/* NAV */
.nav{background:var(--navy);color:#fff;border-bottom:2px solid var(--gold)}
.nav .wrap{display:flex;align-items:center;gap:22px;height:84px}
.brand{display:flex;align-items:center;gap:13px;margin-right:auto;text-decoration:none}
.brand img{height:50px;width:50px;display:block}
.brand .bt{font-family:var(--display);font-size:23px;font-weight:600;letter-spacing:.08em;line-height:1;color:#fff}
.brand .bs{font-family:var(--body);font-style:italic;font-size:12.5px;color:var(--gold-l);letter-spacing:.02em}
.nav a.link{font-family:var(--ui);font-size:15px;color:#E9E4D6;text-decoration:none;font-weight:500;text-transform:capitalize;position:relative;padding-bottom:9px}
/* Active/hover underline lives in its own row beneath the label — reserved for every link so
   the active item never shifts the text up. */
.nav a.link::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;border-radius:2px;background:transparent;transition:background .15s}
.nav a.link:hover{color:#fff}
.nav a.link:hover::after{background:rgba(217,190,115,.45)}
/* Title-case pane / card headings (not the long hero sentence headings). */
.card h3,.step h4,.plan .pname,.guarantee h3{text-transform:capitalize}
.foot .cols a{text-transform:capitalize}
.nav a.link.here{color:#fff}
.nav a.link.here::after{background:var(--gold)}
/* Buttons — polished-metal finish (subtle bevel: top highlight, mid body, bottom reflection). */
.btn{font-family:var(--ui);font-weight:600;font-size:15px;border-radius:7px;padding:11px 20px;text-decoration:none;display:inline-block;cursor:pointer;border:1px solid transparent;text-transform:capitalize;white-space:nowrap;line-height:1.1;transition:filter .15s,box-shadow .15s,transform .04s}
.btn:active{transform:translateY(1px)}
/* Polished gold */
.btn-gold{background:linear-gradient(180deg,#EAD08A 0%,#D9BE73 20%,#C2A14D 54%,#A9863A 84%,#CBAA55 100%);color:#0F1A30;border-color:#8C6F2E;text-shadow:0 1px 0 rgba(255,255,255,.28);box-shadow:inset 0 1px 0 rgba(255,255,255,.6),inset 0 -1px 0 rgba(0,0,0,.18),0 2px 7px rgba(15,26,48,.22)}
.btn-gold:hover{filter:brightness(1.05)}
/* Frosted metal ghost — legible over the navy/hero photo */
.btn-ghost{background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.05));color:#fff;border-color:rgba(255,255,255,.6);box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 2px 6px rgba(0,0,0,.18)}
.btn-ghost:hover{background:linear-gradient(180deg,rgba(255,255,255,.30),rgba(255,255,255,.12));border-color:#fff;color:#fff}
/* Polished navy steel */
.btn-navy{background:linear-gradient(180deg,#364970 8%,#24365C 55%,#15223D 100%);color:#fff;border-color:#0E1830;box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 2px 7px rgba(15,26,48,.3)}
.btn-navy:hover{filter:brightness(1.12)}
/* Brushed steel — light buttons */
.btn-outline{background:linear-gradient(180deg,#ffffff 0%,#eef0f3 20%,#dfe3e8 55%,#c9ced5 85%,#e6eaee 100%);color:var(--navy);border-color:#aab0b8;box-shadow:inset 0 1px 0 rgba(255,255,255,.85),inset 0 -1px 0 rgba(0,0,0,.1),0 2px 6px rgba(15,26,48,.15)}
.btn-outline:hover{filter:brightness(1.03);border-color:var(--navy)}
.btn-lg{font-size:16.5px;padding:15px 28px}
/* Keep nav buttons crisp and uncrushed at mid widths */
.nav .btn{flex:none;padding:9px 18px;font-size:14.5px}
.nav a.link{white-space:nowrap}

/* HERO */
.hero{background:
   radial-gradient(120% 120% at 80% 10%, rgba(194,161,77,.16), transparent 55%),
   linear-gradient(180deg,var(--navy7),var(--navy9));
   color:#fff;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;opacity:.06;
   background-image:repeating-linear-gradient(45deg,#C2A14D 0 1px,transparent 1px 22px),
                    repeating-linear-gradient(-45deg,#C2A14D 0 1px,transparent 1px 22px)}
.hero .wrap{position:relative;z-index:2;padding:88px 40px 96px}
.hero h1{color:#fff;max-width:18ch}
.hero .lede{color:#D7DCEA;max-width:46ch;margin:22px 0 34px;font-size:22px}
.hero .cta-row{display:flex;gap:16px;flex-wrap:wrap}

/* SECTIONS */
.sec{padding:78px 0}
.sec.tight{padding:58px 0}
.sec-head{max-width:62ch}
.sec-head.center{margin:0 auto}

/* PILLARS / CARD GRID */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:34px 30px;box-shadow:0 10px 30px rgba(15,26,48,.06)}
.card .ic{font-size:30px;line-height:1;margin-bottom:14px}
/* Engraving-vignette medallion replacing the old emoji icons (see scripts/gen_card_art.py). */
.card .ic-art,.plan .ic-art{display:block;width:92px;height:92px;border-radius:50%;object-fit:cover;
  margin:0 0 18px;border:1px solid rgba(194,161,77,.55);background:var(--ivory);
  box-shadow:0 6px 18px rgba(15,26,48,.10)}
.card h3{margin-bottom:10px}
.card p{font-size:17px;color:#41454f;margin:0}

/* STEP STRIP */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.step{padding:30px 26px;border-right:1px solid var(--line)}
.step:last-child{border-right:0}
.step .n{font-family:var(--display);font-size:34px;color:var(--gold);font-weight:700}
.step h4{margin:6px 0 8px}
.step p{font-size:16px;color:#41454f;margin:0}

/* NAVY BAND */
.band{background:linear-gradient(180deg,var(--navy7),var(--navy9));color:#fff}
.band .wrap{padding:66px 40px}
.band h2{color:#fff}
.band p{color:#D7DCEA;max-width:60ch}
.band .q{font-family:var(--display);font-size:30px;color:var(--gold-l);font-style:italic;margin-bottom:10px}

/* TWO-COL COMPLIANCE TABLE */
.twocol{width:100%;border-collapse:separate;border-spacing:0;background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 14px 36px rgba(15,26,48,.08)}
.twocol th{font-family:var(--ui);font-size:13px;font-weight:700;text-align:left;padding:16px 24px;letter-spacing:.06em;text-transform:uppercase}
.twocol th:first-child{background:var(--navy9);color:var(--gold-l)}
.twocol th.col-do{background:var(--gold);color:var(--navy9)}
.twocol td{padding:15px 24px;border-top:1px solid var(--line);font-size:16.5px;vertical-align:top;width:50%}
.twocol td:first-child{color:#41454f}
.twocol td.do{color:var(--navy);font-weight:600;background:rgba(194,161,77,.08);border-left:3px solid var(--gold);position:relative;padding-left:44px}
.twocol td.do::before{content:"✓";position:absolute;left:18px;color:var(--gold-d);font-weight:800}

/* EVALUATOR CALLOUT */
.callout{background:#FFFDF6;border:2px solid var(--gold);border-radius:14px;padding:34px 36px;box-shadow:0 10px 30px rgba(154,126,51,.12)}
.callout::after{content:"";display:block;clear:both} /* contain floated .callout-fig images */
.callout .tag{font-family:var(--ui);font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-d);margin-bottom:10px}
.callout h3{margin-bottom:12px}
.callout p{font-size:17px;color:#41454f}
/* A photo set INSIDE a callout — smaller, floated beside the copy (not full-width). */
.callout-fig{float:right;width:340px;max-width:42%;margin:2px 0 16px 26px}
@media(max-width:680px){.callout-fig{float:none;width:auto;max-width:none;margin:6px 0 18px}}
/* Motto pane — a featured navy-and-gold panel for the Latin motto */
.motto-pane{text-align:center;background:linear-gradient(160deg,#24365C,#0F1A30);color:#fff;border:1px solid var(--gold-d);
  border-radius:18px;padding:54px 44px;box-shadow:0 22px 60px rgba(15,26,48,.28);max-width:880px;margin:0 auto}
.motto-crest{width:64px;height:64px;display:block;margin:0 auto 14px}
.motto-pane .eyebrow{color:var(--gold-l)}
.motto-latin{font-family:var(--display);font-style:italic;font-weight:600;font-size:46px;color:var(--gold-l);margin:10px 0 0;line-height:1.05}
.motto-rule{width:70px;height:2px;background:var(--gold);margin:20px auto}
.motto-text{color:#E7ECF5;font-size:20px;max-width:52ch;margin:0 auto}
@media(max-width:560px){.motto-latin{font-size:34px}.motto-pane{padding:40px 26px}}

/* PRICING */
.price-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:30px;align-items:start}
.plan{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:38px 34px;box-shadow:0 14px 36px rgba(15,26,48,.08)}
.plan.feature{border:2px solid var(--navy)}
.plan .pname{font-family:var(--ui);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-d)}
.plan .amt{font-family:var(--display);font-size:54px;color:var(--navy);font-weight:700;margin:8px 0 2px;line-height:1}
.plan .per{font-family:var(--ui);font-size:15px;color:var(--stone)}
.feat{list-style:none;padding:0;margin:22px 0 26px}
.feat li{padding:9px 0 9px 30px;position:relative;font-size:16.5px;border-top:1px solid var(--line)}
.feat li:first-child{border-top:0}
.feat li::before{content:"✓";position:absolute;left:0;top:9px;color:var(--gold);font-weight:700}

/* LIST WITH CHECK on navy */
ul.clean{list-style:none;padding:0;margin:0}
ul.clean li{padding:8px 0 8px 26px;position:relative}
ul.clean li::before{content:"—";position:absolute;left:0;color:var(--gold)}

/* ROLES TABLE */
.roles{width:100%;border-collapse:separate;border-spacing:0;background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 14px 36px rgba(15,26,48,.08)}
.roles th,.roles td{padding:16px 24px;text-align:left;font-size:16.5px;border-top:1px solid var(--line)}
.roles thead th{border-top:0;font-family:var(--ui);font-size:13px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.roles thead th:first-child{background:var(--navy9);color:var(--gold-l)}
.roles thead th.col-you{background:var(--gold);color:var(--navy9)}
.roles thead th.col-lm{background:var(--navy);color:#fff}
.roles td:first-child{font-family:var(--ui);font-size:12.5px;font-weight:700;color:var(--gold-d);text-transform:uppercase;letter-spacing:.05em;width:20%;background:#FCFAF3}
.roles td.you{color:var(--navy);font-weight:600;background:rgba(194,161,77,.08);border-left:3px solid var(--gold)}
.roles td.lm{color:#41454f}

/* GUARANTEE BAND */
.guarantee{background:#FFFDF6;border-top:2px solid var(--gold);border-bottom:2px solid var(--gold)}
.guarantee .wrap{padding:44px 40px;text-align:center}
.guarantee h3{color:var(--gold-d);margin-bottom:8px}
.guarantee p{max-width:64ch;margin:0 auto;color:#41454f}

/* FAQ */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.qa{border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:12px;background:var(--paper);padding:18px 24px;box-shadow:0 6px 18px rgba(15,26,48,.05)}
.qa .q{font-family:var(--display);font-size:21px;color:var(--navy);display:flex;gap:13px;align-items:flex-start}
.qa .q::before{content:"?";font-family:var(--ui);font-weight:800;font-size:13px;color:var(--navy9);background:var(--gold);width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex:none;margin-top:5px}
.qa .a{margin:8px 0 0 37px;color:#41454f;font-size:16.5px}

/* CLOSING CTA */
.closer{background:linear-gradient(180deg,var(--navy7),var(--navy9));color:#fff;text-align:center}
.closer .wrap{padding:64px 40px}
.closer h2{color:#fff;margin-bottom:22px}
.closer .cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
.foot{background:var(--navy9);color:#C7CDDC;font-family:var(--ui);font-size:14px}
.foot .wrap{padding:48px 40px 40px}
.foot .top{display:flex;gap:16px;align-items:center;margin-bottom:26px}
.foot .top img{height:34px;width:34px}
.foot .top .ft{font-family:var(--display);font-size:20px;letter-spacing:.08em;color:#fff}
.foot .cols{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid rgba(255,255,255,.12);padding-top:26px}
.foot .cols h5{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-l);margin:0 0 12px}
.foot .cols a{display:block;color:#C7CDDC;text-decoration:none;padding:4px 0}
.foot .cols a:hover{color:#fff}
.foot .fine{margin-top:28px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);color:#8C93A6;line-height:1.6;text-align:justify;-webkit-hyphens:auto;hyphens:auto}
.pill{display:inline-block;font-family:var(--ui);font-size:12.5px;color:var(--gold-l);border:1px solid rgba(194,161,77,.5);border-radius:999px;padding:5px 13px;text-transform:capitalize}
.tease{text-align:center}
.tease .big{font-family:var(--display);font-size:30px;color:var(--navy)}

/* WAITLIST (/start) */
.waitlist{max-width:640px;margin:0 auto;text-align:center}
.waitlist .card{padding:42px 38px}
.waitlist .amt{font-family:var(--display);font-size:30px;color:var(--navy);margin:0 0 4px}
.waitlist .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}

/* HERO PHOTO BACKDROP — per page via --hero-img; sits over the navy
   gradient at low opacity so white hero text stays legible. */
.hero.photo::before{content:"";position:absolute;inset:0;z-index:0;
  background-image:var(--hero-img);background-size:cover;background-position:center;
  opacity:var(--hero-op,.34)}
.hero.photo .wrap{position:relative;z-index:2}

/* FEATURE IMAGE (framed artwork inside an ivory section) */
.feature-figure{margin:0}
.feature-img{display:block;width:100%;height:auto;border-radius:14px;
  border:1px solid var(--line);box-shadow:0 18px 44px rgba(15,26,48,.15)}
.feature-figure figcaption{font-family:var(--ui);font-size:13.5px;color:var(--stone);
  text-align:center;margin-top:13px;letter-spacing:.02em}

/* MEDIA SPLIT — copy alongside a lifestyle photo */
.media-split{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.media-split .ms-text h2{margin-top:0}
.media-split.rev .ms-text{order:2}
.media-split .ms-text p{margin:0 0 12px}

/* FEATURED PANE (e.g. the College-Bound block) */
.feature-pane{background:var(--ivory);border:1px solid var(--line);border-top:4px solid var(--gold);
  border-radius:16px;padding:34px 36px;box-shadow:0 18px 44px rgba(15,26,48,.10)}
.feature-pane .tag{display:inline-block;font-family:var(--ui);font-size:12px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gold-d);margin-bottom:8px}
@media(max-width:760px){.feature-pane{padding:24px 20px}}

/* Justified body prose — clean right edges, with hyphenation to avoid word-gaps.
   Centered blocks, ledes, and headings stay as designed. */
.card p, .callout p, .feature-pane p, .ms-text p, .step p, .band p, .guarantee p,
.legal p, .legal li, .qa .a,
.sec .wrap:not(.center) > p:not(.lede):not(.big){
  text-align:justify; text-justify:inter-word; -webkit-hyphens:auto; hyphens:auto;
}

/* COURSE CATALOG — multi-column course lists */
.catalog-list{list-style:none;padding:0;margin:14px 0 0;columns:3;column-gap:40px}
.catalog-list li{break-inside:avoid;padding:8px 0 8px 22px;position:relative;border-bottom:1px solid var(--line);font-size:15.5px;color:#41454f}
.catalog-list li::before{content:"—";position:absolute;left:0;color:var(--gold)}
.catalog-list li.ap{font-weight:700;color:var(--navy)}
@media(max-width:860px){.catalog-list{columns:2;column-gap:28px}}
@media(max-width:560px){.catalog-list{columns:1}}
/* "Explore" button on the curriculum subject cards */
.card .explore{margin-top:16px;padding:8px 16px;font-size:14px}

/* LEGAL / long-form text (Terms page) */
.legal{max-width:820px;margin:0 auto}
.legal h2{font-size:24px;margin:34px 0 8px}
.legal h3{font-size:19px;margin:22px 0 6px}
.legal p,.legal li{color:#41454f;font-size:16.5px;line-height:1.72}
.legal ul{padding-left:20px;margin:8px 0}
.legal li{margin:6px 0}

/* CATEGORY NAV (curriculum pills) */
.catnav{display:flex;flex-wrap:wrap;gap:11px;justify-content:center;margin:0 0 6px}
/* Square polished-metal plates (brushed steel) */
.catnav a{font-family:var(--ui);font-size:13.5px;font-weight:700;letter-spacing:.03em;color:var(--navy);text-decoration:none;
  display:inline-flex;align-items:center;gap:9px;
  border:1px solid #aab0b8;border-radius:4px;padding:9px 16px;
  background:linear-gradient(180deg,#ffffff 0%,#eef0f3 20%,#dfe3e8 55%,#c9ced5 85%,#e6eaee 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85),inset 0 -1px 0 rgba(0,0,0,.1),0 2px 6px rgba(15,26,48,.15);
  transition:filter .15s,box-shadow .15s}
.catnav a:hover{filter:brightness(1.04);border-color:var(--navy)}
.catnav-ic{width:24px;height:24px;border-radius:50%;object-fit:cover;flex:none;border:1px solid rgba(194,161,77,.5)}

/* CATALOG — each subject in its own gold-topped pane with an engraving-medallion header */
.wrap.subj-pane{max-width:1000px;background:var(--paper);border:1px solid var(--line);border-top:4px solid var(--gold);
  border-radius:16px;padding:30px 36px;box-shadow:0 16px 40px rgba(15,26,48,.08)}
.subject-head{display:flex;align-items:center;gap:18px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.subj-medallion{width:80px;height:80px;border-radius:50%;object-fit:cover;flex:none;border:1px solid rgba(194,161,77,.55);
  background:var(--ivory);box-shadow:0 5px 14px rgba(15,26,48,.1)}
.subject-head .subj-title{margin:0;font-size:30px;line-height:1.05}
@media(max-width:560px){.subject-head .subj-title{font-size:24px}.subj-medallion{width:64px;height:64px}}

/* HERO TRUST BADGE (gold seal pill on the navy hero) */
.hero-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.seal{display:inline-flex;align-items:center;gap:9px;font-family:var(--ui);font-size:14px;
  font-weight:600;color:var(--gold-l);text-decoration:none;
  background:rgba(194,161,77,.10);border:1px solid rgba(194,161,77,.55);
  border-radius:999px;padding:10px 18px;transition:background .15s,color .15s}
.seal:hover{background:rgba(194,161,77,.20);color:#fff}
.seal .star{color:var(--gold);font-size:16px;line-height:1}

/* PRICING TIERS (sibling discount rows on the main plan) */
.tiers{list-style:none;padding:0;margin:14px 0 0;border-top:1px solid var(--line)}
.tiers li{display:flex;justify-content:space-between;align-items:baseline;
  padding:11px 0;border-bottom:1px solid var(--line);font-size:16px;color:#41454f}
.tiers b{font-family:var(--display);font-size:22px;color:var(--navy);font-weight:700}
.tiers .u{font-family:var(--ui);font-size:13px;color:var(--stone);font-weight:400;margin-left:1px}

/* ---- Responsive (the screenshot mockups were desktop-only) ---- */
@media (max-width:860px){
  .grid3,.grid2,.price-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step{border-right:0;border-bottom:1px solid var(--line)}
  .step:last-child{border-bottom:0}
  .media-split{grid-template-columns:1fr;gap:24px}
  .media-split.rev .ms-text{order:0}
}
@media (max-width:760px){
  .wrap{padding:0 22px}
  h1{font-size:42px} h2{font-size:30px} h3{font-size:22px}
  body{font-size:17px}
  .nav .wrap{height:auto;flex-wrap:wrap;gap:12px 18px;padding-top:14px;padding-bottom:14px}
  .nav a.link{font-size:14px}
  .lede{font-size:19px}
  .hero .wrap{padding:54px 22px 60px}
  .hero h1{font-size:40px}
  .hero .lede{font-size:19px}
  .sec{padding:52px 0}
  .sec.tight{padding:40px 0}
  .closer .cta-row,.hero .cta-row{flex-direction:column;align-items:stretch}
  .closer .btn,.hero .btn{text-align:center}
  .foot .cols{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:440px){
  .brand .bt{font-size:19px}
  .brand .bs{font-size:11px}
  .brand img{height:42px;width:42px}
  h1{font-size:34px}
  .foot .cols{grid-template-columns:1fr}
}

/* Inset photo banner at the top of a Professional Studies academy card. */
.acad-img{display:block;width:100%;height:180px;object-fit:cover;object-position:center 30%;border-radius:10px;margin:-6px 0 18px;border:1px solid var(--line)}

/* ---- Guilloché ornamentation (engraved line-work behind the page) ----
   Matches the spinning rosette on the signed-in app (body.lm), but each
   public page wears a different arrangement via a g-* body class. The
   pseudo-elements sit at z-index:-1 — above the ivory page colour, below
   every section/card — so they show only through the open ivory areas and
   are covered by the navy hero/footer, exactly like the app. */
html{overflow-x:hidden}
body::before,body::after{
  content:"";position:fixed;z-index:-1;pointer-events:none;
  background:url("/assets/guilloche.svg") center/contain no-repeat;
  /* Deepen the gold line-work to a darker bronze so it reads against the ivory page. */
  filter:brightness(.66) saturate(1.25);
  will-change:transform;
}
@keyframes m-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes m-spin-rev{from{transform:rotate(0)}to{transform:rotate(-360deg)}}
@media (prefers-reduced-motion:reduce){body::before,body::after{animation:none}}

/* Default — a slow central medallion with oversized counter-rotating roping. */
body::before{left:50%;top:44%;width:720px;height:720px;margin:-360px 0 0 -360px;opacity:.09;animation:m-spin 120s linear infinite}
body::after{left:50%;top:50%;width:170vmax;height:170vmax;margin:-85vmax 0 0 -85vmax;opacity:.045;animation:m-spin-rev 280s linear infinite}

/* How it works — a single rosette riding off the right edge. */
body.g-how::before{left:auto;right:-240px;top:90px;margin:0;width:640px;height:640px;opacity:.1;animation:m-spin 150s linear infinite}
body.g-how::after{opacity:.035}

/* Curriculum — twin rosettes anchored to opposite corners. */
body.g-curriculum::before{left:-220px;top:150px;margin:0;width:600px;height:600px;opacity:.085;animation:m-spin 160s linear infinite}
body.g-curriculum::after{left:auto;right:-200px;bottom:-200px;top:auto;margin:0;width:800px;height:800px;opacity:.07;animation:m-spin-rev 240s linear infinite}

/* Catalog — a tighter, quieter medallion to sit behind dense lists. */
body.g-catalog::before{width:540px;height:540px;margin:-270px 0 0 -270px;opacity:.075;animation:m-spin 140s linear infinite}
body.g-catalog::after{opacity:.03}

/* About — one grand, very faint rosette, no roping. */
body.g-about::before{width:900px;height:900px;margin:-450px 0 0 -450px;opacity:.075;animation:m-spin 200s linear infinite}
body.g-about::after{display:none}

/* Florida — medallion anchored low, rising from the page foot. */
body.g-florida::before{left:50%;top:auto;bottom:-300px;margin:0 0 0 -350px;width:700px;height:700px;opacity:.085;animation:m-spin 170s linear infinite}
body.g-florida::after{opacity:.04}

/* Pricing — a centre medallion plus a small top-left rosette. */
body.g-pricing::before{width:760px;height:760px;margin:-380px 0 0 -380px;opacity:.085;animation:m-spin 130s linear infinite}
body.g-pricing::after{left:-160px;top:-160px;bottom:auto;margin:0;width:520px;height:520px;opacity:.07;animation:m-spin 150s linear infinite}

/* Legal pages — symmetric rosettes tucked into the diagonal corners. */
body.g-legal::before{left:auto;right:-260px;top:-220px;margin:0;width:600px;height:600px;opacity:.075;animation:m-spin 180s linear infinite}
body.g-legal::after{left:-240px;bottom:-260px;top:auto;margin:0;width:600px;height:600px;opacity:.06;animation:m-spin-rev 200s linear infinite}
