/* ============================================================
   DISHA Marketing Site — shared styles
   Brand: primary #1f4e8c · accent #fb7220 · gold #f59e0b
   ============================================================ */
:root{
  --blue:#1f4e8c;
  --blue-dark:#163a69;
  --blue-deep:#0f2747;
  --orange:#fb7220;
  --gold:#f59e0b;
  --ink:#0f172a;
  --slate:#475569;
  --muted:#64748b;
  --line:#e5e9f0;
  --bg:#f6f9fc;
  --card:#ffffff;
  --green:#15803d;
  --radius:18px;
  --shadow:0 18px 50px rgba(15,39,71,.10);
  --shadow-sm:0 6px 18px rgba(15,39,71,.08);
  --maxw:1280px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%}
*{min-width:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,4vw,64px)}
section{padding:84px 0}
h1,h2,h3{line-height:1.15;letter-spacing:-.02em;font-weight:800}
h2.section-title{font-size:clamp(26px,3.6vw,40px);text-align:center}
.lead{color:var(--slate);font-size:18px}
.eyebrow{
  display:inline-block;font-size:13px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--orange);margin-bottom:14px;
}
.center{text-align:center}
.muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:700;font-size:16px;padding:14px 26px;border-radius:999px;
  border:2px solid transparent;cursor:pointer;transition:.18s ease;white-space:nowrap;
}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 10px 24px rgba(251,114,32,.32)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(251,114,32,.42)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-dark);transform:translateY(-2px)}
.btn-outline{background:#fff;color:var(--blue);border-color:var(--line)}
.btn-outline:hover{border-color:var(--blue)}
.btn-lg{padding:16px 32px;font-size:17px}

/* ---------- Header ---------- */
header.site{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px;color:var(--blue)}
.brand img{height:48px;width:auto}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-weight:600;color:var(--slate);font-size:15px}
.nav-links a:hover{color:var(--blue)}
.nav-cta{display:flex;align-items:center;gap:12px}
.menu-toggle{display:none;background:none;border:none;font-size:26px;color:var(--blue);cursor:pointer}
.app-icon{display:none;width:40px;height:40px;border-radius:10px;overflow:hidden;flex:0 0 auto;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.app-icon img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(circle at 12% 18%,rgba(251,114,32,.20),transparent 30rem),
    radial-gradient(circle at 88% 12%,rgba(245,158,11,.18),transparent 28rem),
    linear-gradient(160deg,var(--blue-deep),var(--blue) 70%);
  color:#fff;padding:84px 0 96px;overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(34px,5vw,56px);font-weight:900;margin-bottom:20px}
.hero h1 .hl{color:var(--gold)}
.hero p.lead{color:rgba(255,255,255,.86);max-width:540px}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-trust{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.hero-trust .t-num{font-size:26px;font-weight:900;color:var(--gold)}
.hero-trust .t-lbl{font-size:13px;color:rgba(255,255,255,.72)}
.hero-card{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  border-radius:26px;padding:26px;backdrop-filter:blur(6px);
}
.phone{
  background:#fff;border-radius:22px;padding:20px;color:var(--ink);box-shadow:var(--shadow);
}
.phone-step{display:flex;gap:13px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line)}
.phone-step:last-child{border-bottom:none}
.step-ico{
  flex:0 0 38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:#eef4fb;color:var(--blue);font-size:19px;font-weight:800;
}
.step-ico.o{background:#fff1e8;color:var(--orange)}
.step-ico.g{background:#fef6e7;color:var(--gold)}
.step-ico.gr{background:#eafaf0;color:var(--green)}
.phone-step h4{font-size:15px;font-weight:700}
.phone-step p{font-size:13.5px;color:var(--muted)}

/* ---------- Logos / stat strip ---------- */
.strip{background:#fff;border-bottom:1px solid var(--line);padding:30px 0}
.strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
.strip .s-num{font-size:30px;font-weight:900;color:var(--blue)}
.strip .s-lbl{font-size:13.5px;color:var(--muted);font-weight:600}

/* ---------- Cards ---------- */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-sm);transition:.2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ico{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  font-size:24px;margin-bottom:16px;background:#eef4fb;color:var(--blue);
}
.card .ico.o{background:#fff1e8;color:var(--orange)}
.card .ico.g{background:#fef6e7;color:var(--gold)}
.card h3{font-size:19px;margin-bottom:8px}
.card p{color:var(--slate);font-size:15px}

/* ---------- How it works steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:46px}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.step .num{
  width:42px;height:42px;border-radius:12px;background:var(--blue);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:18px;margin-bottom:14px;
}
.step.alt .num{background:var(--orange)}
.step h3{font-size:17px;margin-bottom:6px}
.step p{font-size:14.5px;color:var(--slate)}
.flow-note{
  margin-top:30px;background:#eef4fb;border:1px solid #d6e3f3;border-radius:14px;
  padding:18px 22px;color:var(--blue-dark);font-size:14.5px;text-align:center;
}

/* ---------- Section variants ---------- */
.bg-white{background:#fff}
.bg-soft{background:linear-gradient(180deg,#fff,var(--bg))}

/* ---------- FLL arenas ---------- */
.arena-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px}
.arena{
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;text-align:center;transition:.2s;
}
.arena:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:#cdd9ea}
.arena .emoji{font-size:30px;margin-bottom:10px}
.arena h4{font-size:15.5px;margin-bottom:4px}
.arena p{font-size:12.5px;color:var(--muted)}

/* ---------- Pricing / programs ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px;align-items:stretch}
.plan{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;display:flex;flex-direction:column;
}
.plan.featured{border:2px solid var(--orange);box-shadow:var(--shadow);position:relative}
.plan.featured .tag{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--orange);color:#fff;font-size:12px;font-weight:700;padding:5px 16px;border-radius:999px;
}
.plan h3{font-size:20px}
.plan .price{font-size:34px;font-weight:900;color:var(--blue);margin:12px 0 2px}
.plan .price small{font-size:15px;font-weight:600;color:var(--muted)}
.plan ul{list-style:none;margin:18px 0 24px;display:flex;flex-direction:column;gap:11px}
.plan li{font-size:14.5px;color:var(--slate);display:flex;gap:9px;align-items:flex-start}
.plan li::before{content:"✓";color:var(--green);font-weight:800}
.plan .btn{margin-top:auto;justify-content:center}
.price-foot{text-align:center;margin-top:24px;color:var(--muted);font-size:14px}

/* ---------- Testimonials ---------- */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.quote p{font-size:15px;color:var(--ink);font-style:italic}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:16px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-weight:800}
.quote .who b{font-size:14.5px}
.quote .who span{font-size:13px;color:var(--muted);display:block}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:42px auto 0}
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0 22px;margin-bottom:14px}
.faq summary{padding:20px 0;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--orange);font-size:22px;font-weight:700}
.faq details[open] summary::after{content:"−"}
.faq p{padding:0 0 20px;color:var(--slate);font-size:15px}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;text-align:center;border-radius:26px;
  padding:58px 30px;margin:0 22px;
}
.cta-band h2{font-size:clamp(26px,3.5vw,38px);margin-bottom:14px}
.cta-band p{color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 28px}

/* ---------- Forms ---------- */
.form-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;
  font-family:inherit;font-size:15px;color:var(--ink);transition:.15s;background:#fff;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field textarea{resize:vertical;min-height:96px}
.form-side .ico-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.form-side .ico-row .ico{flex:0 0 44px;height:44px;border-radius:12px;background:#eef4fb;color:var(--blue);display:grid;place-items:center;font-size:20px}
.form-side .ico-row h4{font-size:16px}
.form-side .ico-row p{font-size:14px;color:var(--slate)}
.form-note{font-size:13px;color:var(--muted);margin-top:8px}
.alert{padding:14px 16px;border-radius:11px;font-size:14.5px;margin-bottom:18px;display:none}
.alert.ok{background:#eafaf0;color:var(--green);border:1px solid #bfe6cd}
.alert.err{background:#fdecec;color:#b91c1c;border:1px solid #f5c2c2}

/* ---------- Legal / article pages ---------- */
.page-head{
  background:linear-gradient(160deg,var(--blue-deep),var(--blue) 75%);color:#fff;padding:56px 0 46px;
}
.page-head h1{font-size:clamp(28px,4vw,42px)}
.page-head p{color:rgba(255,255,255,.82);margin-top:10px}
.legal{max-width:820px;margin:0 auto;padding:56px 0}
.legal h2{font-size:22px;margin:34px 0 10px;color:var(--blue-dark)}
.legal h3{font-size:17px;margin:22px 0 6px}
.legal p,.legal li{color:var(--slate);font-size:15.5px;margin-bottom:12px}
.legal ul{padding-left:22px;margin-bottom:14px}
.legal li{margin-bottom:7px}
.legal a{color:var(--blue);font-weight:600;text-decoration:underline}
.legal .updated{color:var(--muted);font-size:14px;margin-bottom:8px}
.legal .note{background:#eef4fb;border:1px solid #d6e3f3;border-radius:12px;padding:16px 18px;color:var(--blue-dark);font-size:14.5px}
.legal .placeholder{background:#fff7e6;border:1px dashed #f0c36b;border-radius:10px;padding:3px 8px;color:#92600a;font-weight:600;font-size:13.5px}

/* ---------- Footer ---------- */
footer.site{background:var(--blue-deep);color:#cbd5e1;padding:56px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
footer .brand{color:#fff;margin-bottom:14px}
footer p{font-size:14px;color:#9fb3cc;max-width:300px}
footer h5{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
footer ul a{font-size:14.5px;color:#bcd0e8}
footer ul a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#8aa1bd}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid,.form-wrap{grid-template-columns:1fr}
  .grid-4,.arena-grid{grid-template-columns:repeat(2,1fr)}
  .grid-3,.price-grid,.steps{grid-template-columns:1fr 1fr}
  .strip-grid{grid-template-columns:repeat(2,1fr);gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
/* Phones / narrow tablets — collapse everything to a single clean column */
@media(max-width:820px){
  section{padding:56px 0}
  .nav{height:64px}
  .nav-links{
    display:none;position:absolute;top:64px;left:0;right:0;background:#fff;flex-direction:column;
    align-items:flex-start;gap:0;padding:8px 22px 18px;border-bottom:1px solid var(--line);box-shadow:va