/* ===========================================================
   רוקדים ללא גבולות ומוגבלות — Design System
   RTL · Hebrew · accessible · warm/joyful/dignified
   =========================================================== */

/* ---------- Tokens ---------- */
:root{
  /* brand */
  --navy:#0b2c63;
  --navy-700:#0a234d;
  --blue:#1657c8;
  --blue-600:#1e63d6;
  --blue-300:#7ba6f0;
  --sky:#eaf2ff;
  --sky-2:#f4f8ff;
  --gold:#d99a2b;
  --gold-400:#e7b24a;
  --gold-deep:#a96e16;
  --gold-soft:#fcefd4;

  --ink:#16223f;
  --muted:#51618a;
  --line:#e2e9f6;
  --white:#ffffff;
  --cream:#fbfcff;

  /* semantic */
  --bg:var(--cream);
  --surface:var(--white);
  --surface-alt:var(--sky-2);
  --text:var(--ink);
  --text-soft:var(--muted);
  --primary:var(--blue);

  /* type */
  --f-display:"Suez One", "Heebo", system-ui, sans-serif;
  --f-body:"Heebo", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* spacing */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:24px;
  --sp-6:32px; --sp-7:48px; --sp-8:64px; --sp-9:96px; --sp-10:128px;

  /* radius */
  --r-sm:10px; --r:18px; --r-lg:28px; --r-xl:36px; --r-pill:999px;

  /* shadow */
  --sh-1:0 1px 2px rgba(11,44,99,.06), 0 2px 8px rgba(11,44,99,.05);
  --sh-2:0 8px 24px rgba(11,44,99,.10);
  --sh-3:0 18px 50px rgba(11,44,99,.16);
  --sh-gold:0 14px 34px rgba(217,154,43,.30);

  --container:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--f-body); font-size:17px; line-height:1.7;
  font-weight:400; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video{max-width:100%; height:auto; display:block}
svg{width:1.3em; height:1.3em; flex:none; vertical-align:-.18em}
.ribbon svg{width:100%; height:auto; vertical-align:top}
.embed svg{width:auto;height:auto}
a{color:var(--blue); text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--f-display); font-weight:400; line-height:1.12; color:var(--navy); margin:0 0 .4em}
p{margin:0 0 1em}
ul{margin:0; padding:0; list-style:none}
:focus-visible{outline:3px solid var(--gold); outline-offset:3px; border-radius:6px}

/* ---------- Utilities ---------- */
.container{width:min(100% - 40px, var(--container)); margin-inline:auto}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:700; font-size:.82rem; letter-spacing:.04em;
  color:var(--gold-deep); background:var(--gold-soft);
  padding:7px 16px; border-radius:var(--r-pill);
  border:1px solid #f0dcae;
}
.eyebrow.on-dark{color:#ffe7b0; background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.22)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex:none}
.lead{font-size:1.18rem; color:var(--text-soft); line-height:1.75; max-width:62ch}
.center{text-align:center}
.center .lead{margin-inline:auto}
.section{padding:var(--sp-9) 0}
.section--tight{padding:var(--sp-8) 0}
.muted{color:var(--text-soft)}
.hl{color:var(--blue); font-weight:700}
.nowrap{white-space:nowrap}

h1{font-size:clamp(2.3rem,6.2vw,4.5rem)}
h2.title{font-size:clamp(1.9rem,4.4vw,3.1rem); margin-bottom:.5em}
h3{font-size:1.35rem}
.sec-head{max-width:64ch}
.sec-head.center{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--blue); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 28px; min-height:52px;
  font-weight:700; font-size:1.02rem; border-radius:var(--r-pill);
  background:var(--bg); color:var(--fg); border:2px solid transparent;
  cursor:pointer; transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s;
  box-shadow:var(--sh-1);
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--gold{
  --fg:var(--navy-700);
  background:linear-gradient(135deg,var(--gold-400),var(--gold));
  box-shadow:var(--sh-gold);
}
.btn--gold:hover{box-shadow:0 18px 42px rgba(217,154,43,.42)}
.btn--ghost{--bg:transparent; --fg:var(--navy); border-color:var(--line); box-shadow:none; background:#fff}
.btn--ghost:hover{border-color:var(--blue-300); background:var(--sky-2)}
.btn--light{--bg:#fff; --fg:var(--navy)}
.btn--on-dark{--bg:rgba(255,255,255,.14); --fg:#fff; border-color:rgba(255,255,255,.3); backdrop-filter:blur(6px)}
.btn--on-dark:hover{background:rgba(255,255,255,.24)}
.btn .ico{width:20px;height:20px;flex:none}
.btn-row{display:flex; flex-wrap:wrap; gap:14px}
.btn-row.center{justify-content:center}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.82); backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s, background .3s;
}
.site-header.scrolled{box-shadow:var(--sh-2)}
.nav{display:flex; align-items:center; justify-content:space-between; gap:20px; height:72px}
.brand{display:flex; align-items:center; gap:12px; font-family:var(--f-display); color:var(--navy); font-size:1.12rem}
.brand img{width:46px; height:46px; border-radius:12px; object-fit:cover; box-shadow:var(--sh-1)}
.brand .b-sub{display:block; font-family:var(--f-body); font-weight:600; font-size:.7rem; color:var(--gold-deep); letter-spacing:.02em; margin-top:1px}
.nav-links{display:flex; align-items:center; gap:4px}
.nav-links a{
  color:var(--navy); font-weight:600; font-size:.98rem;
  padding:9px 14px; border-radius:var(--r-pill); position:relative;
  transition:background .2s, color .2s;
}
.nav-links a:hover{background:var(--sky)}
.nav-links a.active{color:var(--blue)}
.nav-links a.active::after{
  content:""; position:absolute; inset-inline:14px; bottom:3px; height:3px;
  background:var(--gold); border-radius:3px;
}
.nav-cta{display:flex; align-items:center; gap:10px}
.nav-cta .btn{padding:11px 20px; min-height:44px; font-size:.95rem}
.hamburger{
  display:none; width:46px;height:46px; border:1px solid var(--line); background:#fff;
  border-radius:12px; cursor:pointer; align-items:center; justify-content:center;
}
.hamburger span{position:relative; width:20px; height:2px; background:var(--navy); border-radius:2px; transition:.25s}
.hamburger span::before,.hamburger span::after{content:""; position:absolute; left:0; width:20px; height:2px; background:var(--navy); border-radius:2px; transition:.25s}
.hamburger span::before{top:-6px} .hamburger span::after{top:6px}
body.menu-open .hamburger span{background:transparent}
body.menu-open .hamburger span::before{top:0; transform:rotate(45deg)}
body.menu-open .hamburger span::after{top:0; transform:rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed; inset:0 0 0 auto; width:min(86vw,360px); z-index:120;
  background:#fff; box-shadow:var(--sh-3); transform:translateX(100%);
  transition:transform .35s var(--ease); padding:84px 22px 24px;
  display:flex; flex-direction:column; gap:6px; overflow-y:auto;
}
body.menu-open .drawer{transform:translateX(0)}
.drawer a{color:var(--navy); font-weight:600; font-size:1.1rem; padding:14px 16px; border-radius:14px}
.drawer a:hover,.drawer a.active{background:var(--sky); color:var(--blue)}
.drawer .btn{margin-top:14px}
.scrim{
  position:fixed; inset:0; background:rgba(11,44,99,.5); backdrop-filter:blur(2px);
  z-index:110; opacity:0; visibility:hidden; transition:.3s;
}
body.menu-open .scrim{opacity:1; visibility:visible}
.skip-link{position:absolute; right:-9999px; top:8px; background:var(--navy); color:#fff; padding:10px 16px; border-radius:10px; z-index:200}
.skip-link:focus{right:12px}

/* ---------- Hero ---------- */
.hero{position:relative; overflow:hidden; padding:var(--sp-9) 0 var(--sp-8);
  background:
    radial-gradient(1200px 600px at 85% -10%, var(--gold-soft), transparent 60%),
    radial-gradient(1000px 700px at 0% 0%, var(--sky), transparent 55%),
    linear-gradient(180deg,#fff, var(--cream));
}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:var(--sp-8); align-items:center}
.hero h1{margin-bottom:.25em}
.hero h1 .swash{color:var(--blue); position:relative; white-space:nowrap}
.hero h1 .swash::after{
  content:""; position:absolute; right:0; left:0; bottom:.02em; height:.18em;
  background:linear-gradient(90deg,var(--gold-400),var(--gold)); border-radius:6px; z-index:-1; opacity:.55;
}
.hero .lead{margin-top:.4em}
.hero-cta{margin-top:var(--sp-6)}
.hero-trust{margin-top:var(--sp-6); display:flex; flex-wrap:wrap; gap:18px 26px; align-items:center}
.hero-trust .t{display:flex; align-items:baseline; gap:8px}
.hero-trust .n{font-family:var(--f-display); font-size:1.7rem; color:var(--navy)}
.hero-trust .l{font-size:.9rem; color:var(--text-soft)}
.hero-trust .sep{width:1px; height:30px; background:var(--line)}

.hero-media{position:relative}
.hero-photo{
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  box-shadow:var(--sh-3); aspect-ratio:4/3; transform:rotate(-1.2deg);
}
.hero-photo img{width:100%; height:100%; object-fit:cover}
.hero-photo .credit{position:absolute; inset-inline-end:12px; bottom:10px; font-size:.7rem; color:#fff; background:rgba(11,44,99,.55); padding:3px 9px; border-radius:999px; backdrop-filter:blur(4px)}
.hero-badge{
  position:absolute; inset-block-start:-22px; inset-inline-start:-18px;
  background:#fff; border-radius:var(--r); box-shadow:var(--sh-2);
  padding:12px 16px; display:flex; align-items:center; gap:10px; transform:rotate(2deg);
  border:1px solid var(--line);
}
.hero-badge .emoji-ring{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gold-400),var(--gold));display:grid;place-items:center;color:#fff}
.hero-badge b{font-family:var(--f-display); color:var(--navy); font-size:1rem; display:block}
.hero-badge small{color:var(--text-soft); font-size:.78rem}

/* decorative rotating ring */
.ring-decor{position:absolute; z-index:0; border-radius:50%; border:2px dashed rgba(22,87,200,.18); animation:spin 70s linear infinite}
.ring-decor.r1{width:340px;height:340px; inset-block-start:-90px; inset-inline-end:-80px}
.ring-decor.r2{width:200px;height:200px; inset-block-end:-50px; inset-inline-start:-40px; border-color:rgba(217,154,43,.28); animation-duration:48s; animation-direction:reverse}
.float-dot{position:absolute; border-radius:50%; z-index:0; opacity:.5; animation:float 9s ease-in-out infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

/* ---------- Ribbon divider ---------- */
.ribbon{display:block; width:100%; height:auto; line-height:0}
.ribbon svg{display:block;width:100%;height:auto}

/* ---------- Stats band ---------- */
.stats{background:linear-gradient(135deg,var(--navy),#123a82); color:#fff; position:relative; overflow:hidden}
.stats::before{content:""; position:absolute; inset:0; background:radial-gradient(600px 300px at 90% 0%, rgba(217,154,43,.22), transparent 60%)}
.stats .container{position:relative}
.stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-5); text-align:center}
.stat .num{font-family:var(--f-display); font-size:clamp(2.4rem,5vw,3.4rem); line-height:1; color:#fff}
.stat .num .plus{color:var(--gold-400)}
.stat .lbl{margin-top:8px; color:#cdddff; font-weight:600; font-size:.98rem}
.stat .sub{color:#9fb9ec; font-size:.82rem}

/* ---------- Feature cards ---------- */
.cards{display:grid; gap:var(--sp-5)}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.cards.c4{grid-template-columns:repeat(4,1fr)}
.cards.c2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:var(--sp-6); box-shadow:var(--sh-1);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.card:hover{transform:translateY(-4px); box-shadow:var(--sh-2); border-color:#d4e1f6}
.card .ic{
  width:54px;height:54px;border-radius:16px; display:grid; place-items:center; margin-bottom:16px;
  background:var(--sky); color:var(--blue);
}
.card.gold .ic{background:var(--gold-soft); color:var(--gold-deep)}
.card h3{margin-bottom:.35em; font-size:1.25rem}
.card p{color:var(--text-soft); margin:0; font-size:1rem}
.ic svg{width:28px;height:28px}

/* value chips */
.chips{display:flex; flex-wrap:wrap; gap:10px}
.chip{display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--line);
  padding:9px 16px; border-radius:var(--r-pill); font-weight:600; color:var(--navy); font-size:.95rem; box-shadow:var(--sh-1)}
.chip svg{width:18px;height:18px;color:var(--gold-deep)}

/* ---------- Split feature ---------- */
.split{display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-8); align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative}
.split-media img{border-radius:var(--r-xl); box-shadow:var(--sh-3); width:100%; object-fit:cover}
.split-media .caption{position:absolute; inset-inline:14px; bottom:14px; background:rgba(11,44,99,.62); color:#fff; padding:10px 14px; border-radius:14px; font-size:.85rem; backdrop-filter:blur(4px)}
.tick-list{display:grid; gap:14px; margin-top:var(--sp-5)}
.tick-list li{display:flex; gap:12px; align-items:flex-start; color:var(--text)}
.tick-list .tk{flex:none; width:26px;height:26px;border-radius:50%;background:var(--gold-soft);color:var(--gold-deep);display:grid;place-items:center;margin-top:2px}
.tick-list .tk svg{width:15px;height:15px}
.tick-list b{color:var(--navy)}

/* ---------- Goals quadrant ---------- */
.goal{padding:var(--sp-6); border-radius:var(--r-lg); border:1px solid var(--line); background:#fff; box-shadow:var(--sh-1)}
.goal .ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;margin-bottom:14px;background:var(--sky);color:var(--blue)}
.goal:nth-child(2) .ic{background:#fdeef0;color:#c0405a}
.goal:nth-child(3) .ic{background:#eaf7f0;color:#1f8a59}
.goal:nth-child(4) .ic{background:var(--gold-soft);color:var(--gold-deep)}
.goal h3{font-size:1.2rem}
.goal ul{display:grid; gap:8px; margin-top:10px}
.goal ul li{position:relative; padding-inline-start:20px; color:var(--text-soft); font-size:.97rem}
.goal ul li::before{content:""; position:absolute; inset-inline-start:0; top:.62em; width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* ---------- Quote ---------- */
.quote{
  background:linear-gradient(135deg,var(--sky),#fff); border:1px solid var(--line);
  border-radius:var(--r-xl); padding:var(--sp-8); position:relative; overflow:hidden; box-shadow:var(--sh-1);
}
.quote .mark{font-family:var(--f-display); font-size:6rem; line-height:.6; color:var(--gold); opacity:.35; position:absolute; inset-block-start:18px; inset-inline-start:24px}
.quote blockquote{font-family:var(--f-display); font-size:clamp(1.4rem,3vw,2rem); color:var(--navy); line-height:1.4; margin:0 0 18px; position:relative}
.quote cite{font-style:normal; color:var(--text-soft); font-weight:600}
.quote cite b{color:var(--blue)}

/* ---------- Branches ---------- */
.branch{display:flex; gap:16px; align-items:flex-start; padding:var(--sp-5); border-radius:var(--r-lg); border:1px solid var(--line); background:#fff; box-shadow:var(--sh-1)}
.branch .pin{flex:none; width:48px;height:48px;border-radius:14px; background:var(--sky); color:var(--blue); display:grid; place-items:center}
.branch.soon .pin{background:var(--gold-soft); color:var(--gold-deep)}
.branch h3{font-size:1.15rem; margin-bottom:2px}
.branch p{margin:0; color:var(--text-soft); font-size:.95rem}
.branch .tag{display:inline-block; margin-top:8px; font-size:.78rem; font-weight:700; color:var(--blue); background:var(--sky); padding:3px 10px; border-radius:999px}
.branch.soon .tag{color:var(--gold-deep); background:var(--gold-soft)}

/* ---------- Timeline ---------- */
.timeline{position:relative; margin-top:var(--sp-7)}
.timeline::before{content:""; position:absolute; inset-inline-start:50%; top:0; bottom:0; width:3px; background:linear-gradient(var(--sky),var(--gold-soft),var(--sky)); transform:translateX(50%)}
.tl-item{position:relative; width:50%; padding:0 0 var(--sp-6) 0; padding-inline-end:var(--sp-7)}
.tl-item:nth-child(even){margin-inline-start:50%; padding-inline:var(--sp-7) 0}
.tl-card{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:var(--sp-5); box-shadow:var(--sh-1); position:relative}
.tl-card:hover{box-shadow:var(--sh-2)}
.tl-num{position:absolute; top:18px; inset-inline-start:-66px; width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-600)); color:#fff; display:grid; place-items:center;
  font-family:var(--f-display); font-size:1.15rem; box-shadow:var(--sh-2); border:4px solid #fff; z-index:2}
.tl-item:nth-child(even) .tl-num{inset-inline:-66px auto}
.tl-card .when{font-weight:700; color:var(--gold-deep); font-size:.85rem; letter-spacing:.02em}
.tl-card.now .tl-num{background:linear-gradient(135deg,var(--gold-400),var(--gold)); color:var(--navy-700)}
.tl-card.now{border-color:#f0d79a; box-shadow:var(--sh-gold)}
.tl-card h3{font-size:1.2rem; margin:.15em 0 .3em}
.tl-card p{margin:0; color:var(--text-soft); font-size:.96rem}
.tl-card .milestone{display:inline-flex; gap:6px; align-items:center; margin-top:10px; font-size:.8rem; font-weight:700; color:var(--blue); background:var(--sky); padding:4px 11px; border-radius:999px}
.tl-card .milestone svg{width:14px;height:14px}

/* ---------- Gallery ---------- */
.gallery{columns:3; column-gap:16px}
.gallery .g-item{break-inside:avoid; margin-bottom:16px; border-radius:var(--r); overflow:hidden; box-shadow:var(--sh-1); position:relative; cursor:zoom-in; background:#eef3fc}
.gallery .g-item img{width:100%; display:block; transition:transform .5s var(--ease)}
.gallery .g-item:hover img{transform:scale(1.05)}
.gallery .g-item .cap{position:absolute; inset-inline:0; bottom:0; padding:24px 14px 12px; color:#fff; font-size:.85rem;
  background:linear-gradient(transparent, rgba(11,44,99,.78)); opacity:0; transition:.3s; font-weight:600}
.gallery .g-item:hover .cap, .gallery .g-item:focus-within .cap{opacity:1}

/* video cards */
.vids{display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-5)}
.vid{border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-2); background:#000; position:relative}
.vid video{width:100%; aspect-ratio:16/10; object-fit:cover; display:block; background:#06122b}
.vid .vlabel{position:absolute; top:12px; inset-inline-start:12px; background:rgba(11,44,99,.66); color:#fff; padding:5px 12px; border-radius:999px; font-size:.8rem; font-weight:700; backdrop-filter:blur(4px)}
.embed{position:relative; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-3); aspect-ratio:16/9; background:#000}
.embed iframe{position:absolute; inset:0; width:100%; height:100%; border:0}

/* lightbox */
.lightbox{position:fixed; inset:0; z-index:200; background:rgba(7,18,43,.92); display:none; align-items:center; justify-content:center; padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:94vw; max-height:88vh; border-radius:14px; box-shadow:var(--sh-3)}
.lightbox .lb-close{position:absolute; top:18px; inset-inline-start:18px; width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3); color:#fff; cursor:pointer; font-size:1.4rem}
.lightbox .lb-cap{position:absolute; bottom:22px; inset-inline:0; text-align:center; color:#dfe9ff; font-size:.95rem}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee .track{display:flex; gap:14px; width:max-content; animation:marq 38s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee .m-chip{white-space:nowrap; background:#fff; border:1px solid var(--line); padding:10px 20px; border-radius:999px; font-weight:600; color:var(--navy); box-shadow:var(--sh-1)}
.marquee .m-chip .star{color:var(--gold)}
@keyframes marq{to{transform:translateX(50%)}}

/* ---------- CTA band ---------- */
.cta-band{position:relative; overflow:hidden; border-radius:var(--r-xl);
  background:linear-gradient(135deg,var(--blue),var(--navy)); color:#fff; padding:var(--sp-8); text-align:center}
.cta-band::before{content:""; position:absolute; inset:0; background:radial-gradient(500px 260px at 80% 120%, rgba(217,154,43,.3), transparent 60%)}
.cta-band .container{position:relative}
.cta-band h2{color:#fff; font-size:clamp(1.8rem,4vw,2.8rem)}
.cta-band p{color:#d7e3ff; max-width:56ch; margin-inline:auto}

/* ---------- Forms ---------- */
.form-card{background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); padding:var(--sp-7); box-shadow:var(--sh-2)}
.field{margin-bottom:var(--sp-4)}
.field label{display:block; font-weight:700; color:var(--navy); margin-bottom:6px; font-size:.95rem}
.field .req{color:#c0405a}
.field input,.field textarea,.field select{
  width:100%; padding:13px 15px; border:1.5px solid var(--line); border-radius:14px;
  font:inherit; color:var(--text); background:#fcfdff; transition:border-color .2s, box-shadow .2s; min-height:50px;
}
.field textarea{min-height:120px; resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none; border-color:var(--blue-300); box-shadow:0 0 0 4px rgba(123,166,240,.22)}
.field .hint{font-size:.82rem; color:var(--text-soft); margin-top:5px}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-4)}
.form-note{font-size:.85rem; color:var(--text-soft); margin-top:6px}

/* contact aside */
.contact-list{display:grid; gap:14px}
.contact-item{display:flex; gap:14px; align-items:flex-start; padding:16px; border:1px solid var(--line); border-radius:var(--r); background:#fff; box-shadow:var(--sh-1)}
.contact-item .ic{flex:none; width:46px;height:46px;border-radius:13px; background:var(--sky); color:var(--blue); display:grid; place-items:center}
.contact-item b{display:block; color:var(--navy)}
.contact-item a,.contact-item span{color:var(--text-soft); word-break:break-word}

/* ---------- Page hero (inner) ---------- */
.page-hero{position:relative; overflow:hidden; padding:var(--sp-8) 0 var(--sp-7);
  background:radial-gradient(900px 400px at 90% -20%,var(--gold-soft),transparent 60%),linear-gradient(180deg,var(--sky-2),#fff)}
.page-hero .crumb{font-size:.85rem; color:var(--text-soft); margin-bottom:14px}
.page-hero .crumb a{color:var(--blue)}
.page-hero h1{font-size:clamp(2rem,5vw,3.4rem)}
.page-hero .lead{margin-top:.4em}

/* steps */
.steps{display:grid; gap:var(--sp-5); counter-reset:s}
.steps.c3{grid-template-columns:repeat(3,1fr)}
.step{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:var(--sp-6); box-shadow:var(--sh-1); position:relative}
.step::before{counter-increment:s; content:counter(s); position:absolute; top:-18px; inset-inline-start:24px;
  width:44px;height:44px;border-radius:50%; background:linear-gradient(135deg,var(--gold-400),var(--gold)); color:var(--navy-700);
  font-family:var(--f-display); font-size:1.2rem; display:grid; place-items:center; box-shadow:var(--sh-gold); border:4px solid #fff}
.step h3{margin-top:12px; font-size:1.2rem}
.step p{color:var(--text-soft); margin:0}

/* faq */
.faq{display:grid; gap:12px; max-width:840px; margin-inline:auto}
.faq details{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:4px 20px; box-shadow:var(--sh-1)}
.faq summary{cursor:pointer; padding:16px 0; font-weight:700; color:var(--navy); font-size:1.08rem; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:none; width:26px;height:26px;border-radius:50%; background:var(--sky); color:var(--blue); display:grid; place-items:center; transition:.25s; font-size:1.2rem}
.faq details[open] summary .pm{transform:rotate(45deg); background:var(--gold-soft); color:var(--gold-deep)}
.faq details p{color:var(--text-soft); padding:0 0 18px; margin:0}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy); color:#cdddff; padding:var(--sp-8) 0 var(--sp-5); margin-top:var(--sp-9)}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:var(--sp-7)}
.site-footer .brand{color:#fff}
.site-footer .brand .b-sub{color:var(--gold-400)}
.footer-about{color:#a9c2ef; max-width:42ch; margin-top:14px; font-size:.96rem}
.site-footer h4{color:#fff; font-family:var(--f-body); font-weight:700; font-size:1rem; margin:0 0 14px}
.footer-links{display:grid; gap:9px}
.footer-links a{color:#bcd2f5}
.footer-links a:hover{color:#fff}
.social{display:flex; gap:10px; margin-top:6px}
.social a{width:44px;height:44px;border-radius:12px; background:rgba(255,255,255,.1); display:grid; place-items:center; color:#fff; transition:.2s}
.social a:hover{background:var(--gold); color:var(--navy-700); transform:translateY(-2px)}
.social svg{width:22px;height:22px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:var(--sp-6); padding-top:var(--sp-5); display:flex; flex-wrap:wrap; gap:10px; justify-content:space-between; color:#8fabdd; font-size:.86rem}
.footer-bottom a{color:#bcd2f5}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr; gap:var(--sp-7)}
  .hero-media{max-width:560px; margin-inline:auto}
  .split{grid-template-columns:1fr; gap:var(--sp-6)}
  .split.rev .split-media{order:0}
  .cards.c4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .nav-links,.nav-cta .btn{display:none}
  .hamburger{display:flex}
  .stats-grid{grid-template-columns:repeat(2,1fr); gap:var(--sp-6)}
  .cards.c3{grid-template-columns:1fr}
  .steps.c3{grid-template-columns:1fr}
  .gallery{columns:2}
  .vids{grid-template-columns:1fr}
  .timeline::before{right:22px; left:auto; inset-inline-start:auto; transform:none}
  .tl-item,.tl-item:nth-child(even){width:100%; margin-inline-start:0; padding:0 50px 28px 0}
  .tl-num,.tl-item:nth-child(even) .tl-num{
    width:40px; height:40px; top:16px;
    inset-inline-start:auto; inset-inline-end:auto;
    left:auto !important; right:-48px !important; font-size:1.05rem;
  }
  .timeline{padding-inline-start:0}
}
@media (max-width:560px){
  body{font-size:16px}
  .section{padding:var(--sp-8) 0}
  .hero{padding:var(--sp-7) 0}
  .grid2{grid-template-columns:1fr}
  .cards.c4,.cards.c2{grid-template-columns:1fr}
  .gallery{columns:1}
  .footer-grid{grid-template-columns:1fr}
  .quote{padding:var(--sp-6)}
  .goals{grid-template-columns:1fr}
  .hero-trust .sep{display:none}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important; scroll-behavior:auto !important}
  .reveal{opacity:1 !important; transform:none !important; transition:none !important}
  .ring-decor,.float-dot,.marquee .track{animation:none !important}
}
