/* ===== Scholar marketing site ===== */
:root{
  --navy:#102A43;        /* logo dark */
  --navy-700:#1b3a5b;
  --blue:#1A56A4;        /* logo blue */
  --blue-600:#1d63bd;
  --blue-400:#4f8fe0;
  --teal:#0d9488;        /* app accent */
  --ink:#0f1f33;
  --muted:#5b7088;
  --bg:#f6f9fc;
  --card:#ffffff;
  --line:#e4ecf4;
  --radius:18px;
  --shadow-sm:0 2px 8px rgba(16,42,67,.06);
  --shadow:0 18px 50px -20px rgba(16,42,67,.30);
  --shadow-lg:0 40px 90px -30px rgba(16,42,67,.45);
  --maxw:1160px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  font-family:"Plus Jakarta Sans",system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
  max-width:100%;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;line-height:1.08;letter-spacing:-.01em;color:var(--navy)}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* let grid/flex items shrink below their content's intrinsic width (prevents right-edge overflow) */
.hero-inner>*,.belize-inner>*,.parent-inner>*,.contact-grid>*,
.feature-grid>*,.role-grid>*,.steps>*{min-width:0}

/* ===== animated aurora background ===== */
.bg-aurora{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;will-change:transform}
.orb-1{width:520px;height:520px;background:radial-gradient(circle,#cfe1f7,transparent 70%);top:-160px;left:-120px;animation:drift1 22s ease-in-out infinite}
.orb-2{width:460px;height:460px;background:radial-gradient(circle,#d6f3ee,transparent 70%);top:30%;right:-160px;animation:drift2 26s ease-in-out infinite}
.orb-3{width:420px;height:420px;background:radial-gradient(circle,#e3ecfb,transparent 70%);bottom:-160px;left:30%;animation:drift3 30s ease-in-out infinite}
@keyframes drift1{50%{transform:translate(80px,60px) scale(1.1)}}
@keyframes drift2{50%{transform:translate(-70px,40px) scale(1.08)}}
@keyframes drift3{50%{transform:translate(40px,-60px) scale(1.12)}}

/* ===== nav ===== */
.nav{position:sticky;top:0;z-index:60;transition:background .3s,box-shadow .3s,backdrop-filter .3s}
.nav.scrolled{background:rgba(246,249,252,.82);backdrop-filter:saturate(180%) blur(14px);box-shadow:0 1px 0 var(--line)}
.nav-inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand-crest{transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.brand:hover .brand-crest{transform:rotate(-8deg) scale(1.08)}
.brand-word{font-family:"Fraunces",serif;font-size:1.5rem;font-weight:700;color:var(--navy)}
.nav-links{display:flex;gap:28px;margin-left:auto}
.nav-links a{font-weight:600;font-size:.95rem;color:var(--muted);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--blue);transition:width .3s}
.nav-links a:hover{color:var(--navy)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;gap:10px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.95rem;padding:11px 20px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .2s,box-shadow .25s,background .2s,color .2s;white-space:nowrap}
.btn-lg{padding:15px 28px;font-size:1.02rem}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--navy));color:#fff;box-shadow:0 10px 26px -10px rgba(26,86,164,.7)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px -10px rgba(26,86,164,.85)}
.btn-ghost{background:#fff;color:var(--navy);border-color:var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--blue-400);color:var(--blue)}
.play-dot{width:9px;height:9px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 0 rgba(13,148,136,.5);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 8px rgba(13,148,136,0)}100%{box-shadow:0 0 0 0 rgba(13,148,136,0)}}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}

/* ===== hero ===== */
.hero{padding:64px 0 80px}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.eyebrow{display:inline-block;font-weight:700;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);background:rgba(26,86,164,.08);padding:6px 14px;border-radius:999px;margin-bottom:20px}
.eyebrow.light{color:#bcd6f5;background:rgba(255,255,255,.1)}
.hero h1{font-size:clamp(2.5rem,5.2vw,4rem);font-weight:700}
.grad-text{background:linear-gradient(120deg,var(--blue),var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lede{font-size:1.18rem;color:var(--muted);margin:22px 0 30px;max-width:34ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-actions.center{justify-content:center}
.hero-trust{list-style:none;display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;color:var(--muted);font-weight:600;font-size:.92rem}

/* hero mock */
.hero-visual{position:relative}
.mock-window{background:var(--card);border-radius:20px;box-shadow:var(--shadow-lg);border:1px solid var(--line);overflow:hidden;transform:perspective(1400px) rotateY(-9deg) rotateX(3deg);transition:transform .6s ease}
.hero-visual:hover .mock-window{transform:perspective(1400px) rotateY(-4deg) rotateX(1deg)}
.mock-bar{display:flex;align-items:center;gap:7px;padding:12px 16px;background:#f1f5fa;border-bottom:1px solid var(--line)}
.mock-bar .dot{width:11px;height:11px;border-radius:50%;background:#cdd9e6}
.mock-bar .dot:nth-child(1){background:#ff9b8a}.mock-bar .dot:nth-child(2){background:#ffd479}.mock-bar .dot:nth-child(3){background:#8fd6a4}
.mock-url{margin-left:12px;font-size:.78rem;color:var(--muted);background:#fff;padding:4px 12px;border-radius:999px;border:1px solid var(--line)}
.mock-body{display:grid;grid-template-columns:120px minmax(0,1fr);min-height:330px}
.mock-side{background:var(--navy);padding:16px 12px;display:flex;flex-direction:column;gap:6px}
.mock-logo{display:flex;align-items:center;gap:7px;color:#fff;font-weight:700;font-size:.9rem;margin-bottom:10px}
.mock-nav{color:#9fb6d1;font-size:.82rem;font-weight:600;padding:8px 10px;border-radius:9px}
.mock-nav.active{background:rgba(255,255,255,.12);color:#fff}
.mock-main{padding:18px;display:flex;flex-direction:column;gap:14px;min-width:0}
.mock-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.stat-card{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:12px 10px;text-align:center}
.stat-num{display:block;font-family:"Fraunces",serif;font-weight:700;font-size:1.35rem;color:var(--navy)}
.stat-lbl{font-size:.66rem;color:var(--muted);font-weight:600;line-height:1.2;display:block;margin-top:2px}
.mock-chart{display:flex;align-items:flex-end;gap:8px;height:84px;padding:6px 2px;border-bottom:1px solid var(--line)}
.mock-chart span{flex:1;height:var(--h);background:linear-gradient(180deg,var(--blue-400),var(--blue));border-radius:6px 6px 0 0;transform-origin:bottom;animation:grow 1s ease both}
.mock-chart span:nth-child(odd){background:linear-gradient(180deg,#5fd0c4,var(--teal))}
@keyframes grow{from{transform:scaleY(0)}}
.mock-rows{display:flex;flex-direction:column;gap:7px}
.mock-row{display:flex;align-items:center;gap:9px;font-size:.8rem;color:var(--ink);font-weight:500}
.pill{font-size:.66rem;font-weight:700;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}
.pill.green{background:#dcfce7;color:#15803d}.pill.blue{background:#dbeafe;color:#1d4ed8}.pill.amber{background:#fef3c7;color:#b45309}

.float-badge{position:absolute;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:12px;padding:10px 14px;font-weight:700;font-size:.85rem;color:var(--navy)}
.badge-a{top:8%;left:-26px;animation:bob 4s ease-in-out infinite}
.badge-b{bottom:10%;right:-20px;animation:bob 4s ease-in-out infinite .8s}
@keyframes bob{50%{transform:translateY(-12px)}}

/* ===== strip ===== */
.strip{padding:18px 0 8px}
.strip-label{text-align:center;color:var(--muted);font-weight:600;font-size:.86rem;letter-spacing:.04em;margin-bottom:14px}
.strip-items{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:18px}
.strip-items span{font-family:"Fraunces",serif;font-weight:600;font-size:1.15rem;color:var(--navy-700);opacity:.85}
.strip-items i{width:5px;height:5px;border-radius:50%;background:var(--blue-400)}

/* ===== sections ===== */
.section{padding:90px 0}
.section-tint{background:linear-gradient(180deg,#eef4fb,#f6f9fc)}
.section-head{max-width:680px;margin:0 auto 54px;text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.75rem);margin:14px 0 14px}
.section-head p{color:var(--muted);font-size:1.1rem}

/* features */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.feature::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,86,164,.05),transparent 60%);opacity:0;transition:opacity .3s}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#cfe0f1}
.feature:hover::before{opacity:1}
.f-icon{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;color:#fff;position:relative}
.f-icon svg{width:24px;height:24px}
.i-students{background:linear-gradient(135deg,#1A56A4,#1d63bd)}
.i-attend{background:linear-gradient(135deg,#0d9488,#14b8a6)}
.i-grades{background:linear-gradient(135deg,#6366f1,#4f46e5)}
.i-report{background:linear-gradient(135deg,#0284c7,#0ea5e9)}
.i-billing{background:linear-gradient(135deg,#16a34a,#22c55e)}
.i-whatsapp{background:linear-gradient(135deg,#059669,#10b981)}
.i-payroll{background:linear-gradient(135deg,#d97706,#f59e0b)}
.i-parent{background:linear-gradient(135deg,#7c3aed,#a855f7)}
.i-comms{background:linear-gradient(135deg,#0891b2,#06b6d4)}
.i-secure{background:linear-gradient(135deg,#102A43,#1b3a5b)}
.feature h3{font-size:1.25rem;margin-bottom:8px}
.feature p{color:var(--muted);font-size:.98rem}

/* roles */
.role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.role-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.role-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.role-tag{display:inline-block;font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);background:rgba(26,86,164,.09);padding:6px 13px;border-radius:999px;margin-bottom:16px}
.role-card h3{font-size:1.4rem;margin-bottom:16px}
.ticks{list-style:none;display:flex;flex-direction:column;gap:11px}
.ticks li{position:relative;padding-left:30px;color:var(--muted);font-size:.97rem}
.ticks li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background:var(--teal);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-size:12px;background-repeat:no-repeat;background-position:center}
.ticks.light li{color:#cfe0f3}

/* steps */
.steps{display:flex;align-items:flex-start;justify-content:center;gap:0;flex-wrap:wrap}
.step{flex:1;min-width:230px;max-width:320px;text-align:center;padding:0 18px}
.step-num{display:grid;place-items:center;width:60px;height:60px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--navy));color:#fff;font-family:"Fraunces",serif;font-size:1.6rem;font-weight:700;box-shadow:0 12px 28px -10px rgba(26,86,164,.7)}
.step h3{font-size:1.3rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.98rem}
.step-line{flex:0 0 60px;height:2px;background:repeating-linear-gradient(90deg,var(--blue-400) 0 8px,transparent 8px 16px);margin-top:30px;opacity:.6}

/* belize dark */
.section-dark{background:linear-gradient(160deg,var(--navy),#0a1c30);color:#dce8f5}
.section-dark h2{color:#fff}
.belize-inner{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.belize-copy h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin:14px 0 16px}
.belize-copy>p{color:#a9c2db;font-size:1.1rem;margin-bottom:22px}
.belize-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:26px;backdrop-filter:blur(8px);box-shadow:var(--shadow-lg)}
.bc-row{display:flex;justify-content:space-between;align-items:center;color:#cfe0f3;font-weight:600;font-size:.95rem}
.bc-big{font-family:"Fraunces",serif;font-size:3rem;font-weight:700;color:#fff;margin:8px 0 22px}
.bc-big small{font-family:"Plus Jakarta Sans";font-size:.9rem;color:#9fb6d1;font-weight:600;margin-left:8px}
.bc-bars{display:flex;flex-direction:column;gap:14px;margin-bottom:22px}
.bc-bars div{display:flex;align-items:center;gap:12px}
.bc-bars i{height:10px;border-radius:999px;background:linear-gradient(90deg,var(--blue-400),var(--teal));width:var(--w);min-width:30px;box-shadow:0 0 14px rgba(79,143,224,.5)}
.bc-bars span{font-size:.82rem;color:#a9c2db;white-space:nowrap}
.bc-foot{font-size:.85rem;color:#bcd0e6;display:flex;align-items:center;gap:9px;border-top:1px solid rgba(255,255,255,.12);padding-top:16px}

/* ===== parent portal ===== */
.parent-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.parent-copy>h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin:14px 0 16px}
.parent-copy>p{color:var(--muted);font-size:1.12rem;margin-bottom:30px;max-width:46ch}
.parent-points{display:flex;flex-direction:column;gap:22px;margin-bottom:30px}
.pp{display:flex;gap:16px;align-items:flex-start}
.pp-icon{flex:0 0 46px;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff}
.pp-icon svg{width:22px;height:22px}
.pp h3{font-size:1.18rem;margin-bottom:3px}
.pp p{color:var(--muted);font-size:.98rem}

/* phone mockup */
.parent-visual{position:relative;display:flex;justify-content:center}
.parent-stage{position:relative;width:300px;max-width:100%;display:flex;justify-content:center}
.stage-glow{position:absolute;inset:-8% -14%;background:radial-gradient(60% 55% at 50% 38%,rgba(26,86,164,.32),transparent 70%),radial-gradient(50% 45% at 75% 80%,rgba(13,148,136,.28),transparent 70%);filter:blur(18px);z-index:0;animation:glowpulse 7s ease-in-out infinite}
@keyframes glowpulse{50%{opacity:.7;transform:scale(1.05)}}
.stage-ring{position:absolute;width:340px;height:340px;top:-26px;left:50%;transform:translateX(-50%);border:1.5px dashed rgba(26,86,164,.25);border-radius:50%;z-index:0;animation:spin 40s linear infinite}
@keyframes spin{to{transform:translateX(-50%) rotate(360deg)}}

.phone{position:relative;z-index:1;width:300px;max-width:100%;background:linear-gradient(160deg,#16324f,#0a1c30);border-radius:46px;padding:11px;box-shadow:0 50px 90px -34px rgba(10,28,48,.7),0 0 0 2px rgba(255,255,255,.06) inset,0 2px 6px rgba(255,255,255,.18) inset;animation:phonefloat 6s ease-in-out infinite}
@keyframes phonefloat{50%{transform:translateY(-14px)}}
.phone-btn{position:absolute;background:#16324f;border-radius:4px}
.phone-btn-r{right:-3px;top:130px;width:3px;height:60px}
.phone-btn-l1{left:-3px;top:104px;width:3px;height:34px}
.phone-btn-l2{left:-3px;top:148px;width:3px;height:34px}
.phone-screen{position:relative;background:var(--bg);border-radius:36px;overflow:hidden;display:flex;flex-direction:column;min-height:540px}

.ph-header{position:relative;background:linear-gradient(150deg,var(--blue),var(--navy));padding:30px 18px 20px;color:#fff}
.phone-notch{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:96px;height:20px;background:rgba(0,0,0,.55);border-radius:999px}
.ph-header-row{display:flex;align-items:center;gap:8px;margin-top:6px}
.ph-brand{display:flex;align-items:center;gap:7px;font-weight:700;font-size:.92rem}
.ph-avatar{margin-left:auto;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;font-size:.72rem;font-weight:700}
.ph-greet{font-size:1.05rem;line-height:1.25;margin-top:14px;color:#dbe9fb}
.ph-greet strong{color:#fff;font-family:"Fraunces",serif;font-weight:600;font-size:1.3rem}

.ph-body{padding:14px 14px 18px;display:flex;flex-direction:column;gap:11px;margin-top:-14px}
.ph-child{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px;box-shadow:0 10px 26px -16px rgba(16,42,67,.4)}
.ph-ava{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--navy));color:#fff;display:grid;place-items:center;font-weight:700;font-size:.85rem;flex:0 0 40px}
.ph-child-info{display:flex;flex-direction:column;line-height:1.25}
.ph-child-info strong{font-size:.94rem;color:var(--navy)}
.ph-child-info span{font-size:.74rem;color:var(--muted)}
.ph-attend{margin-left:auto;display:flex;flex-direction:column;align-items:center;line-height:1}
.ph-attend b{font-family:"Fraunces",serif;color:var(--teal);font-size:1.1rem}
.ph-attend i{font-size:.62rem;color:var(--muted);font-style:normal;margin-top:2px}

.ph-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:13px;box-shadow:var(--shadow-sm)}
.ph-card-h{display:flex;justify-content:space-between;align-items:center;font-size:.72rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.ph-chip{font-size:.6rem;background:var(--secondary,#eef2ff);color:var(--blue);padding:3px 8px;border-radius:999px;letter-spacing:0}
.ph-grade{display:flex;justify-content:space-between;align-items:center;padding:6px 0}
.ph-grade+.ph-grade{border-top:1px solid var(--line)}
.g-name{font-size:.86rem;color:var(--ink)}
.g-mark{font-family:"Fraunces",serif;font-weight:700;font-size:.86rem;width:34px;height:24px;display:grid;place-items:center;border-radius:7px}
.m-a{background:#dcfce7;color:#15803d}
.m-b{background:#dbeafe;color:#1d4ed8}

.ph-pay{display:flex;align-items:center;justify-content:space-between}
.ph-pay-left .ph-card-h{margin-bottom:6px}
.ph-bal{display:flex;align-items:baseline;gap:7px}
.ph-bal b{font-family:"Fraunces",serif;font-size:1.5rem;color:var(--navy)}
.ph-bal i{font-style:normal;font-size:.72rem;color:var(--muted)}
.ph-paid{background:#dcfce7;color:#15803d;font-weight:700;font-size:.78rem;padding:8px 12px;border-radius:999px;white-space:nowrap}

.ph-note{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#eef4fb,#e3f0ee);border:1px solid var(--line);border-radius:16px;padding:12px}
.ph-note-ico{flex:0 0 30px;width:30px;height:30px;border-radius:9px;background:var(--blue);color:#fff;display:grid;place-items:center}
.ph-note-ico svg{width:16px;height:16px}
.ph-note p{font-size:.82rem;color:var(--ink);line-height:1.35}
.ph-note strong{color:var(--navy)}

.float-badge.badge-c,.float-chip{display:inline-flex;align-items:center;gap:7px}
.float-badge.badge-c svg,.float-chip svg{width:15px;height:15px}
.float-badge.badge-c{z-index:2;bottom:13%;left:-44px;color:var(--teal);animation:bob 4s ease-in-out infinite .4s}
.float-chip{position:absolute;z-index:2;top:15%;right:-34px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:12px;padding:9px 13px;font-weight:700;font-size:.8rem;color:var(--navy);animation:bob 4.5s ease-in-out infinite 1.1s}
.float-chip svg{color:var(--teal)}

/* ===== pricing ===== */
.price-wrap{display:flex;justify-content:center}
.price-card{position:relative;width:100%;max-width:480px;background:var(--card);border:1px solid var(--line);border-radius:26px;padding:44px 40px 36px;box-shadow:var(--shadow);text-align:center;overflow:hidden}
.price-card::before{content:"";position:absolute;inset:0 0 auto 0;height:6px;background:linear-gradient(90deg,var(--blue),var(--teal))}
.price-ribbon{display:inline-block;font-weight:700;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);background:rgba(26,86,164,.09);padding:6px 14px;border-radius:999px;margin-bottom:18px}
.price-name{font-family:"Fraunces",serif;font-weight:600;font-size:1.35rem;color:var(--navy)}
.price-amount{display:flex;align-items:baseline;justify-content:center;gap:6px;margin:14px 0 6px}
.price-cur{font-family:"Fraunces",serif;font-weight:600;font-size:1.6rem;color:var(--navy);align-self:flex-start;margin-top:10px}
.price-num{font-family:"Fraunces",serif;font-weight:700;font-size:4.6rem;line-height:1;color:var(--navy);letter-spacing:-.02em}
.price-per{font-size:1.05rem;font-weight:600;color:var(--muted)}
.price-sub{color:var(--muted);font-size:.98rem;margin-bottom:26px}
.price-feats{list-style:none;text-align:left;display:flex;flex-direction:column;gap:12px;margin-bottom:30px}
.price-feats li{position:relative;padding-left:32px;color:var(--ink);font-size:.98rem}
.price-feats li::before{content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:var(--teal);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-size:13px;background-repeat:no-repeat;background-position:center}
.price-cta{width:100%;justify-content:center}
.price-foot{color:var(--muted);font-size:.86rem;margin-top:16px}

/* cta band */
.cta-band{display:flex;align-items:center;justify-content:space-between;gap:32px;background:linear-gradient(135deg,#eef4fb,#e3f0ee);border:1px solid var(--line);border-radius:26px;padding:44px 48px;flex-wrap:wrap}
.cta-band h2{font-size:clamp(1.6rem,3vw,2.2rem);margin:10px 0 8px}
.cta-band p{color:var(--muted);max-width:54ch}

/* final */
.final{text-align:center;max-width:680px;margin:0 auto}
.final-crest{margin:0 auto 22px;filter:drop-shadow(0 12px 24px rgba(26,86,164,.3))}
.final h2{font-size:clamp(2rem,4vw,3rem)}
.final p{color:var(--muted);font-size:1.15rem;margin:16px 0 30px}
.final-contact{font-size:.98rem;margin-top:26px}
.final-contact a{color:var(--blue);font-weight:700}

/* ===== contact form ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:center;max-width:1000px;margin:0 auto}
.contact-copy .final-crest{margin:0 0 18px;filter:drop-shadow(0 12px 24px rgba(26,86,164,.3))}
.contact-copy h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:14px}
.contact-copy>p{color:var(--muted);font-size:1.1rem;margin-bottom:22px}
.contact-form{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:30px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cf-field{display:flex;flex-direction:column;gap:6px}
.cf-field span{font-weight:600;font-size:.86rem;color:var(--navy)}
.cf-field span i{color:var(--blue);font-style:normal}
.cf-field input,.cf-field textarea{font-family:inherit;font-size:.96rem;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:11px 13px;transition:border-color .2s,box-shadow .2s;width:100%}
.cf-field input:focus,.cf-field textarea:focus{outline:none;border-color:var(--blue-400);box-shadow:0 0 0 3px rgba(26,86,164,.12);background:#fff}
.cf-field textarea{resize:vertical;min-height:96px}
.cf-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.cf-submit{width:100%;justify-content:center;margin-top:4px}
.cf-submit:disabled{opacity:.7;cursor:default;transform:none}
.cf-status{font-size:.92rem;font-weight:600;margin:0;min-height:1px;text-align:center}
.cf-status.ok{color:#15803d}
.cf-status.err{color:var(--destructive,#dc2626)}
.cf-status a{color:var(--blue);text-decoration:underline}
.cf-fine{font-size:.8rem;color:var(--muted);text-align:center;margin:0}

/* footer */
.footer{background:var(--navy);color:#cbd9e8;padding:54px 0 30px}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.footer-brand{display:flex;align-items:center;gap:10px;font-family:"Fraunces",serif;font-size:1.4rem;font-weight:700;color:#fff}
.footer-tag{color:#9fb6d1;font-size:.95rem}
.footer-links{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;margin:6px 0}
.footer-links a{color:#bcd0e6;font-weight:600;font-size:.92rem;transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-copy{color:#6f89a6;font-size:.84rem;margin-top:8px}

/* ===== reveal animation ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.feature.reveal,.role-card.reveal{transition-delay:var(--d,0s)}

/* ===== responsive ===== */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-visual{max-width:520px;margin:0 auto}
  .mock-window{transform:none!important}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .role-grid{grid-template-columns:1fr}
  .belize-inner{grid-template-columns:1fr;gap:36px}
  .parent-inner{grid-template-columns:1fr;gap:44px}
  .parent-copy>p{max-width:none}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .step-line{display:none}
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:rgba(246,249,252,.97);backdrop-filter:blur(14px);padding:18px 24px;gap:16px;box-shadow:var(--shadow);border-top:1px solid var(--line)}
  .nav.open .nav-cta{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:rgba(246,249,252,.97);padding:0 24px 20px}
}
@media(max-width:600px){
  .feature-grid{grid-template-columns:1fr}
  .section{padding:64px 0}
  .hero{padding:36px 0 56px}
  .cta-band{padding:32px 26px}
  .float-badge,.float-chip{display:none}
  .stage-ring{width:300px;height:300px}
  .hero-trust{gap:14px}
  .cf-row{grid-template-columns:1fr}
  .contact-form{padding:22px}
  /* shrink the hero dashboard mock so it fits a phone-width window */
  .mock-body{grid-template-columns:92px minmax(0,1fr)}
  .mock-side{padding:12px 8px}
  .mock-logo{font-size:.78rem;gap:5px}
  .mock-nav{font-size:.72rem;padding:6px 8px}
  .mock-main{padding:12px;gap:11px}
  .mock-stats{gap:7px}
  .stat-card{padding:9px 5px}
  .stat-num{font-size:.95rem}
  .stat-lbl{font-size:.56rem}
  .mock-chart{height:64px}
  .mock-row{font-size:.74rem}
  .mock-url{font-size:.68rem;padding:3px 9px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
