/* ═══════════════════════════════════════════════════════════════
   AADYA HOPE FOUNDATION — Main CSS v2.0
   DS Awareness: Blue #1565C0 + Yellow #FFD600
   Organisation: West Garo Hills, Meghalaya, Northeast India
   Mobile-first | Accessible | Print-friendly
   ═══════════════════════════════════════════════════════════════ */

:root{
  --blue:#1565C0; --blue2:#1976D2; --blue3:#E3F0FF; --blue4:#F0F6FF; --blue5:#0D47A1;
  --yellow:#FFD600; --yellow2:#FFF8DC; --yellow3:#F9A825;
  --green:#2E7D32; --green2:#E8F5E9;
  --red:#C62828; --red2:#FFEBEE;
  --dark:#0A1628; --dark2:#162038; --dark3:#1E2D4A;
  --mid:#4A5568; --muted:#718096; --light:#F5F7FB; --white:#FFFFFF;
  --gold:#B8860B; --gold2:#FFF9E6;
  --serif:'Merriweather',Georgia,serif;
  --sans:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --border:1px solid rgba(21,101,192,0.12);
  --shadow:0 2px 16px rgba(21,101,192,0.08);
  --shadow2:0 6px 32px rgba(21,101,192,0.16);
  --r:14px; --rm:10px; --rs:6px;
  --trans:all 0.2s ease;
}

/* ── RESET ── */
.ahf *, .ahf *::before, .ahf *::after { box-sizing:border-box; margin:0; padding:0; }
.ahf { font-family:var(--sans); color:var(--dark); line-height:1.65; background:var(--white); }
.ahf img { max-width:100%; height:auto; display:block; }
.ahf a { color:var(--blue); text-decoration:none; transition:var(--trans); }
.ahf a:hover { color:var(--blue5); }

/* ── LAYOUT ── */
.ahf .cnt    { max-width:1120px; margin:0 auto; padding:0 1.25rem; }
.ahf .cnt-sm { max-width:780px;  margin:0 auto; padding:0 1.25rem; }
.ahf .cnt-xs { max-width:540px;  margin:0 auto; padding:0 1.25rem; }

/* ── NAVIGATION ── */
.ahf-nav {
  background:var(--dark); position:sticky; top:0; z-index:1000;
  box-shadow:0 2px 20px rgba(0,0,0,0.35);
}
.ahf-nav-inner {
  display:flex; align-items:center; justify-content:space-between;
  max-width:1120px; margin:0 auto; padding:0 1.25rem; height:66px;
}
.ahf-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.ahf-logo img { height:40px; width:auto; }
.ahf-logo-text { display:flex; flex-direction:column; }
.ahf-logo-name { font-family:var(--serif); font-size:0.9rem; font-weight:700; color:var(--white); line-height:1.1; }
.ahf-logo-sub  { font-size:0.62rem; color:rgba(255,255,255,0.5); letter-spacing:0.06em; text-transform:uppercase; }
.ahf-nav-links { display:flex; align-items:center; gap:2px; }
.ahf-nav-links a {
  color:rgba(255,255,255,0.72); font-size:0.8rem; font-weight:600;
  padding:6px 9px; border-radius:6px; white-space:nowrap; transition:var(--trans);
}
.ahf-nav-links a:hover, .ahf-nav-links a.ahf-current { background:rgba(255,255,255,0.1); color:var(--white); }
.ahf-nav-donate {
  background:linear-gradient(135deg,var(--yellow3),var(--yellow)) !important;
  color:#5a3700 !important; font-weight:700 !important; border-radius:8px !important;
  padding:7px 16px !important;
}
.ahf-nav-login {
  background:rgba(255,255,255,0.1) !important; color:var(--white) !important;
  border:1px solid rgba(255,255,255,0.25) !important; border-radius:8px !important;
}
.ahf-hamburger {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  background:none; border:none; padding:4px;
}
.ahf-hamburger span { display:block; width:24px; height:2px; background:var(--white); border-radius:2px; transition:var(--trans); }
.ahf-mobile-menu {
  display:none; background:var(--dark2); padding:1rem 1.25rem;
  border-top:1px solid rgba(255,255,255,0.07);
}
.ahf-mobile-menu.open { display:block; }
.ahf-mobile-menu a {
  display:block; color:rgba(255,255,255,0.8); font-size:0.9rem; font-weight:600;
  padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.06);
}
.ahf-mobile-menu a:last-child { border-bottom:none; }
.ahf-mobile-menu a:hover { color:var(--yellow); }

/* ── DS AWARENESS STRIP ── */
.ahf-ds-strip {
  background:var(--blue3); border-bottom:2px solid rgba(21,101,192,0.2);
  display:flex; align-items:center; justify-content:center; gap:1.5rem;
  padding:0.6rem 1.25rem; flex-wrap:wrap;
}
.ahf-ds-strip-item { font-size:0.76rem; color:var(--blue5); font-weight:600; display:flex; align-items:center; gap:5px; }

/* ── HERO WITH REAL PHOTOS ── */
.ahf-hero {
  position:relative; overflow:hidden;
  min-height:580px; display:flex; align-items:center;
}
.ahf-hero-bg {
  position:absolute; inset:0; background:var(--dark);
}
.ahf-hero-bg img {
  width:100%; height:100%; object-fit:cover; opacity:0.35;
}
.ahf-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(10,22,40,0.9) 0%, rgba(21,101,192,0.6) 100%);
}
.ahf-hero-content {
  position:relative; z-index:2;
  padding:5rem 1.25rem 4rem; max-width:1120px; margin:0 auto; width:100%;
}
.ahf-hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,214,0,0.15); border:1px solid rgba(255,214,0,0.35);
  color:var(--yellow); font-size:0.7rem; padding:4px 14px; border-radius:20px;
  margin-bottom:1.25rem; font-weight:700; letter-spacing:0.09em; text-transform:uppercase;
}
.ahf-hero h1 {
  font-family:var(--serif); font-size:clamp(1.8rem,5vw,3rem);
  color:var(--white); font-weight:700; line-height:1.18;
  margin-bottom:1rem; max-width:640px;
}
.ahf-hero h1 em { color:var(--yellow); font-style:normal; }
.ahf-hero p {
  font-size:clamp(0.95rem,2.5vw,1.1rem); color:rgba(255,255,255,0.75);
  max-width:540px; margin-bottom:2rem; line-height:1.8;
}
.ahf-hero-btns { display:flex; gap:12px; flex-wrap:wrap; }
.ahf-hero-stats {
  display:flex; gap:2.5rem; flex-wrap:wrap;
  margin-top:3rem; padding-top:2rem;
  border-top:1px solid rgba(255,255,255,0.12);
}
.ahf-stat-n { font-size:clamp(1.6rem,4vw,2.4rem); font-weight:700; color:var(--yellow); font-family:var(--serif); }
.ahf-stat-l { font-size:0.68rem; color:rgba(255,255,255,0.45); text-transform:uppercase; letter-spacing:0.07em; margin-top:2px; }

/* ── PAGE HERO (inner pages) ── */
.ahf-page-hero {
  background:var(--dark); padding:3.5rem 1.25rem 3rem;
  position:relative; overflow:hidden;
}
.ahf-page-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 70% 50%, rgba(21,101,192,0.4) 0%, transparent 65%);
}
.ahf-page-hero .cnt { position:relative; }
.ahf-page-hero h1 {
  font-family:var(--serif); font-size:clamp(1.5rem,4vw,2.4rem);
  color:var(--white); margin-bottom:0.5rem;
}
.ahf-page-hero p { font-size:0.95rem; color:rgba(255,255,255,0.72); max-width:580px; }

/* ── BUTTONS ── */
.btn { display:inline-flex; align-items:center; gap:6px; font-family:var(--sans); font-weight:700; border-radius:var(--rm); transition:var(--trans); cursor:pointer; border:none; font-size:0.9rem; }
.btn-lg  { padding:14px 30px; font-size:1rem; }
.btn-sm  { padding:7px 16px; font-size:0.78rem; }
.btn-full { width:100%; justify-content:center; padding:13px; }
.btn-primary { background:var(--blue); color:var(--white); }
.btn-primary:hover { background:var(--blue5); color:var(--white); transform:translateY(-1px); box-shadow:var(--shadow2); }
.btn-gold { background:linear-gradient(135deg,var(--yellow3),var(--yellow)); color:#5a3700; }
.btn-gold:hover { opacity:0.92; transform:translateY(-1px); color:#5a3700; }
.btn-outline { background:transparent; color:var(--blue); border:2px solid var(--blue); }
.btn-outline:hover { background:var(--blue3); }
.btn-outline-white { background:rgba(255,255,255,0.1); color:var(--white); border:1.5px solid rgba(255,255,255,0.35); }
.btn-outline-white:hover { background:rgba(255,255,255,0.18); color:var(--white); }
.btn-danger { background:var(--red); color:var(--white); }

/* ── SECTIONS ── */
.ahf-sec { padding:4.5rem 1.25rem; }
.ahf-sec-sm { padding:2.5rem 1.25rem; }
.ahf-sec-white  { background:var(--white); }
.ahf-sec-light  { background:var(--light); }
.ahf-sec-blue   { background:var(--blue4); }
.ahf-sec-dark   { background:var(--dark); }
.ahf-sec-dark2  { background:var(--dark2); }
.ahf-sec-yellow { background:var(--yellow2); }
.ahf-sec-hd { text-align:center; margin-bottom:3rem; }
.ahf-sec-hd h2 { font-family:var(--serif); font-size:clamp(1.4rem,3.5vw,2rem); color:var(--blue); margin-bottom:0.5rem; }
.ahf-sec-hd p  { font-size:0.95rem; color:var(--muted); max-width:520px; margin:0 auto; }
.ahf-sec-dark .ahf-sec-hd h2, .ahf-sec-dark2 .ahf-sec-hd h2 { color:var(--white); }
.ahf-sec-dark .ahf-sec-hd p, .ahf-sec-dark2 .ahf-sec-hd p   { color:rgba(255,255,255,0.6); }
.ahf-accent { display:block; width:50px; height:4px; background:var(--yellow); border-radius:2px; margin:0 auto 1.5rem; }
.ahf-accent-left { margin:0 0 1.5rem; }

/* ── CARDS ── */
.ahf-grid { display:grid; gap:1.25rem; }
.g2 { grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.g3 { grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.g4 { grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); }
.ahf-card {
  background:var(--white); border:var(--border); border-radius:var(--r);
  padding:1.5rem; transition:var(--trans); position:relative; overflow:hidden;
}
.ahf-card:hover { border-color:var(--blue2); transform:translateY(-3px); box-shadow:var(--shadow2); }
.ahf-card-bt { border-top:4px solid var(--blue); }
.ahf-card-yt { border-top:4px solid var(--yellow); }
.ahf-card-bl { border-left:4px solid var(--blue); border-radius:0 var(--r) var(--r) 0; }
.ahf-icon { width:52px; height:52px; border-radius:13px; display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:1rem; }
.ahf-card h3 { font-size:1rem; font-weight:700; color:var(--dark); margin-bottom:0.5rem; }
.ahf-card p  { font-size:0.875rem; color:var(--mid); line-height:1.7; }

/* ── PHOTO GALLERY ── */
.ahf-photo-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:12px; }
.ahf-photo-item { border-radius:var(--r); overflow:hidden; position:relative; }
.ahf-photo-item img { width:100%; height:220px; object-fit:cover; transition:transform 0.3s; }
.ahf-photo-item:hover img { transform:scale(1.03); }
.ahf-photo-caption {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent, rgba(10,22,40,0.85));
  color:var(--white); font-size:0.78rem; padding:1rem 1rem 0.75rem;
  transform:translateY(100%); transition:transform 0.25s;
}
.ahf-photo-item:hover .ahf-photo-caption { transform:translateY(0); }

/* ── BANNER PHOTO STRIP ── */
.ahf-banner-strip { display:grid; grid-template-columns:repeat(3,1fr); height:280px; overflow:hidden; }
.ahf-banner-strip-item { overflow:hidden; position:relative; }
.ahf-banner-strip-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.ahf-banner-strip-item:hover img { transform:scale(1.05); }
.ahf-banner-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(21,101,192,0.5),rgba(10,22,40,0.4));
}

/* ── IMPACT BOXES ── */
.ahf-impact-box { background:var(--blue); color:var(--white); border-radius:var(--r); padding:1.5rem; text-align:center; }
.ahf-impact-amount { font-size:1.75rem; font-weight:700; color:var(--yellow); font-family:var(--serif); }
.ahf-impact-desc   { font-size:0.8rem; color:rgba(255,255,255,0.8); margin-top:5px; line-height:1.4; }

/* ── STATS BAR ── */
.ahf-stats-bar { display:grid; grid-template-columns:repeat(4,1fr); background:var(--white); border-bottom:var(--border); }
.ahf-stat-item { padding:1.5rem 1rem; text-align:center; border-right:var(--border); }
.ahf-stat-item:last-child { border-right:none; }
.ahf-stat-big  { font-size:2rem; font-weight:700; color:var(--blue); font-family:var(--serif); }
.ahf-stat-lbl  { font-size:0.68rem; color:var(--muted); text-transform:uppercase; letter-spacing:0.06em; margin-top:3px; }

/* ── TESTIMONIALS / QUOTES ── */
.ahf-quote {
  background:var(--white); border:var(--border); border-left:4px solid var(--yellow);
  border-radius:0 var(--r) var(--r) 0; padding:1.25rem 1.5rem;
}
.ahf-quote p { font-size:0.9rem; font-style:italic; color:var(--mid); line-height:1.8; margin-bottom:0.75rem; }
.ahf-quote-name { font-size:0.85rem; font-weight:700; color:var(--blue); }
.ahf-quote-role { font-size:0.78rem; color:var(--muted); }

/* ── INFO / TIP BOXES ── */
.ahf-tip  { background:var(--green2); border-radius:var(--rm); padding:10px 14px; font-size:0.82rem; color:#1B5E20; line-height:1.65; }
.ahf-info { background:var(--blue3); border-left:3px solid var(--blue); border-radius:0 var(--rm) var(--rm) 0; padding:10px 14px; font-size:0.82rem; color:var(--blue5); line-height:1.65; }
.ahf-warn { background:var(--yellow2); border-left:3px solid var(--yellow3); border-radius:0 var(--rm) var(--rm) 0; padding:10px 14px; font-size:0.82rem; color:#5a3700; line-height:1.65; }

/* ── BADGES ── */
.badge { font-size:0.7rem; padding:2px 9px; border-radius:20px; font-weight:700; letter-spacing:0.04em; display:inline-block; }
.badge-free { background:var(--green2); color:var(--green); }
.badge-pro  { background:var(--blue3);  color:var(--blue5); }
.badge-new  { background:#FFF3E0;       color:#E65100; }
.badge-book { background:var(--gold2);  color:var(--gold); }
.badge-ds   { background:var(--blue);   color:var(--white); }

/* ── FORMS ── */
.ahf-form-group { margin-bottom:1rem; }
.ahf-form-group label { display:block; font-size:0.82rem; font-weight:600; color:var(--mid); margin-bottom:4px; }
.ahf-input, .ahf-select, .ahf-textarea {
  width:100%; padding:11px 14px; border:1.5px solid rgba(21,101,192,0.18);
  border-radius:var(--rm); font-size:0.9rem; font-family:var(--sans);
  color:var(--dark); background:var(--white); transition:var(--trans);
}
.ahf-input:focus, .ahf-select:focus, .ahf-textarea:focus {
  outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(21,101,192,0.12);
}
.ahf-textarea { resize:vertical; min-height:120px; }
.ahf-form-card { background:var(--white); border:var(--border); border-radius:var(--r); padding:2rem; }
.ahf-form-msg  { font-size:0.875rem; padding:10px 14px; border-radius:var(--rm); margin-top:8px; display:none; }
.ahf-form-msg.ok  { background:var(--green2); color:var(--green); display:block; }
.ahf-form-msg.err { background:var(--red2); color:var(--red); display:block; }
.ahf-input-icon { position:relative; }
.ahf-input-icon .ahf-input { padding-left:40px; }
.ahf-input-icon::before { position:absolute; left:14px; top:50%; transform:translateY(-50%); font-size:16px; pointer-events:none; }

/* ── AUTH PAGES ── */
.ahf-auth-wrap {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:var(--light); padding:2rem 1.25rem;
}
.ahf-auth-card {
  background:var(--white); border:var(--border); border-radius:var(--r);
  padding:2.5rem 2rem; width:100%; max-width:420px;
  box-shadow:0 8px 40px rgba(21,101,192,0.12);
}
.ahf-auth-logo { text-align:center; margin-bottom:1.75rem; }
.ahf-auth-logo img { height:56px; width:auto; margin:0 auto 8px; }
.ahf-auth-logo h2 { font-family:var(--serif); font-size:1rem; color:var(--blue); margin-bottom:3px; }
.ahf-auth-logo p  { font-size:0.75rem; color:var(--muted); }
.ahf-auth-tabs { display:flex; background:var(--light); border-radius:var(--rm); padding:4px; margin-bottom:1.5rem; }
.ahf-auth-tab {
  flex:1; padding:8px; border-radius:7px; border:none; background:none;
  font-size:0.85rem; font-weight:700; cursor:pointer; font-family:var(--sans);
  color:var(--muted); transition:var(--trans);
}
.ahf-auth-tab.on { background:var(--white); color:var(--blue); box-shadow:0 1px 6px rgba(0,0,0,0.1); }
.ahf-auth-panel { display:none; }
.ahf-auth-panel.on { display:block; }
.ahf-auth-divider { text-align:center; font-size:0.75rem; color:var(--muted); margin:12px 0; position:relative; }
.ahf-auth-divider::before, .ahf-auth-divider::after { content:''; position:absolute; top:50%; width:42%; height:0.5px; background:rgba(21,101,192,0.15); }
.ahf-auth-divider::before { left:0; } .ahf-auth-divider::after { right:0; }
.ahf-trust-badges { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-top:1rem; }
.ahf-trust-badge  { font-size:0.68rem; color:var(--muted); background:var(--light); padding:3px 8px; border-radius:20px; }

/* ── DASHBOARD ── */
.ahf-dash { padding:2.5rem 1.25rem; background:var(--light); min-height:80vh; }
.ahf-dash-header { background:var(--dark); border-radius:var(--r); padding:1.75rem; margin-bottom:1.5rem; display:flex; align-items:center; gap:1.25rem; }
.ahf-dash-avatar { width:52px; height:52px; border-radius:50%; background:var(--yellow); color:#5a3700; display:flex; align-items:center; justify-content:center; font-size:1.2rem; font-weight:700; flex-shrink:0; }
.ahf-dash-name { font-family:var(--serif); font-size:1.1rem; color:var(--white); }
.ahf-dash-meta { font-size:0.8rem; color:rgba(255,255,255,0.55); margin-top:2px; }
.ahf-dash-plan  { margin-left:auto; }
.ahf-progress-card { background:var(--white); border:var(--border); border-radius:var(--r); padding:1.25rem; margin-bottom:1rem; }
.ahf-progress-row  { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.ahf-progress-lbl  { font-size:0.82rem; font-weight:600; width:120px; flex-shrink:0; }
.ahf-progress-track { flex:1; background:var(--blue3); border-radius:20px; height:9px; overflow:hidden; }
.ahf-progress-fill  { height:100%; border-radius:20px; background:linear-gradient(90deg,var(--blue),var(--blue2)); transition:width 0.5s ease; }
.ahf-progress-pct   { font-size:0.8rem; font-weight:700; color:var(--blue); width:36px; text-align:right; }
.ahf-milestone-row  { display:flex; align-items:flex-start; gap:8px; margin-bottom:8px; padding-bottom:8px; border-bottom:1px solid rgba(21,101,192,0.07); }
.ahf-milestone-row:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0; }
.ahf-ms-dot { width:20px; height:20px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:700; flex-shrink:0; margin-top:1px; }
.ahf-ms-dot.done { background:var(--green2); color:var(--green); }
.ahf-ms-dot.now  { background:var(--blue3); color:var(--blue); }
.ahf-ms-dot.lock { background:#F1EFE8; color:#888; }
.ahf-ms-title { font-size:0.85rem; font-weight:700; }
.ahf-ms-sub   { font-size:0.78rem; color:var(--muted); }

/* ── PLANS ── */
.ahf-plans-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; max-width:720px; margin:0 auto; }
.ahf-plan-card  { background:var(--white); border:var(--border); border-radius:var(--r); padding:1.75rem; position:relative; }
.ahf-plan-card.featured { border:2.5px solid var(--blue); }
.ahf-plan-popular { position:absolute; top:-1px; left:50%; transform:translateX(-50%); background:var(--blue); color:var(--white); font-size:0.68rem; padding:4px 16px; border-radius:0 0 10px 10px; font-weight:700; letter-spacing:0.06em; white-space:nowrap; }
.ahf-plan-tier  { font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--muted); margin-bottom:6px; }
.ahf-plan-price { font-size:2rem; font-weight:700; color:var(--dark); font-family:var(--serif); line-height:1; margin-bottom:4px; }
.ahf-plan-price span { font-size:0.8rem; font-weight:400; color:var(--muted); font-family:var(--sans); }
.ahf-plan-desc  { font-size:0.78rem; color:var(--muted); margin-bottom:1.25rem; line-height:1.5; }
.ahf-plan-feat  { display:flex; align-items:flex-start; gap:8px; font-size:0.85rem; color:var(--mid); margin-bottom:7px; }
.ahf-feat-dot   { width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:9px; flex-shrink:0; margin-top:1px; font-weight:700; }
.ahf-feat-dot.y { background:var(--green2); color:var(--green); }
.ahf-feat-dot.n { background:#F1EFE8; color:#888; }

/* ── MATHS TOOLS UI ── */
.ahf-tools-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.25rem; }
.ahf-tool-card  { background:var(--white); border:var(--border); border-radius:var(--r); padding:1.25rem; position:relative; transition:var(--trans); cursor:pointer; }
.ahf-tool-card:hover { border-color:var(--blue2); transform:translateY(-2px); box-shadow:var(--shadow); }
.ahf-tool-card.locked::after { content:'🔒 Pro'; position:absolute; top:12px; right:12px; background:var(--blue); color:var(--white); font-size:0.65rem; font-weight:700; padding:2px 8px; border-radius:20px; }
.ahf-tool-tabs  { display:flex; background:var(--dark); overflow-x:auto; scrollbar-width:none; }
.ahf-tool-tabs::-webkit-scrollbar { display:none; }
.ahf-ttab { flex:1; min-width:110px; padding:12px 8px; text-align:center; color:rgba(255,255,255,0.55); font-size:0.78rem; font-weight:700; cursor:pointer; border:none; background:none; font-family:var(--sans); border-bottom:3px solid transparent; transition:var(--trans); white-space:nowrap; }
.ahf-ttab.on, .ahf-ttab:hover { color:var(--white); border-bottom-color:var(--yellow); }
.ahf-tool-body { display:none; padding:1.25rem; background:var(--light); }
.ahf-tool-body.on { display:block; }
.ahf-level-tabs { display:flex; gap:6px; margin-bottom:1rem; flex-wrap:wrap; }
.ahf-ltab { padding:7px 14px; border-radius:6px; border:1px solid rgba(21,101,192,0.15); font-size:0.78rem; font-weight:700; cursor:pointer; background:var(--white); color:var(--muted); transition:var(--trans); font-family:var(--sans); }
.ahf-ltab.on { background:var(--blue); color:var(--white); border-color:var(--blue); }
.ahf-ex-card { background:var(--white); border:var(--border); border-radius:var(--r); padding:1.25rem; margin-bottom:10px; }
.ahf-ex-q { font-size:0.9rem; font-weight:700; color:var(--dark); margin-bottom:12px; line-height:1.5; }
.ahf-opts { display:grid; gap:8px; }
.ahf-opts.g2 { grid-template-columns:1fr 1fr; }
.ahf-opts.g4 { grid-template-columns:repeat(4,1fr); }
.ahf-opt { border:1.5px solid rgba(21,101,192,0.15); border-radius:var(--rm); padding:12px 8px; text-align:center; cursor:pointer; background:var(--white); font-size:1rem; font-weight:600; transition:var(--trans); font-family:var(--sans); }
.ahf-opt:hover { background:var(--blue3); border-color:var(--blue); }
.ahf-opt.ok { background:var(--green2); border-color:var(--green); color:var(--green); }
.ahf-opt.no { background:var(--red2); border-color:var(--red); color:var(--red); }
.ahf-fb { font-size:0.82rem; margin-top:10px; min-height:18px; text-align:center; font-weight:700; }
.ahf-fb.ok { color:var(--green); } .ahf-fb.no { color:var(--red); }
.ahf-next-btn { width:100%; margin-top:10px; padding:11px; border-radius:var(--rm); background:var(--blue); color:var(--white); border:none; font-size:0.875rem; font-weight:700; cursor:pointer; font-family:var(--sans); transition:var(--trans); }
.ahf-next-btn:hover { background:var(--blue5); }
.ahf-calc-disp { background:var(--dark); color:#4ade80; font-family:'Courier New',monospace; font-size:1.4rem; padding:12px 14px; border-radius:var(--rm); margin-bottom:10px; text-align:right; min-height:48px; }
.ahf-calc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; }
.ahf-cb { padding:12px 6px; border:1px solid rgba(21,101,192,0.15); border-radius:var(--rm); font-size:0.9rem; font-weight:700; cursor:pointer; background:var(--white); font-family:var(--sans); color:var(--dark); transition:var(--trans); }
.ahf-cb:hover { background:var(--blue3); }
.ahf-cb.op { background:var(--blue3); color:var(--blue5); }
.ahf-cb.eq { background:var(--blue); color:var(--white); }
.ahf-cb.cl { background:var(--red2); color:var(--red); }
.ahf-sort-pool { display:flex; flex-wrap:wrap; gap:8px; padding:10px; background:var(--blue4); border-radius:var(--rm); min-height:52px; }
.ahf-sortable { font-size:1.4rem; cursor:pointer; padding:3px; border-radius:6px; border:2px solid transparent; transition:var(--trans); }
.ahf-sortable.picked { border-color:var(--blue); background:var(--blue3); }
.ahf-bins { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:10px; }
.ahf-bin  { border:2px dashed rgba(21,101,192,0.2); border-radius:var(--rm); min-height:72px; padding:8px; text-align:center; transition:var(--trans); cursor:pointer; }
.ahf-bin:hover { border-color:var(--blue); background:var(--blue4); }
.ahf-bin-lbl { font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; margin-bottom:5px; color:var(--muted); }
.ahf-dot-grid { display:flex; flex-wrap:wrap; gap:5px; width:90px; }
.ahf-dot { width:20px; height:20px; border-radius:50%; background:var(--blue); }
.ahf-step-item { display:flex; align-items:center; gap:10px; padding:10px; border:var(--border); border-radius:var(--rm); margin-bottom:6px; cursor:pointer; background:var(--white); transition:var(--trans); }
.ahf-step-item.done { background:var(--green2); border-color:var(--green); }
.ahf-step-num { width:28px; height:28px; border-radius:50%; background:var(--blue3); color:var(--blue); display:flex; align-items:center; justify-content:center; font-size:0.78rem; font-weight:700; flex-shrink:0; }
.ahf-step-item.done .ahf-step-num { background:var(--green); color:var(--white); }
.ahf-upsell { background:var(--dark); border-radius:var(--r); padding:1.5rem; margin-top:1.25rem; text-align:center; }
.ahf-upsell h3 { font-family:var(--serif); font-size:1rem; color:var(--white); margin-bottom:0.4rem; }
.ahf-upsell p  { font-size:0.8rem; color:rgba(255,255,255,0.6); margin-bottom:1rem; }

/* ── CONTACT ── */
.ahf-contact-item { background:var(--white); border:var(--border); border-radius:var(--rm); padding:1rem 1.25rem; margin-bottom:10px; }
.ahf-contact-item h3 { font-size:0.72rem; font-weight:700; color:var(--blue); text-transform:uppercase; letter-spacing:0.07em; margin-bottom:4px; }
.ahf-contact-item p  { font-size:0.875rem; color:var(--mid); line-height:1.65; }
.ahf-contact-item a  { color:var(--blue); }

/* ── BLOG CARDS ── */
.ahf-blog-card { background:var(--white); border:var(--border); border-radius:var(--r); padding:1.5rem; }
.ahf-blog-card h3 { font-size:0.95rem; font-weight:700; margin-bottom:0.5rem; line-height:1.4; }
.ahf-blog-card p  { font-size:0.85rem; color:var(--mid); }
.ahf-blog-meta { font-size:0.75rem; color:var(--muted); margin-top:0.75rem; }

/* ── ACTIVATION BOX ── */
.ahf-activation-box { background:var(--gold2); border:2px solid var(--yellow3); border-radius:var(--rm); padding:1.25rem 1.5rem; margin-top:1.5rem; }
.ahf-activation-box h3 { font-size:0.95rem; font-weight:700; color:#5a3700; margin-bottom:4px; }
.ahf-activation-box p  { font-size:0.85rem; color:#7a5c00; line-height:1.65; }

/* ── FOOTER ── */
.ahf-footer { background:#06101f; color:rgba(255,255,255,0.6); }
.ahf-footer-top { padding:3.5rem 1.25rem 2.5rem; }
.ahf-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:2.5rem; max-width:1120px; margin:0 auto; }
.ahf-footer-brand img  { height:44px; width:auto; margin-bottom:1rem; }
.ahf-footer-brand h3   { font-family:var(--serif); font-size:1rem; color:var(--white); margin-bottom:0.6rem; }
.ahf-footer-brand p    { font-size:0.82rem; line-height:1.75; }
.ahf-footer-col h4     { font-size:0.7rem; font-weight:700; color:var(--yellow); text-transform:uppercase; letter-spacing:0.09em; margin-bottom:1rem; }
.ahf-footer-col a      { display:block; font-size:0.82rem; color:rgba(255,255,255,0.6); padding:4px 0; transition:var(--trans); }
.ahf-footer-col a:hover{ color:var(--white); }
.ahf-footer-bottom     { border-top:1px solid rgba(255,255,255,0.07); padding:1.25rem; text-align:center; font-size:0.76rem; max-width:1120px; margin:0 auto; }

/* ── CTA BAND ── */
.ahf-cta-band { background:var(--blue); color:var(--white); padding:4rem 1.25rem; text-align:center; }
.ahf-cta-band h2 { font-family:var(--serif); font-size:clamp(1.4rem,3.5vw,2rem); color:var(--white); margin-bottom:0.75rem; }
.ahf-cta-band p  { font-size:0.95rem; color:rgba(255,255,255,0.78); margin-bottom:1.75rem; max-width:480px; margin-left:auto; margin-right:auto; }
.ahf-cta-btns    { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ── TEAM CARD ── */
.ahf-team-card { background:var(--white); border:var(--border); border-radius:var(--r); padding:1.5rem; display:flex; align-items:flex-start; gap:1rem; }
.ahf-avatar { width:52px; height:52px; border-radius:50%; flex-shrink:0; background:var(--blue3); color:var(--blue); border:2px solid var(--blue); display:flex; align-items:center; justify-content:center; font-size:1rem; font-weight:700; }

/* ── PROGRESS BAR ── */
.ahf-prog-bar  { background:var(--blue3); border-radius:20px; height:10px; overflow:hidden; margin:6px 0; }
.ahf-prog-fill { background:linear-gradient(90deg,var(--blue),var(--blue2)); height:100%; border-radius:20px; }
.ahf-prog-lbl  { display:flex; justify-content:space-between; font-size:0.75rem; color:var(--muted); margin-top:4px; }

/* ── RESPONSIVE ── */
@media(max-width:900px) { .ahf-footer-grid { grid-template-columns:1fr 1fr; gap:2rem; } }
@media(max-width:680px) {
  .ahf-nav-links { display:none; }
  .ahf-hamburger { display:flex; }
  .ahf-stats-bar { grid-template-columns:repeat(2,1fr); }
  .ahf-stats-bar .ahf-stat-item:nth-child(2) { border-right:none; }
  .ahf-banner-strip { grid-template-columns:1fr; height:auto; }
  .ahf-banner-strip-item:not(:first-child) { display:none; }
  .ahf-sec { padding:3rem 1.25rem; }
  .ahf-footer-grid { grid-template-columns:1fr; gap:1.5rem; }
  .ahf-plans-grid { grid-template-columns:1fr; }
  .ahf-opts.g4 { grid-template-columns:repeat(2,1fr); }
  .ahf-hero-stats { gap:1.5rem; }
  .ahf-dash-header { flex-wrap:wrap; gap:0.75rem; }
  .ahf-dash-plan { margin-left:0; }
}
@media(max-width:420px) {
  .ahf-hero-btns, .ahf-cta-btns { flex-direction:column; align-items:stretch; }
  .ahf-g4 { grid-template-columns:repeat(2,1fr); }
}
