/* Erickson Coaching International — Georgia · landing page styles
   Brand palette (matches erickson.edu): greenish-blue #073f52 + gold #ebbe34.
   Display font = ArchyEDT (from the source PDF); body = Open Sans + Noto Sans Georgian.
   Read top→bottom: design tokens, base & headings, sections in DOM order, then responsive. */

@font-face{font-family:'ArchyEDT';font-weight:400 700;font-style:normal;font-display:swap;src:url('assets/fonts/ArchyEDT-Bold.woff2') format('woff2')}
/* DM Merab Kostava — a Unicode Georgian handwritten/cursive face (from fonts.ge), used only for the slogan */
@font-face{font-family:'DM Merab Kostava';font-weight:400;font-style:normal;font-display:swap;src:url('assets/fonts/dm-merab-kostava.woff2') format('woff2')}
/* Elguja (ელგუჯა) — handwritten Georgian face by Shalva Mesxi (fonts.ge); the source TTF was a legacy
   Latin-mapped font, remapped to proper Georgian Unicode codepoints so the slogan markup stays semantic. */
@font-face{font-family:'Elguja';font-weight:400;font-style:normal;font-display:swap;src:url('assets/fonts/elguja.woff2') format('woff2')}
:root{
  /* Erickson brand palette (sampled from erickson.edu):
     greenish-blue #073f52 (kept in the --teal-* vars) + gold #ebbe34 (in the --rust-* vars).
     Gold fills carry dark navy text; gold text on light backgrounds uses the deep --rust-700. */
  --teal-950:#00172a;
  --teal-900:#073f52;
  --teal-700:#2f677a;
  --teal-500:#3b8fab;
  --sky:#60b8d0;
  --teal-soft:rgba(7,63,82,.12);
  --rust-300:#f3d375;
  --rust-500:#ebbe34;
  --rust-600:#cda021;
  --rust-700:#8a6a10;
  --rust-soft:rgba(235,190,52,.16);
  --mist:#cfdde4;
  --mist-dim:#8aa6b1;
  --muted:#4a6675;
  --bg:#f5f9fb;
  --bg-deep:#e9f2f6;
  --card:#ffffff;
  --line:#dde9ee;
  --radius:18px;
  --radius-sm:12px;
  --radius-xs:8px;
  --shadow:0 10px 30px rgba(0,23,42,.08);
  --shadow-lg:0 24px 60px rgba(0,23,42,.16);
  /* type — display = ArchyEDT (the PDF's signature Georgian display face) */
  --font-display:'ArchyEDT','Noto Sans Georgian',sans-serif;
  --font-body:'Open Sans','Noto Sans Georgian',-apple-system,'Segoe UI',sans-serif;
  --h1:clamp(2.4rem,5.4vw,3.65rem);
  --h2:clamp(1.85rem,3.6vw,2.7rem);
  --h3:clamp(1.12rem,1.5vw,1.32rem);
  /* 8px spacing scale */
  --s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;--s8:64px;--s9:96px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
::selection{background:rgba(7,63,82,.25)}
body{
  font-family:'Open Sans','Noto Sans Georgian',-apple-system,'Segoe UI',sans-serif;
  color:var(--teal-900);
  background:var(--bg);
  font-size:1.05rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
/* ---------- helpers ---------- */
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
section{padding:96px 0}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--rust-700);margin-bottom:14px;
}
.kicker::before{content:"";width:26px;height:2px;background:var(--rust-500);display:inline-block}
/* Display headings use ArchyEDT — the PDF's signature Georgian display face. It carries only
   Mkhedruli forms (no Mtavruli), so headings are NOT uppercased; this matches the source PDF. */
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;text-transform:none}
h1{letter-spacing:-.015em;line-height:1.06}
h2{font-size:var(--h2);font-weight:700;line-height:1.16;letter-spacing:-.012em;color:var(--teal-900);margin-bottom:20px}
h3{font-size:var(--h3);letter-spacing:-.005em}
.lead{font-size:1.18rem;color:var(--muted);max-width:840px;line-height:1.7}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
/* ---------- header ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(7,63,82,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.07);
  transition:background .3s;
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{height:44px;width:auto;display:block}
.brand .brand-full{height:46px}
.brand .brand-wordmark{display:none;height:34px}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{display:inline-block;padding:4px 0;color:var(--mist);text-decoration:none;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{display:flex;align-items:center;gap:14px}
.btn{
  display:inline-block;background:var(--rust-500);color:var(--teal-950);text-decoration:none;
  font-weight:700;font-size:.9rem;padding:12px 26px;border-radius:999px;border:none;cursor:pointer;
  font-family:inherit;transition:transform .2s,box-shadow .2s,background .2s;
  box-shadow:0 8px 20px rgba(235,190,52,.4);
}
.btn:hover{transform:translateY(-2px);background:var(--rust-600);box-shadow:0 12px 26px rgba(235,190,52,.5)}
.btn.ghost{background:transparent;border:1.5px solid rgba(255,255,255,.4);box-shadow:none;color:#fff}
.btn.ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn.small{padding:9px 20px;font-size:.82rem}
/* no gold/yellow glow on the dark hero+header — use neutral depth instead */
#header .btn{box-shadow:0 6px 16px rgba(0,0,0,.20)}
#header .btn:hover{box-shadow:0 10px 22px rgba(0,0,0,.26)}
.hero-actions .btn{box-shadow:0 10px 24px rgba(0,0,0,.22)}
.hero-actions .btn:hover{box-shadow:0 14px 30px rgba(0,0,0,.28)}
.burger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.burger span{display:block;width:22px;height:2px;background:#fff;margin:5px 0;transition:.3s}
/* ---------- hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--teal-950) 0%,var(--teal-900) 45%,var(--teal-700) 100%);
  color:#fff;padding:170px 0 110px;
}
.hero::after{
  content:"";position:absolute;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,143,171,.4),transparent 65%);
  bottom:-200px;left:-140px;pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative;z-index:2}
.hero h1{font-size:clamp(3.1rem,6.6vw,5.6rem);font-weight:700;line-height:1.02;letter-spacing:-.02em;margin:0 0 22px}
.hero h1 .line{display:block}
.hero h1 .accent{color:var(--sky)}
.hero .tag{
  display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:7px 16px;
  font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:24px;
}
.hero .tag .dot{width:7px;height:7px;border-radius:50%;background:var(--rust-500)}
.hero p.sub{font-size:1.12rem;color:var(--mist);max-width:580px;margin-bottom:34px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:54px}
.hero-actions .btn{padding:16px 40px;font-size:1.05rem}
.hero-img{position:relative}
.hero-img .frame{
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.15);
}
.hero-img img{width:100%;height:560px;object-fit:cover;object-position:center 20%;display:block}
.float-chip{
  position:absolute;background:#fff;color:var(--teal-900);border-radius:var(--radius-sm);
  padding:12px 18px;font-size:.8rem;font-weight:700;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:10px;animation:float 5s ease-in-out infinite;
}
.float-chip img{height:34px;width:auto}
.chip-icf{bottom:26px;left:-30px}
.chip-cert{top:30px;right:-18px;animation-delay:2.5s}
.chip-cert .big{color:var(--rust-700);font-size:1.05rem}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  position:relative;z-index:2;margin-top:10px;
}
.stat{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:22px 20px;text-align:center;
}
.stat .num{font-family:var(--font-display);font-size:clamp(2rem,3vw,2.5rem);font-weight:700;color:#fff;letter-spacing:-.01em;font-variant-numeric:tabular-nums;line-height:1}
.stat .num span:last-child{color:var(--rust-300)}
.stat .lbl{font-size:.78rem;color:var(--mist);margin-top:6px}
/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.about-grid p{margin-bottom:16px;color:var(--muted);font-size:1.09rem}
.vision{
  background:linear-gradient(135deg,var(--teal-900),var(--teal-700));
  color:#fff;border-radius:var(--radius);padding:34px 32px;position:relative;overflow:hidden;
}
.vision::before{content:"“";position:absolute;font-size:9rem;font-weight:800;opacity:.12;top:-30px;left:14px}
.vision p{font-size:1.25rem;font-weight:700;line-height:1.5;position:relative;margin:0 0 10px}
.vision p{color:#fff !important}
.vision .src{font-size:.8rem;color:var(--mist);position:relative}
/* full-width slogan band — minimalist white card with an elegant italic-serif slogan */
.vision-band{padding:18px 0 54px}
.vision-band .vision{
  text-align:center;padding:54px 40px;
  background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);
}
.vision-band .vision::before{content:none}   /* drop the quote watermark — keep it minimal */
.vision-band .kicker{margin-bottom:18px}
.vision-band .vision p{
  color:var(--teal-900) !important;
  font-family:'Elguja','Noto Sans Georgian',cursive;font-style:normal;font-weight:400;
  /* one line that fills the card: ~14× the font-size in width; box inner width ≈ 1012px on desktop */
  font-size:clamp(1rem,5vw,4.3rem);line-height:1.25;letter-spacing:0;
  white-space:nowrap;max-width:none;margin:0 auto;
}
.award{
  display:flex;gap:22px;align-items:center;margin-top:30px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 28px;box-shadow:var(--shadow);
}
.award img{height:92px;width:auto}
.award .t{font-weight:700;color:var(--teal-900);font-size:1.15rem;line-height:1.25}
.award .d{font-size:.97rem;color:var(--muted);margin-top:4px}
/* tighten the vertical gap between About and the slogan band */
#about{padding-bottom:30px}
/* ---------- author ---------- */
.author{background:linear-gradient(160deg,var(--teal-950),var(--teal-900));color:#fff}
.author-grid{display:grid;grid-template-columns:330px 1fr;gap:56px;align-items:center}
.author-photo{position:relative}
.author-photo img{
  width:100%;border-radius:var(--radius);display:block;box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.18);
}
.author h2{color:#fff}
.author .role{color:var(--rust-300);font-weight:700;font-size:.95rem;margin-bottom:18px}
.author .kicker{color:var(--rust-300)}
.author p{color:var(--mist);margin-bottom:14px}
/* ---------- benefits ---------- */
/* the 3 program cards = the core promise; sized up to be the focal point */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:56px}
.bcard{
  background:linear-gradient(165deg,var(--teal-900),var(--teal-950));
  border:1px solid rgba(255,255,255,.10);border-radius:22px;
  padding:48px 34px 40px;box-shadow:0 20px 50px rgba(0,23,42,.20);
  position:relative;overflow:hidden;
}
.bcard::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,var(--rust-500),var(--sky))}
/* big faint index number, top-right watermark (white on the blue card) */
.bcard::after{position:absolute;top:10px;right:24px;font-family:var(--font-display);font-weight:700;font-size:5rem;line-height:1;color:#fff;opacity:.09;pointer-events:none}
.cards3 .bcard:nth-child(1)::after{content:"01"}
.cards3 .bcard:nth-child(2)::after{content:"02"}
.cards3 .bcard:nth-child(3)::after{content:"03"}
.bcard .ico{
  width:76px;height:76px;border-radius:20px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--rust-500),var(--rust-600));
  box-shadow:0 12px 26px rgba(0,0,0,.30);margin-bottom:26px;position:relative;
}
.bcard h3{font-size:1.46rem;font-weight:700;color:#fff;margin-bottom:14px;position:relative}
.bcard p{font-size:1.13rem;line-height:1.62;color:var(--mist);position:relative}
/* clean ICF accreditation line (re-added; not a bubble) under the program intro */
.accred{display:inline-flex;align-items:center;gap:16px;margin-top:34px;
  font-size:1.18rem;font-weight:700;color:var(--teal-900);line-height:1.3}
.accred img{height:58px;width:auto;flex-shrink:0}
.accred span{text-align:left}
/* ---------- pricing ---------- */
#pricing{background:var(--bg-deep)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.pcard{
  background:var(--card);border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);display:flex;flex-direction:column;
  transition:transform .25s,box-shadow .25s;
}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.pcard .head{
  background:linear-gradient(135deg,var(--teal-900),var(--teal-700));
  color:#fff;padding:26px 26px 22px;position:relative;min-height:116px;
}
.pcard.featured .head{background:linear-gradient(135deg,var(--rust-600),var(--rust-700))}
.pcard .lvl{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.9}
.pcard .head h3{font-size:1.25rem;font-weight:800;margin:6px 0 2px}
.pcard .head .dur{font-size:.8rem;opacity:.9}
.pcard .cert-badge{
  position:absolute;top:22px;right:22px;background:rgba(0,0,0,.16);
  border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-xs);padding:5px 11px;
  font-size:.74rem;font-weight:800;letter-spacing:.06em;
}
/* Erickson EAC (bronze) / ECPC (silver) seals stacked + centered directly under the EAC/ECPC label
   (3rd price card, top-right). The stack centers the seals beneath the chip rather than far-right. */
.pcard .cert-stack{position:absolute;top:16px;right:20px;display:flex;flex-direction:column;align-items:center;gap:7px;z-index:2}
.pcard .cert-stack .cert-badge{position:static}
.pcard .cert-logos{display:flex;justify-content:center;gap:5px}
/* Seals are wider than tall (ribbon), so size by height with width:auto to keep their aspect ratio. */
.pcard .cert-logos img{height:26px;width:auto;display:block;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}
.pcard .cert-logos img:first-child{transform:translateX(-4px)}   /* nudge the bronze (EAC) seal slightly left */
.pricing-grid .pcard:nth-child(3) .head .lvl,
.pricing-grid .pcard:nth-child(3) .head h3,
.pricing-grid .pcard:nth-child(3) .head .dur{padding-right:90px}
.pcard .body{padding:26px;display:flex;flex-direction:column;flex:1}
.price{display:flex;align-items:baseline;gap:8px}
.price .amount{font-family:var(--font-display);font-size:2.3rem;font-weight:700;color:var(--teal-900);letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.price .per{font-size:.85rem;color:var(--muted)}
.total{font-size:.85rem;color:var(--muted);margin:2px 0 4px}
.total b{color:var(--teal-900)}
.early{
  display:inline-block;font-size:.72rem;font-weight:700;color:var(--rust-600);
  background:var(--rust-soft);border-radius:999px;padding:4px 12px;margin:10px 0 18px;
}
.months{font-size:.78rem;color:var(--muted);margin-bottom:14px}
.feature-list{list-style:none;margin:0 0 22px;flex:1}
.feature-list li{
  font-size:.86rem;color:var(--muted);padding:9px 0 9px 28px;position:relative;
  border-bottom:1px dashed var(--line);
}
.feature-list li:last-child{border-bottom:none}
.feature-list li::before{
  content:"✓";position:absolute;left:0;top:9px;width:18px;height:18px;border-radius:50%;
  background:var(--rust-soft);color:var(--rust-700);font-size:.7rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.feature-list li b{color:var(--teal-900)}
.pcard .btn{width:100%;text-align:center}
.pay-note{text-align:center;margin-top:30px;font-size:.85rem;color:var(--muted)}
.pay-note b{color:var(--rust-600)}
/* ---------- schedule (accordion) ---------- */
.acc{margin-top:48px;display:flex;flex-direction:column;gap:16px}
.acc-item{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);
}
.acc-head{
  width:100%;display:flex;align-items:center;gap:18px;padding:24px 28px;
  background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;
}
.acc-head .n{
  flex-shrink:0;width:46px;height:46px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--rust-500),var(--rust-600));color:var(--teal-950);font-weight:800;font-size:1.1rem;
}
.acc-head .tt{flex:1}
.acc-head .ttl{display:block;font-family:var(--font-display);font-size:1.18rem;font-weight:700;color:var(--teal-900);letter-spacing:-.005em}
.acc-head .tt .sub{display:block;font-family:var(--font-body);font-size:.82rem;font-weight:400;color:var(--muted);margin-top:3px;letter-spacing:normal}
.acc-head .arrow{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--teal-700);
  transition:transform .3s;font-size:.8rem;
}
.acc-item.open .arrow{transform:rotate(180deg);background:var(--teal-900);color:#fff;border-color:var(--teal-900)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .45s ease}
.acc-inner{padding:0 28px 28px 92px;display:grid;grid-template-columns:1fr 1fr;gap:28px}
.acc-inner h4{font-size:.78rem;font-weight:700;letter-spacing:.1em;color:var(--rust-700);margin-bottom:10px}
/* ICF Level badge beside each LEVEL 1 / LEVEL 2 COACH heading in the mentoring (3rd) schedule box */
.acc-inner .lvl-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.acc-inner .lvl-head h4{margin-bottom:0}
.acc-inner .lvl-badge{width:58px;height:58px;flex-shrink:0;display:block}
.acc-inner ul{list-style:none}
.acc-inner li{font-size:.87rem;color:var(--muted);padding:6px 0 6px 22px;position:relative}
.acc-inner li::before{content:"";position:absolute;left:2px;top:14px;width:7px;height:7px;border-radius:50%;background:var(--teal-500)}
.acc-inner li .pill{
  display:inline-block;font-size:.66rem;font-weight:700;background:var(--teal-soft);
  color:var(--teal-700);border-radius:999px;padding:1px 9px;margin-left:6px;vertical-align:1px;
}
/* ---------- trainers ---------- */
#trainers{background:linear-gradient(160deg,var(--teal-950),var(--teal-900));color:#fff}
#trainers h2{color:#fff}
#trainers .kicker{color:var(--rust-300)}
#trainers .lead{color:var(--mist)}
.trainer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px;align-items:start}
.tcard{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);overflow:hidden;transition:transform .25s,background .25s;
  display:flex;flex-direction:column;
}
.tcard:hover{transform:translateY(-6px);background:rgba(255,255,255,.09)}
.tcard .ph{height:280px;overflow:hidden;position:relative}
.tcard .ph img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .4s}
.tcard:hover .ph img{transform:scale(1.05)}
.tcard .cred{
  position:absolute;top:14px;right:14px;background:var(--rust-500);color:var(--teal-950);
  font-size:.7rem;font-weight:800;letter-spacing:.06em;border-radius:var(--radius-xs);padding:4px 10px;
}
.tcard .info{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
.tcard h3{font-size:1rem;font-weight:700;margin-bottom:4px}
.tcard .role{font-size:.76rem;color:var(--rust-300);font-weight:600;margin-bottom:10px}
.tcard p{font-size:.8rem;color:var(--mist);flex:1;display:none}
.tcard .more{
  background:none;border:none;color:#fff;font-family:inherit;font-size:.76rem;font-weight:700;
  cursor:pointer;padding:0;margin-top:12px;text-align:left;opacity:.8;transition:.2s;
}
.tcard .more:hover{opacity:1;color:var(--rust-300)}
/* collapsed = only the yellow .role line shows; the white bio <p> is hidden until "სრულად" is pressed */
.tcard.expanded p{display:block}
/* ---------- register ---------- */
.reg-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.reg-info h2{margin-bottom:18px}
.reg-points{list-style:none;margin-top:28px}
.reg-points li{
  display:flex;gap:14px;align-items:flex-start;padding:13px 0;font-size:.92rem;color:var(--muted);
}
.reg-points .ic{
  flex-shrink:0;width:38px;height:38px;border-radius:var(--radius-sm);background:var(--rust-soft);
  display:flex;align-items:center;justify-content:center;font-size:1rem;
}
.reg-points b{color:var(--teal-900)}
form{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:36px;box-shadow:var(--shadow-lg);
}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.f-group{margin-bottom:18px}
label{display:block;font-size:.78rem;font-weight:700;color:var(--teal-900);margin-bottom:7px}
input,select,textarea{
  width:100%;border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:12px 15px;
  font-family:inherit;font-size:.9rem;color:var(--teal-900);background:var(--bg);
  transition:border .2s,box-shadow .2s;outline:none;
}
input:focus,select:focus,textarea:focus{border-color:var(--rust-500);box-shadow:0 0 0 3px var(--rust-soft)}
::placeholder{color:var(--muted);opacity:1}
textarea{resize:vertical;min-height:96px}
.form-ok{
  display:none;text-align:center;padding:40px 10px;
}
.form-ok .big-ic{
  width:72px;height:72px;border-radius:50%;background:var(--teal-soft);color:var(--teal-500);
  font-size:2rem;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
}
.form-ok h3{color:var(--teal-900);font-size:1.2rem;margin-bottom:8px}
.form-ok p{color:var(--muted);font-size:.9rem}
/* ---------- contact / footer ---------- */
footer{background:var(--teal-950);color:#fff;padding:80px 0 0}
.foot-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:56px;padding-bottom:60px}
.foot-grid img.flogo{height:60px;margin-bottom:20px}
.foot-grid p{font-size:.85rem;color:var(--mist-dim)}
.foot-grid h4{font-size:.8rem;font-weight:700;letter-spacing:.12em;color:var(--rust-300);margin-bottom:18px}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:12px;font-size:.88rem;color:var(--mist)}
.foot-grid a{color:var(--mist);text-decoration:none;transition:color .2s}
.foot-grid a:hover{color:var(--rust-300)}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding:22px 0;text-align:center;
  font-size:.78rem;color:var(--mist-dim);
}
/* ---------- focus & reduced motion ---------- */
a:focus-visible,button:focus-visible{outline:2px solid var(--teal-500);outline-offset:2px}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
}
/* ---------- responsive ---------- */
@media(max-width:1000px){
  /* hero stays TWO-COLUMN down to 760px so laptop/tablet widths fill the row
     (it only stacks + centers on phones, in the ≤760 block) */
  .stats{grid-template-columns:repeat(2,1fr)}
  .about-grid,.author-grid,.reg-grid{grid-template-columns:1fr;gap:40px}
  .author-grid{justify-items:center;text-align:left}
  .author-photo{max-width:300px}
  .cards3,.pricing-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}
  .trainer-grid{grid-template-columns:repeat(2,1fr)}
  .acc-inner{grid-template-columns:1fr;padding-left:28px}
}
@media(max-width:760px){
  .nav-links{
    position:fixed;top:72px;left:0;right:0;background:var(--teal-950);
    flex-direction:column;padding:24px;gap:18px;display:none;border-bottom:1px solid rgba(255,255,255,.1);
  }
  .nav-links.show{display:flex}
  .burger{display:block}
  /* compact mobile header: Erickson wordmark (no ICF badge) + register CTA + burger */
  .brand .brand-full{display:none}
  .brand .brand-wordmark{display:block}
  .nav-cta{gap:10px}
  .nav-cta .btn{display:inline-block}
  /* phone hero: single column, centered copy (incl. the gold rule) */
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero-copy{min-width:0;max-width:560px;margin-left:auto;margin-right:auto;text-align:center}
  .hero .hero-copy .sub-rule{margin-left:auto;margin-right:auto}
  .hero-copy .sub{margin-left:auto;margin-right:auto}
  .hero-copy .hero-actions{justify-content:center}
  .hero-img{width:100%;max-width:480px;margin:0 auto}
  section{padding:70px 0}
  .trainer-grid{grid-template-columns:1fr;max-width:380px;margin-left:auto;margin-right:auto}
  .f-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:36px}
  .chip-icf{left:8px}
  .chip-cert{right:8px}
  .hero{padding-top:140px}
  /* trim the slogan card's side padding so the one-line (nowrap) slogan keeps room to fit */
  .vision-band .vision{padding:40px 22px}
}
@media(max-width:480px){
  .vision-band .vision{padding:34px 14px}
}


/* ===== Print / PDF stylesheet (added) ===== */
@media print{
  *,*::before,*::after{-webkit-print-color-adjust:exact !important;print-color-adjust:exact !important;color-adjust:exact !important}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal{opacity:1 !important;transform:none !important}
  @page{margin:11mm}
  html,body{background:#fff !important}
  .wrap{max-width:100% !important;padding-left:0 !important;padding-right:0 !important}
  #header{position:static !important;box-shadow:none !important}
  #burger,.burger{display:none !important}
  section{padding-top:18px !important;padding-bottom:18px !important}
  .float-chip,.stat,.card,.price,.item,.vision,.award,.impact-band,.impact-tile,.hero-img,.frame,figure,blockquote{break-inside:avoid !important;page-break-inside:avoid !important}
  h1,h2,h3{break-after:avoid !important;page-break-after:avoid !important}
  .about-grid{grid-template-columns:1fr !important;gap:22px !important}
  .hero-img{max-width:430px;margin-left:auto;margin-right:auto}
  .float-chip{box-shadow:0 6px 16px rgba(0,0,0,.20) !important}
  .chip-icf{left:6px !important;bottom:14px !important}
  .chip-cert{right:6px !important}
  .vision .src{color:rgba(255,255,255,.92) !important}
}


/* ===== about credibility pillars — qualitative, no overlap with the hero stat numbers ===== */
.vis-creds{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:30px}
.vis-creds .vc{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);padding:26px 20px;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s,border-color .25s}
.vis-creds .vc:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--rust-300)}
.vis-creds .vc b{display:block;font-family:var(--font-display);font-size:1.22rem;font-weight:700;color:var(--teal-700);line-height:1.15;letter-spacing:-.005em}
.vis-creds .vc span{display:block;font-size:.95rem;color:var(--muted);margin-top:10px;line-height:1.45}
@media(max-width:600px){.vis-creds{grid-template-columns:1fr}}

/* ============================================================
   ENHANCEMENTS — Georgian-only redesign (ArchyEDT display system)
   ============================================================ */
/* condensed header on scroll + scroll-spy underline */
.nav{transition:height .3s}
header.scrolled{background:rgba(7,63,82,.97)}
header.scrolled .nav{height:60px}
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:2px;background:var(--rust-500);transition:right .25s ease}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav-links a.active{color:#fff}
/* hero: stacked monumental title + program subtitle rule */
.hero h1 .accent{color:var(--sky)}
.hero .sub-rule{display:block;width:40px;height:3px;background:var(--rust-500);border-radius:2px;margin:0 0 20px}
/* stats: lift + rust accent on hover */
.stat{transition:transform .25s,border-color .25s,background .25s}
.stat:hover{transform:translateY(-4px);border-color:var(--rust-300);background:rgba(255,255,255,.1)}
/* tabular figures so number columns align */
.price,.total b,.stat .num,.acc-inner li{font-variant-numeric:tabular-nums}
/* dark bands get a soft rust glow for continuity across the seams */
.author,#trainers{position:relative;overflow:hidden}
.author::before,#trainers::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(235,190,52,.16),transparent 65%);top:-160px;right:-120px;pointer-events:none}
.author > .wrap,#trainers > .wrap{position:relative;z-index:2}
/* professional line icons (replaced the emojis) */
.bcard .ico svg{width:35px;height:35px;color:var(--teal-950);transition:color .25s}
.bcard:hover .ico svg{color:var(--teal-950)}
.reg-points .ic svg{width:20px;height:20px;color:var(--rust-700)}
/* pricing cards = single-open accordions (uniform teal heads) */
.pricing-grid{align-items:start}
.pcard-toggle{display:block;width:100%;text-align:left;background:none;border:none;padding:0;margin:0;cursor:pointer;font-family:inherit;color:inherit}
.pcard-toggle:focus-visible{outline:2px solid var(--teal-500);outline-offset:-3px}
.psummary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 26px}
.psummary .price{margin:0}
.pchevron{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--teal-700);font-size:.72rem;transition:transform .3s,background .3s,color .3s,border-color .3s}
.pcard.open .pchevron{transform:rotate(180deg);background:var(--teal-900);color:#fff;border-color:var(--teal-900)}
.pcard-body{max-height:0;overflow:hidden;transition:max-height .45s ease}
.pcard-inner{padding:0 26px 26px}
.prereq{font-size:.82rem;color:var(--teal-900);background:var(--teal-soft);border:1px solid var(--line);border-radius:var(--radius-xs);padding:9px 13px;margin-bottom:16px}
.prereq b{color:var(--teal-700)}
/* unified card hover language: rust accent */
.bcard{transition:transform .25s,box-shadow .25s,border-color .25s}
.bcard:hover{transform:translateY(-10px);box-shadow:0 30px 66px rgba(0,23,42,.18);border-color:var(--rust-300)}
.bcard .ico{transition:background .25s,transform .25s}
.bcard:hover .ico{background:linear-gradient(135deg,var(--rust-600),var(--rust-500));transform:scale(1.06) rotate(-3deg)}
.pcard.featured{box-shadow:0 0 0 2px var(--rust-500),var(--shadow)}
.pcard.featured:hover{box-shadow:0 0 0 2px var(--rust-500),var(--shadow-lg)}
.acc-head{transition:background .2s}
.acc-head:hover{background:var(--bg-deep)}
.acc-head .n{transition:transform .25s}
.acc-item:hover .acc-head .n{transform:scale(1.06)}
/* early-bird banner above the pricing grid (replaces the 3 per-card repeats) */
.early-banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 14px;
  margin-top:40px;padding:14px 22px;border-radius:999px;background:var(--rust-soft);
  border:1px solid rgba(235,190,52,.32);text-align:center}
/* both halves identical size + colour (looked mismatched on desktop) */
.early-banner b,.early-banner span{color:var(--rust-700);font-size:1rem;font-weight:700}
.early-banner .sep{color:var(--rust-500)}
/* pricing payment-plan sub-line */
.price .plan{font-size:.78rem;color:var(--muted);margin-top:2px}
/* ---------- tablet (iPad portrait, 761–1000px) ---------- */
@media(min-width:761px) and (max-width:1000px){
  .cards3{grid-template-columns:1fr 1fr;max-width:720px}
  .pricing-grid{max-width:600px}
  .reg-grid{max-width:640px;margin-left:auto;margin-right:auto}
}
/* ---------- phones (≤760px) ---------- */
@media(max-width:760px){
  /* scope the hero photo height to the FRAME image only — never the float-chip badges */
  .hero-img .frame img{height:clamp(260px,56vw,380px)}
  .float-chip{padding:9px 12px;font-size:.72rem;gap:8px}
  .float-chip img{height:28px}
  .chip-cert .big{font-size:.95rem}
  .chip-icf{left:8px;bottom:10px}
  .chip-cert{right:8px;top:10px}
  .burger{padding:11px}
  .stats{gap:12px}
  .stat{padding:18px 12px}
  .stat .num{font-size:clamp(1.7rem,8vw,2.15rem)}
  .stat .lbl{font-size:.72rem;margin-top:4px}
  form{padding:26px 22px}
}
/* ---------- small phones (≤600px) ---------- */
@media(max-width:600px){
  section{padding:60px 0}
  .hero{padding:128px 0 76px}
  .accred{flex-direction:column;gap:12px;margin-top:28px;font-size:1.08rem}
  .accred span{text-align:center}
  .award{flex-direction:column;text-align:center}
  .award img{height:64px}
  .acc-head{padding:20px 16px;gap:14px}
  .acc-head .n{width:40px;height:40px}
  .acc-inner{padding:0 16px 22px}
  .pcard .head{padding:22px 20px 18px}
  .psummary{padding:15px 20px}
  .pcard-inner{padding:0 20px 22px}
  .reg-points li{font-size:.9rem}
  .early-banner{flex-direction:column;gap:4px;border-radius:18px;padding:16px 20px}
  .early-banner .sep{display:none}
  .vision-band{padding:36px 0}
  .vision-band .vision{padding:34px 22px}
}
/* ---------- very small phones (≤380px) ---------- */
@media(max-width:380px){
  .wrap{padding:0 16px}
  .hero h1{line-height:1.05}
  .stat .num{font-size:7.2vw}
  /* keep wordmark + register CTA + burger on one row on tiny phones */
  .brand .brand-wordmark{height:30px}
  .nav-cta{gap:8px}
  .nav-cta .btn.small{padding:8px 13px;font-size:.76rem}
  .burger{padding:9px}
}

/* ============================================================
   GRADUATES / TESTIMONIALS — single-card slider mirroring erickson.edu
   "What our GRADUATES SAY": one large testimonial at a time inside one box,
   with big blue side arrows + dots to switch. The .grad-viewport IS the
   visible card; slides are transparent panels. align-items:stretch makes
   every slide the height of the tallest testimonial, so the box is a FIXED
   size and never resizes while scrolling. Each portrait ring cycles through
   the brand colours, like the reference alternates blue / gold.
   ============================================================ */
#graduates{background:#fff}
.grad-slider{
  display:grid;align-items:center;gap:24px 12px;max-width:1080px;margin:52px auto 0;
  grid-template-columns:auto 1fr auto;
  grid-template-areas:"prev view next" "dots dots dots";
}
.grad-viewport{
  grid-area:view;min-width:0;overflow:hidden;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);touch-action:pan-y;
}
.grad-track{display:flex;align-items:stretch;will-change:transform;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.grad-slide{
  flex:0 0 100%;box-sizing:border-box;padding:52px 62px 46px;text-align:center;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
/* round portrait with a thick brand-colour ring — erickson's bordered circle */
.grad-slide .gphoto{width:138px;height:138px;border-radius:50%;flex-shrink:0;margin-bottom:24px}
.grad-slide .gphoto img{
  width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;
  border:6px solid var(--rust-500);box-shadow:0 10px 24px rgba(0,23,42,.2);
}
/* cycle the ring colour per graduate through the brand palette */
.grad-slide:nth-child(3n+1) .gphoto img{border-color:var(--rust-500)}  /* gold */
.grad-slide:nth-child(3n+2) .gphoto img{border-color:var(--sky)}       /* blue */
.grad-slide:nth-child(3n+3) .gphoto img{border-color:var(--teal-700)}  /* teal */
/* normal text-colour quotation marks around the testimonial */
.grad-slide .gquote{
  margin:4px 0 26px;max-width:800px;quotes:"\201C" "\201D";
  font-size:1.16rem;line-height:1.7;color:var(--teal-900);font-style:italic;
}
.grad-slide .gquote::before{content:open-quote}
.grad-slide .gquote::after{content:close-quote}
.grad-slide .gname{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--teal-900);letter-spacing:-.005em}
.grad-slide .grole{font-size:.88rem;color:var(--rust-700);font-weight:600;margin-top:8px;line-height:1.5;max-width:620px}
/* bubble-less blue chevron arrows (like erickson.edu) — a bold blue ‹ › that fills the
   side space; the chevron is drawn with two borders on a rotated square. */
.grad-arrow{
  width:62px;height:130px;flex-shrink:0;background:none;border:none;box-shadow:none;
  padding:0;cursor:pointer;color:var(--sky);font-family:inherit;
  display:flex;align-items:center;justify-content:center;
  transition:color .2s,transform .2s;
}
.grad-arrow.prev{grid-area:prev}
.grad-arrow.next{grid-area:next}
.grad-arrow::before{
  content:"";display:block;width:34px;height:34px;
  border:solid currentColor;border-width:0 6px 6px 0;transition:border-color .2s;
}
.grad-arrow.prev::before{transform:rotate(135deg);margin-left:10px}   /* points left  ‹ */
.grad-arrow.next::before{transform:rotate(-45deg);margin-right:10px}  /* points right › */
.grad-arrow:hover{color:var(--teal-500);transform:scale(1.14)}
.grad-arrow:active{transform:scale(1.03)}
.grad-arrow:focus-visible{outline:2px solid var(--teal-500);outline-offset:4px;border-radius:8px}
/* dots */
.grad-dots{grid-area:dots;display:flex;justify-content:center;flex-wrap:wrap;gap:11px;margin-top:4px}
.gdot{
  width:11px;height:11px;border-radius:50%;border:none;padding:0;cursor:pointer;
  background:var(--mist);transition:background .25s,transform .25s;
}
.gdot:hover{background:var(--mist-dim)}
.gdot.active{background:var(--rust-500);transform:scale(1.3)}
.gdot:focus-visible{outline:2px solid var(--teal-500);outline-offset:2px}
/* ---------- graduates responsive ---------- */
@media(max-width:1000px){
  .grad-slide{padding:46px 44px 40px}
  .grad-slide .gquote{font-size:1.08rem;max-width:640px}
}
@media(max-width:760px){
  /* arrows drop to a bottom control row beside the dots; the card goes full-width */
  .grad-slider{
    grid-template-columns:1fr auto auto auto 1fr;
    grid-template-areas:"view view view view view" ". prev dots next .";
    gap:18px 22px;max-width:600px;
  }
  .grad-slide{padding:40px 26px 34px}
  .grad-slide .gphoto{width:110px;height:110px;margin-bottom:20px}
  .grad-slide .gquote{font-size:1rem;line-height:1.68;margin:4px 0 22px}
  .grad-slide .gname{font-size:1.18rem}
  .grad-arrow{width:50px;height:50px}
  .grad-arrow::before{width:22px;height:22px;border-width:0 5px 5px 0}
  .grad-arrow.prev::before{margin-left:7px}
  .grad-arrow.next::before{margin-right:7px}
}
@media(max-width:480px){
  .grad-slide{padding:34px 18px 30px}
  .grad-slide .gphoto{width:102px;height:102px}
  .grad-slide .gquote{font-size:.95rem}
  .grad-arrow{width:46px;height:46px}
  .grad-arrow::before{width:19px;height:19px}
}
