/* ============================================================
   Central Trade Agency P Ltd — Website  |  DRAFT v2
   Botanical-premium design system — shared stylesheet
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  --forest:#15402e;
  --forest-deep:#0e2c1f;
  --forest-mid:#1f5a40;
  --sage:#5d7d66;
  --sage-pale:#e9efe7;
  --sage-tint:#f1f4ee;
  --gold:#b3833c;
  --gold-soft:#d8b873;
  --teal:#2d6f6a;
  --cream:#faf8f1;
  --paper:#ffffff;
  --ink:#1b231e;
  --ink-soft:#4d574f;
  --ink-faint:#7c857d;
  --line:#e3e0d4;
  --line-dark:#2c4a3b;
  --shadow:0 12px 40px -16px rgba(14,44,31,.28);
  --shadow-sm:0 4px 18px -10px rgba(14,44,31,.30);
  --radius:14px;
  --radius-sm:9px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--ink);background:var(--cream);
  line-height:1.65;font-size:17px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

h1,h2,h3,h4{
  font-family:'Fraunces','Georgia',serif;font-weight:500;
  line-height:1.16;color:var(--forest);letter-spacing:-.01em;
}
h1{font-size:clamp(2.2rem,4.6vw,3.5rem)}
h2{font-size:clamp(1.8rem,3.3vw,2.6rem)}
h3{font-size:1.3rem;line-height:1.3}
h4{font-size:1.05rem}
p{color:var(--ink-soft)}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:88px 0}
.section--tight{padding:60px 0}
.section--sage{background:var(--sage-tint)}
.section--forest{background:var(--forest);color:#dfe7df}
.section--forest h2,.section--forest h3,.section--forest h4{color:#fff}
.center{text-align:center}
.narrow{max-width:730px;margin-left:auto;margin-right:auto}

.eyebrow{
  display:inline-block;font-size:.78rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;
}
.section--forest .eyebrow,.page-hero .eyebrow{color:var(--gold-soft)}
.lead{font-size:1.15rem;color:var(--ink-soft)}
.section--forest .lead{color:#c4d2c5}
.muted{color:var(--ink-faint);font-size:.86rem}
.muted2{color:#9fb3a3}
.prose p{margin-bottom:16px}
.prose p:last-child{margin-bottom:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.95rem;font-weight:600;padding:14px 28px;border-radius:40px;
  cursor:pointer;border:1.5px solid transparent;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s;
}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--gold);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:#a0742f}
.btn--forest{background:var(--forest);color:#fff}
.btn--forest:hover{background:var(--forest-deep)}
.btn--ghost{border-color:var(--forest);color:var(--forest)}
.btn--ghost:hover{background:var(--forest);color:#fff}
.btn--light{background:#fff;color:var(--forest)}
.btn--light:hover{background:var(--sage-pale)}
.btn--outline-light{border-color:rgba(255,255,255,.5);color:#fff}
.btn--outline-light:hover{background:rgba(255,255,255,.12)}
.btn--sm{padding:10px 20px;font-size:.86rem}
.btn .arr{transition:transform .2s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(250,248,241,.96);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:18px}
.brand{display:flex;align-items:center;gap:11px;flex:none}
.brand__mark{width:40px;height:40px;flex:none}
.brand__text{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:'Fraunces',serif;font-size:1.12rem;color:var(--forest);font-weight:600}
.brand__tag{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600}

.nav__links{display:flex;align-items:center;gap:2px}
.nav__item{position:relative}
.nav__top{
  display:flex;align-items:center;gap:4px;
  font-size:.88rem;font-weight:500;color:var(--ink-soft);
  padding:10px 11px;border-radius:8px;transition:color .15s,background .15s;white-space:nowrap;
}
.nav__top:hover{color:var(--forest);background:var(--sage-tint)}
.nav__top.active{color:var(--forest);font-weight:600}
.nav__caret{width:11px;height:11px;opacity:.7}
.nav__drop{
  position:absolute;top:calc(100% + 6px);left:0;min-width:266px;
  background:var(--paper);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .16s var(--ease),transform .16s var(--ease),visibility .16s;
}
.nav__item--has:hover .nav__drop,.nav__item--has:focus-within .nav__drop{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav__drop a{
  display:block;font-size:.86rem;font-weight:500;color:var(--ink-soft);
  padding:9px 13px;border-radius:7px;transition:background .13s,color .13s;
}
.nav__drop a:hover{background:var(--sage-tint);color:var(--forest)}
.nav__drop a.on{background:var(--sage-pale);color:var(--forest);font-weight:600}
.nav__cta{display:flex;align-items:center;gap:12px;flex:none}
.nav__toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav__toggle span{display:block;width:24px;height:2px;background:var(--forest);margin:5px 0;border-radius:2px}

/* ---------- Draft ribbon ---------- */
.draftbar{
  background:var(--gold);color:#3d2c0c;text-align:center;
  font-size:.78rem;font-weight:500;padding:7px 16px;letter-spacing:.01em;
}
.draftbar strong{font-weight:700}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  background:
    radial-gradient(900px 500px at 88% -10%,rgba(179,131,60,.22),transparent 60%),
    linear-gradient(160deg,var(--forest-deep),var(--forest) 55%,var(--forest-mid));
  color:#e6ede6;overflow:hidden;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><path d='M60 8C44 28 44 52 60 72c16-20 16-44 0-64z' fill='none' stroke='%23ffffff' stroke-width='1' opacity='.05'/></svg>");
  background-size:160px;opacity:.6;pointer-events:none;
}
.hero__inner{position:relative;z-index:2;padding:100px 0 104px;max-width:800px}
.hero h1{color:#fff;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero p{color:#c7d4c8;font-size:1.17rem;max-width:620px;margin-bottom:30px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.hero__stats{
  position:relative;z-index:2;display:flex;gap:44px;flex-wrap:wrap;
  border-top:1px solid var(--line-dark);padding:26px 0 0;margin-top:6px;
}
.hero__stat .n{font-family:'Fraunces',serif;font-size:2rem;color:var(--gold-soft)}
.hero__stat .l{font-size:.84rem;color:#9fb3a3;letter-spacing:.03em}

/* page hero (interior) */
.page-hero{
  background:linear-gradient(160deg,var(--forest-deep),var(--forest-mid));
  color:#e6ede6;padding:62px 0 58px;position:relative;overflow:hidden;
}
.page-hero::after{
  content:"";position:absolute;right:-60px;top:-40px;width:320px;height:320px;
  background:radial-gradient(circle,rgba(179,131,60,.25),transparent 68%);
}
.page-hero h1{color:#fff;max-width:820px;position:relative;z-index:2}
.page-hero p{color:#c7d4c8;max-width:680px;margin-top:14px;position:relative;z-index:2;font-size:1.06rem}
.crumbs{font-size:.82rem;color:#9fb3a3;margin-bottom:16px;position:relative;z-index:2}
.crumbs a:hover{color:var(--gold-soft)}
.crumbs .sep{margin:0 7px;opacity:.5}

/* ---------- Trust band ---------- */
.trust{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust__inner{display:flex;align-items:center;gap:26px;flex-wrap:wrap;justify-content:center;padding:24px 0}
.trust__label{font-size:.76rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.trust__badge{
  display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--forest);
  padding:8px 15px;border:1px solid var(--line);border-radius:30px;background:var(--cream);
}
.trust__badge .dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}

/* ---------- Section heading block ---------- */
.shead{max-width:700px;margin-bottom:42px}
.shead.center{margin-left:auto;margin-right:auto}
.shead p{margin-top:4px}

/* ---------- Card grid ---------- */
.grid{display:grid;gap:24px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s;
}
.card--link{display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d2cdb8}
.card__icon{
  width:50px;height:50px;border-radius:12px;background:var(--sage-pale);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.card__icon svg{width:25px;height:25px}
.card h3{margin-bottom:8px}
.card p{font-size:.95rem}
.card__link{
  display:inline-flex;align-items:center;gap:6px;margin-top:15px;
  font-size:.87rem;font-weight:600;color:var(--gold);
}
.card__link:hover{color:#a0742f}
.card--link:hover .card__link{gap:9px}

/* feature card (numbered) */
.fcard{padding:26px 28px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper)}
.fcard__num{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--gold);margin-bottom:6px}
.fcard h4{margin-bottom:5px}

/* ---------- Designed placeholder thumbnail ---------- */
.thumb{
  position:relative;width:100%;aspect-ratio:4/3;border-radius:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:9px;overflow:hidden;text-align:center;
}
img.thumb{object-fit:cover}
.thumb__art{display:flex;color:rgba(255,255,255,.92)}
.thumb__art svg{width:42px;height:42px}
.thumb__name{
  font-family:'Fraunces',serif;font-size:.96rem;color:#fff;font-weight:500;
  padding:0 14px;line-height:1.2;text-shadow:0 1px 6px rgba(0,0,0,.25);
}
.thumb::after{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'><path d='M40 8C28 22 28 44 40 60c12-16 12-38 0-52z' fill='none' stroke='%23ffffff' stroke-width='1' opacity='.09'/></svg>");
  background-size:96px;pointer-events:none;
}
.thumb--t0{background:linear-gradient(150deg,#1f5a40,#0e2c1f)}
.thumb--t1{background:linear-gradient(150deg,#2d6f6a,#163f3c)}
.thumb--t2{background:linear-gradient(150deg,#5d7d66,#2c4a3b)}
.thumb--t3{background:linear-gradient(150deg,#a0742f,#5e421a)}
.thumb--t4{background:linear-gradient(150deg,#3a6b4e,#15402e)}
.thumb--t5{background:linear-gradient(150deg,#6b7d3c,#33401c)}
.thumb--sm{aspect-ratio:1/1}
.thumb--wide{aspect-ratio:16/9}

/* ---------- Product card (with thumbnail) ---------- */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pgrid--4{grid-template-columns:repeat(4,1fr)}
.pcard{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s;
  display:flex;flex-direction:column;
}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d2cdb8}
.pcard__body{padding:20px;display:flex;flex-direction:column;flex:1}
.pcard__body h3{font-size:1.06rem;margin-bottom:2px}
.pcard__bot{font-style:italic;font-size:.83rem;color:var(--ink-faint);margin-bottom:11px}
.pcard__spec{
  font-size:.78rem;color:var(--forest);background:var(--sage-pale);
  display:inline-block;padding:5px 11px;border-radius:20px;font-weight:600;margin-bottom:12px;align-self:flex-start;
}
.pcard p{font-size:.88rem}
.pcard__link{
  font-size:.84rem;font-weight:600;color:var(--gold);display:inline-flex;gap:5px;
  align-items:center;margin-top:14px;
}
.pcard:hover .pcard__link{gap:8px}
.pcard__tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:auto;padding-top:12px}
.ptag{
  font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  padding:3px 8px;border-radius:5px;background:var(--sage-tint);color:var(--sage);
}

/* ---------- Filter bar ---------- */
.filterbar{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;margin-bottom:28px;
}
.searchwrap{position:relative;margin-bottom:14px}
.searchwrap svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--ink-faint)}
.search{
  width:100%;padding:13px 16px 13px 44px;border:1px solid var(--line);border-radius:9px;
  font-family:inherit;font-size:.96rem;color:var(--ink);background:var(--cream);
}
.search:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px rgba(21,64,46,.1)}
.chips{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.chips__label{font-size:.78rem;font-weight:600;color:var(--ink-faint);letter-spacing:.04em;text-transform:uppercase;margin-right:4px}
.chip{
  padding:7px 15px;border:1px solid var(--line);border-radius:30px;background:var(--cream);
  font-size:.84rem;font-weight:600;color:var(--ink-soft);cursor:pointer;
  transition:background .14s,color .14s,border-color .14s;
}
.chip:hover{border-color:var(--sage)}
.chip.active{background:var(--forest);color:#fff;border-color:var(--forest)}
.filtermeta{font-size:.85rem;color:var(--ink-faint);margin-bottom:18px}
.filtermeta strong{color:var(--forest)}
.noresults{display:none;text-align:center;padding:50px 20px;color:var(--ink-faint)}

/* ---------- Directory grid (compact cards) ---------- */
.dgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.dcard{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;transition:transform .18s var(--ease),box-shadow .18s var(--ease),border-color .18s;
}
.dcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:#d2cdb8}
.dcard__body{padding:14px 15px}
.dcard__name{font-family:'Fraunces',serif;font-size:1rem;color:var(--forest);line-height:1.25}
.dcard__bot{font-style:italic;font-size:.78rem;color:var(--ink-faint);margin-top:2px}
.dcard__spec{font-size:.8rem;color:var(--ink-soft);margin-top:8px}
.dcard__spec b{color:var(--forest);font-weight:600}
.dcard__meta{font-size:.72rem;color:var(--ink-faint);margin-top:6px}

/* ---------- Directory table ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:.92rem;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.tbl th{
  background:var(--forest);color:#fff;text-align:left;padding:13px 16px;
  font-size:.8rem;letter-spacing:.04em;font-weight:600;
}
.tbl td{padding:12px 16px;border-top:1px solid var(--line);color:var(--ink-soft);vertical-align:top}
.tbl tr:nth-child(even) td{background:var(--sage-tint)}
.tbl .bn{font-style:italic;color:var(--ink-faint);font-size:.86rem}

/* ---------- Split content ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split--wide-text{grid-template-columns:1.05fr .95fr}
.split__media{
  border-radius:var(--radius);overflow:hidden;min-height:330px;
  background:linear-gradient(150deg,var(--forest-mid),var(--forest-deep));
  display:flex;align-items:center;justify-content:center;position:relative;
}
.split__media .thumb{height:100%;aspect-ratio:auto;min-height:330px}

/* ---------- Placeholder image block ---------- */
.ph{
  border:1.5px dashed rgba(255,255,255,.4);border-radius:10px;
  padding:26px 24px;text-align:center;color:#cdd9ce;margin:18px;max-width:340px;
}
.ph svg{width:32px;height:32px;margin:0 auto 10px;opacity:.7}
.ph__t{font-size:.9rem;font-weight:600;color:#e6ede6}
.ph__s{font-size:.78rem;color:#9fb3a3;margin-top:4px}
.ph--light{border-color:var(--line);background:var(--sage-tint);color:var(--ink-faint)}
.ph--light .ph__t{color:var(--forest)}
.ph--light .ph__s{color:var(--ink-faint)}
.ph--light svg{opacity:.5}

/* inline TBC marker */
.tbc{
  background:#fcf3dd;color:#8a6a1f;border:1px solid #ecd99a;
  font-size:.72rem;font-weight:700;letter-spacing:.04em;
  padding:2px 7px;border-radius:5px;white-space:nowrap;
}

/* ---------- Stat band ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;text-align:center}
.statband .n{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--gold-soft)}
.statband .l{font-size:.88rem;color:#bcccbd;margin-top:4px}

/* ---------- Ticks list ---------- */
.ticks li{
  position:relative;padding:9px 0 9px 32px;font-size:.96rem;color:var(--ink-soft);
  border-bottom:1px solid var(--line);
}
.ticks li:last-child{border-bottom:none}
.ticks li::before{
  content:"";position:absolute;left:0;top:13px;width:18px;height:18px;border-radius:50%;
  background:var(--sage-pale);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path d='M5 10l3 3 7-7' fill='none' stroke='%2315402e' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size:14px;background-repeat:no-repeat;background-position:center;
}
.section--forest .ticks li{color:#c7d4c8;border-color:var(--line-dark)}
.section--forest .ticks li::before{background-color:rgba(255,255,255,.1)}
.ticks--plain li{border-bottom:none;padding:6px 0 6px 32px}

/* ---------- Process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.steps--4{grid-template-columns:repeat(4,1fr)}
.step{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:22px 18px;position:relative;
}
.section--forest .step{background:rgba(255,255,255,.05);border-color:var(--line-dark)}
.step__n{
  width:32px;height:32px;border-radius:50%;background:var(--forest);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;margin-bottom:11px;
}
.section--forest .step__n{background:var(--gold)}
.step h4{margin-bottom:5px}
.step p{font-size:.85rem}

/* ---------- Tables / spec sheet ---------- */
.spec{width:100%;border-collapse:collapse;font-size:.92rem;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.spec th{background:var(--forest);color:#fff;text-align:left;padding:13px 18px;font-size:.82rem;font-weight:600}
.spec td{padding:12px 18px;border-top:1px solid var(--line);color:var(--ink-soft)}
.spec td:first-child{font-weight:600;color:var(--forest);width:42%}
.spec tr:nth-child(even) td{background:var(--sage-tint)}

/* ---------- Anchor / section sub-nav ---------- */
.anchornav{
  position:sticky;top:76px;z-index:40;background:rgba(250,248,241,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.anchornav__inner{display:flex;gap:6px;overflow-x:auto;padding:12px 0}
.anchornav a{
  font-size:.85rem;font-weight:600;color:var(--ink-soft);padding:8px 14px;
  border-radius:30px;white-space:nowrap;transition:background .14s,color .14s;
}
.anchornav a:hover{background:var(--sage-tint);color:var(--forest)}

/* ---------- PDP grade pills ---------- */
.grades{display:flex;gap:10px;flex-wrap:wrap}
.gradepill{
  border:1px solid var(--line);border-radius:10px;background:var(--paper);
  padding:14px 18px;min-width:130px;
}
.gradepill .g{font-family:'Fraunces',serif;font-size:1.3rem;color:var(--gold)}
.gradepill .gl{font-size:.8rem;color:var(--ink-faint);margin-top:2px}

/* ---------- Applications cards ---------- */
.applic{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.acard{border:1px solid var(--line);border-radius:var(--radius-sm);padding:20px;background:var(--paper)}
.acard__ic{width:40px;height:40px;border-radius:9px;background:var(--sage-pale);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.acard__ic svg{width:21px;height:21px}
.acard h4{font-size:.98rem;margin-bottom:5px}
.acard p{font-size:.85rem}

/* ---------- FAQ ---------- */
.faq{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--paper)}
.faq__q{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:20px 24px;font-family:'Fraunces',serif;font-size:1.06rem;color:var(--forest);
  display:flex;justify-content:space-between;gap:18px;align-items:center;
  border-top:1px solid var(--line);
}
.faq__q:first-child,.faq>.faq__item:first-child .faq__q{border-top:none}
.faq__item{border-top:1px solid var(--line)}
.faq__item:first-child{border-top:none}
.faq__q .pm{flex:none;width:22px;height:22px;position:relative;transition:transform .2s}
.faq__q .pm::before,.faq__q .pm::after{
  content:"";position:absolute;background:var(--gold);border-radius:2px;
}
.faq__q .pm::before{width:14px;height:2px;top:10px;left:4px}
.faq__q .pm::after{width:2px;height:14px;top:4px;left:10px;transition:transform .2s}
.faq__item.open .pm::after{transform:rotate(90deg)}
.faq__a{display:none;padding:0 24px 22px}
.faq__item.open .faq__a{display:block}
.faq__a p{font-size:.95rem}

/* ---------- Forms ---------- */
.formwrap{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm)}
.formrow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.85rem;font-weight:600;color:var(--forest);margin-bottom:6px}
.field .req{color:var(--gold)}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--cream);
  transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--forest);box-shadow:0 0 0 3px rgba(21,64,46,.1);
}
.field textarea{resize:vertical;min-height:110px}
.formnote{font-size:.8rem;color:var(--ink-faint);margin-top:14px}
.etabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.etab{
  padding:10px 18px;border:1px solid var(--line);border-radius:30px;background:var(--paper);
  font-size:.85rem;font-weight:600;color:var(--ink-soft);cursor:pointer;
}
.etab.active{background:var(--forest);color:#fff;border-color:var(--forest)}

/* ---------- Contact info blocks ---------- */
.cinfo{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.cinfo:last-child{border-bottom:none}
.cinfo__ic{width:44px;height:44px;flex:none;border-radius:11px;background:var(--sage-pale);display:flex;align-items:center;justify-content:center}
.cinfo__ic svg{width:21px;height:21px}
.cinfo h4{margin-bottom:3px}
.cinfo p{font-size:.91rem}

/* ---------- CTA band ---------- */
.cta{
  background:linear-gradient(150deg,var(--forest),var(--forest-deep));
  border-radius:20px;padding:54px;text-align:center;color:#dfe7df;position:relative;overflow:hidden;
}
.cta::before{
  content:"";position:absolute;left:-40px;bottom:-60px;width:240px;height:240px;
  background:radial-gradient(circle,rgba(179,131,60,.3),transparent 70%);
}
.cta h2{color:#fff;position:relative}
.cta p{color:#c7d4c8;max-width:560px;margin:13px auto 24px;position:relative}
.cta__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* ---------- Callout ---------- */
.callout{
  background:var(--sage-tint);border-left:3px solid var(--gold);
  border-radius:0 10px 10px 0;padding:18px 22px;margin:22px 0;
}
.callout p{font-size:.92rem;margin:0}
.callout strong{color:var(--forest)}
.divider{height:1px;background:var(--line);margin:0}

/* ---------- Footer ---------- */
.footer{background:var(--forest-deep);color:#a9bdac;padding:62px 0 24px;font-size:.9rem}
.footer__top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:36px;padding-bottom:38px;border-bottom:1px solid var(--line-dark)}
.footer__brand .brand__name{color:#fff}
.footer__brand .brand__tag{color:var(--gold-soft)}
.footer p{color:#9fb3a3;font-size:.9rem;margin-top:14px;max-width:320px}
.footer h4{color:#fff;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:15px;font-family:'Inter',sans-serif;font-weight:600}
.footer__links li{margin-bottom:8px}
.footer__links a{color:#a9bdac;transition:color .15s}
.footer__links a:hover{color:var(--gold-soft)}
.footer__bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:22px;color:#7f9384;font-size:.82rem}

/* ---------- Responsive ---------- */
@media(max-width:1180px){
  .nav__top{padding:10px 8px;font-size:.84rem}
}
@media(max-width:1040px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .grid--3{grid-template-columns:repeat(2,1fr)}
  .pgrid,.pgrid--4{grid-template-columns:repeat(2,1fr)}
  .dgrid{grid-template-columns:repeat(3,1fr)}
  .applic{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:34px}
  .split--wide-text{grid-template-columns:1fr}
  .steps,.steps--4{grid-template-columns:repeat(2,1fr)}
  .statband{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr 1fr;gap:30px}
  .nav__cta .btn{display:none}
  .nav__toggle{display:block}
  .nav__links{
    display:none;position:absolute;top:76px;left:0;right:0;max-height:calc(100vh - 76px);overflow-y:auto;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--cream);border-bottom:1px solid var(--line);padding:8px 20px 20px;
  }
  .nav__links.open{display:flex}
  .nav__item{width:100%;border-bottom:1px solid var(--line)}
  .nav__top{padding:14px 6px;font-size:.95rem;justify-content:space-between}
  .nav__drop{
    position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;
    border:none;padding:0 0 8px 14px;min-width:0;
    display:none;
  }
  .nav__item--has.open .nav__drop{display:block}
  .nav__caret{transition:transform .2s}
  .nav__item--has.open .nav__caret{transform:rotate(180deg)}
}
@media(max-width:680px){
  body{font-size:16px}
  .section{padding:58px 0}
  .grid--2,.grid--3,.grid--4,.pgrid,.pgrid--4{grid-template-columns:1fr}
  .dgrid{grid-template-columns:repeat(2,1fr)}
  .applic{grid-template-columns:1fr}
  .formrow{grid-template-columns:1fr}
  .steps,.steps--4,.statband{grid-template-columns:1fr}
  .cta{padding:38px 24px}
  .hero__inner{padding:68px 0 74px}
  .hero__stats{gap:26px}
  .footer__top{grid-template-columns:1fr}
  .grades{gap:8px}
  .gradepill{min-width:calc(50% - 4px)}
  .spec td:first-child{width:48%}
}
@media(max-width:430px){
  .dgrid{grid-template-columns:1fr}
}
