/* =========================================================
   אלום המזרח — Alum HaMezrah
   Theme: Black · White · Olive Green
   ========================================================= */

:root{
  /* Core palette */
  --black:        #16170f;   /* near-black, warm */
  --black-soft:   #21241a;
  --ink:          #2b2e22;

  --white:        #ffffff;
  --cream:        #f7f7f1;   /* off-white page bg */
  --cream-2:      #eef0e6;   /* light olive tint */
  --line:         #e2e3d6;

  --olive:        #5a6a35;   /* primary olive */
  --olive-2:      #45531f;   /* darker olive */
  --olive-deep:   #353f1b;   /* deepest olive (sections) */
  --olive-tint:   #e9ecdd;
  --olive-bright: #7c8f4a;   /* hover / accents */

  --muted:        #6c6f5e;
  --muted-light:  #b7bbac;

  /* System */
  --maxw: 1180px;
  --radius: 14px;
  --radius-sm: 10px;
  --shadow-sm: 0 4px 16px rgba(22,23,15,.08);
  --shadow:    0 14px 40px rgba(22,23,15,.14);
  --shadow-lg: 0 30px 70px rgba(22,23,15,.22);
  --t: .3s cubic-bezier(.4,0,.2,1);

  --ff: 'Heebo', system-ui, 'Segoe UI', sans-serif;
  --ff-display: 'Rubik', 'Heebo', system-ui, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--ff);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-weight:400;
  overflow-x:hidden;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3{ font-family:var(--ff-display); line-height:1.15; margin:0; font-weight:700; color:var(--black); letter-spacing:-.01em; }
p{ margin:0; }
.en{ font-family:var(--ff-display); letter-spacing:.08em; font-weight:500; opacity:.7; }

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

.section{ padding:92px 0; }
@media(max-width:760px){ .section{ padding:64px 0; } }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:14px 26px; border-radius:999px; font-weight:700; font-size:1.02rem;
  border:2px solid transparent; transition:var(--t); white-space:nowrap;
  font-family:var(--ff); line-height:1;
}
.btn .ico{ width:20px; height:20px; }
.btn-sm{ padding:9px 16px; font-size:.95rem; }
.btn-block{ width:100%; }

.btn-primary{ background:var(--olive); color:#fff; border-color:var(--olive); }
.btn-primary:hover{ background:var(--olive-2); border-color:var(--olive-2); transform:translateY(-2px); box-shadow:var(--shadow); }

.btn-ghost{ background:transparent; color:var(--black); border-color:transparent; }
.btn-ghost:hover{ color:var(--olive); }

.btn-light{ background:#fff; color:var(--black); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }

.btn-outline-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.6); }
.btn-outline-light:hover{ background:#fff; color:var(--black); border-color:#fff; }

.btn-outline-olive{ background:transparent; color:var(--olive-2); border-color:var(--olive); }
.btn-outline-olive:hover{ background:var(--olive); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow); }

/* ---------- Header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  background:rgba(247,247,241,.0); transition:var(--t);
  padding:18px 0;
}
.site-header.scrolled{
  background:rgba(247,247,241,.94);
  backdrop-filter:saturate(160%) blur(10px);
  box-shadow:var(--shadow-sm); padding:10px 0;
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:20px; }

.logo{ display:flex; align-items:center; gap:11px; color:var(--white); transition:var(--t); }
.site-header.scrolled .logo{ color:var(--black); }
.logo-mark{ width:40px; height:40px; color:#fff; flex:none; }
.site-header.scrolled .logo-mark{ color:var(--black); }
.logo-mark svg{ width:100%; height:100%; }
.logo-text{ display:flex; flex-direction:column; line-height:1; }
.logo-he{ font-family:var(--ff-display); font-weight:800; font-size:1.32rem; letter-spacing:-.01em; }
.logo-en{ font-family:var(--ff-display); font-size:.6rem; letter-spacing:.28em; opacity:.65; margin-top:3px; }

.nav{ display:flex; gap:30px; margin-inline-start:auto; }
.nav a{
  color:rgba(255,255,255,.92); font-weight:500; font-size:1.02rem; position:relative; padding:4px 0;
}
.site-header.scrolled .nav a{ color:var(--ink); }
.nav a::after{
  content:""; position:absolute; bottom:-2px; right:0; left:0; height:2px;
  background:var(--olive-bright); transform:scaleX(0); transition:var(--t);
}
.nav a:hover::after{ transform:scaleX(1); }
.nav a:hover{ color:var(--olive-bright); }
.site-header.scrolled .nav a:hover{ color:var(--olive); }

.header-cta{ display:flex; align-items:center; gap:8px; }
.header-cta .btn-ghost{ color:#fff; }
.site-header.scrolled .header-cta .btn-ghost{ color:var(--black); }
.header-cta .btn-ghost:hover{ color:var(--olive-bright); }

/* hamburger */
.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px; }
.nav-toggle span{ width:26px; height:2.5px; background:#fff; border-radius:2px; transition:var(--t); }
.site-header.scrolled .nav-toggle span{ background:var(--black); }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:-1; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; }
.hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(22,23,15,.55) 0%, rgba(22,23,15,.35) 40%, rgba(22,23,15,.78) 100%),
    linear-gradient(280deg, rgba(53,63,27,.55), rgba(22,23,15,.2));
}
.hero-content{ padding-top:120px; padding-bottom:60px; max-width:760px; }
.hero-kicker{ font-weight:600; letter-spacing:.04em; color:var(--olive-bright); margin-bottom:18px; font-size:1.02rem; }
.hero-kicker .en{ color:rgba(255,255,255,.6); margin-inline-start:6px; }
.hero-title{ color:#fff; font-size:clamp(2.3rem,6vw,4.3rem); font-weight:800; margin-bottom:22px; text-shadow:0 2px 30px rgba(0,0,0,.3); }
.hero-title .accent{ color:var(--olive-bright); }
.hero-sub{ font-size:clamp(1.05rem,2.2vw,1.28rem); color:rgba(255,255,255,.92); max-width:640px; margin-bottom:34px; font-weight:300; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:42px; }
.hero-badges{ display:flex; flex-wrap:wrap; gap:34px; list-style:none; padding:0; margin:0; border-top:1px solid rgba(255,255,255,.22); padding-top:26px; }
.hero-badges li{ font-size:1rem; color:rgba(255,255,255,.85); font-weight:300; }
.hero-badges strong{ display:block; font-family:var(--ff-display); font-size:2rem; font-weight:800; color:#fff; line-height:1; margin-bottom:4px; }

/* ---------- Stats ---------- */
.stats{ background:var(--black); color:#fff; }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; padding:46px 22px; }
.stat{ text-align:center; border-inline-start:1px solid rgba(255,255,255,.12); }
.stat:first-child{ border:0; }
.stat-num{ display:block; font-family:var(--ff-display); font-size:clamp(1.8rem,4vw,2.9rem); font-weight:800; color:var(--olive-bright); line-height:1; }
.stat-label{ display:block; margin-top:8px; color:rgba(255,255,255,.7); font-weight:300; font-size:1rem; }
@media(max-width:680px){
  .stats-grid{ grid-template-columns:repeat(2,1fr); gap:30px 10px; }
  .stat:nth-child(odd){ border:0; }
}

/* ---------- Section heads ---------- */
.section-head{ max-width:720px; margin-bottom:54px; }
.section-head.light *{ color:#fff; }
.eyebrow{ font-weight:700; color:var(--olive); letter-spacing:.03em; margin-bottom:14px; font-size:1rem; }
.eyebrow .en{ color:var(--muted); margin-inline-start:6px; }
.section-head h2{ font-size:clamp(1.8rem,4vw,2.7rem); margin-bottom:16px; }
.section-lead{ color:var(--muted); font-size:1.12rem; font-weight:300; }
.section-head.light .section-lead{ color:rgba(255,255,255,.8); }

/* ---------- Services ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 30px; transition:var(--t); position:relative; overflow:hidden;
}
.card::before{
  content:""; position:absolute; inset:auto 0 0 0; height:4px; background:var(--olive);
  transform:scaleX(0); transform-origin:right; transition:var(--t);
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.card:hover::before{ transform:scaleX(1); }
.card-ico{
  display:inline-flex; width:64px; height:64px; align-items:center; justify-content:center;
  border-radius:14px; background:var(--olive-tint); color:var(--olive-2); margin-bottom:20px; transition:var(--t);
}
.card-ico svg{ width:34px; height:34px; }
.card:hover .card-ico{ background:var(--olive); color:#fff; }
.card h3{ font-size:1.4rem; margin-bottom:10px; }
.card p{ color:var(--muted); font-weight:300; }
@media(max-width:920px){ .cards{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){ .cards{ grid-template-columns:1fr; } }

/* ---------- Projects gallery ---------- */
.projects{ background:var(--cream-2); }
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:16px; }
.gal-item{
  position:relative; margin:0; border-radius:var(--radius); overflow:hidden; cursor:pointer;
  background:var(--black); box-shadow:var(--shadow-sm);
}
.gal-item img,.gal-item video{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.6,.2,1); }
.gal-item:hover img,.gal-item:hover video{ transform:scale(1.08); }
.gal-tall{ grid-row:span 2; }
.gal-wide{ grid-column:span 2; }
.gal-item figcaption{
  position:absolute; inset:auto 0 0 0; padding:30px 18px 16px; color:#fff; font-weight:500; font-size:1rem;
  background:linear-gradient(180deg,transparent,rgba(22,23,15,.85)); transform:translateY(8px); opacity:0; transition:var(--t);
}
.gal-item:hover figcaption{ transform:translateY(0); opacity:1; }
.play-badge{
  position:absolute; inset:0; margin:auto; width:68px; height:68px; border-radius:50%;
  background:rgba(90,106,53,.92); display:flex; align-items:center; justify-content:center; color:#fff;
  pointer-events:none; box-shadow:var(--shadow);
}
.play-badge svg{ width:30px; height:30px; margin-inline-start:3px; }
@media(max-width:860px){
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:170px; }
  .gal-wide{ grid-column:span 2; }
  .gal-tall{ grid-row:span 1; }
}
@media(max-width:520px){
  .gallery{ grid-template-columns:1fr; grid-auto-rows:230px; }
  .gal-wide,.gal-tall{ grid-column:span 1; grid-row:span 1; }
}

/* ---------- About ---------- */
.about-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:60px; align-items:center; }
.about-media{ position:relative; }
.about-media img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow); aspect-ratio:4/5; object-fit:cover; }
.about-badge{
  position:absolute; bottom:-26px; inset-inline-start:-26px; background:var(--olive); color:#fff;
  border-radius:var(--radius); padding:22px 26px; display:flex; align-items:center; gap:12px; box-shadow:var(--shadow);
}
.about-badge .big{ font-family:var(--ff-display); font-size:3rem; font-weight:800; line-height:1; }
.about-badge .small{ font-size:.95rem; line-height:1.2; font-weight:500; }
.about-text h2{ font-size:clamp(1.8rem,4vw,2.6rem); margin-bottom:18px; }
.about-text p{ color:var(--muted); margin-bottom:16px; font-size:1.08rem; font-weight:300; }
.about-text strong{ color:var(--ink); font-weight:700; }
.check-list{ list-style:none; padding:0; margin:6px 0 28px; }
.check-list li{ position:relative; padding-inline-start:32px; margin-bottom:12px; color:var(--ink); font-weight:400; }
.check-list li::before{
  content:""; position:absolute; inset-inline-start:0; top:6px; width:18px; height:18px; border-radius:50%;
  background:var(--olive); background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M5 12l5 5 9-10' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size:13px; background-repeat:no-repeat; background-position:center;
}
@media(max-width:860px){
  .about-grid{ grid-template-columns:1fr; gap:50px; }
  .about-badge{ inset-inline-start:auto; inset-inline-end:18px; bottom:-22px; }
}

/* ---------- Why us ---------- */
.why{ background:var(--olive-deep); color:#fff; }
.why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.why-item{ padding:30px 26px; border-radius:var(--radius); background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); transition:var(--t); }
.why-item:hover{ background:rgba(255,255,255,.09); transform:translateY(-5px); }
.why-num{ font-family:var(--ff-display); font-size:2.4rem; font-weight:800; color:var(--olive-bright); display:block; margin-bottom:12px; }
.why-item h3{ color:#fff; font-size:1.3rem; margin-bottom:10px; }
.why-item p{ color:rgba(255,255,255,.75); font-weight:300; }
@media(max-width:860px){ .why-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px){ .why-grid{ grid-template-columns:1fr; } }

/* ---------- CTA strip ---------- */
.cta-strip{ background:var(--olive); color:#fff; }
.cta-inner{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding:46px 22px; flex-wrap:wrap; }
.cta-inner h2{ color:#fff; font-size:clamp(1.5rem,3vw,2.1rem); margin-bottom:6px; }
.cta-inner p{ color:rgba(255,255,255,.85); font-weight:300; }
.cta-actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:start; }
.contact-info h2{ font-size:clamp(1.8rem,4vw,2.5rem); margin-bottom:14px; }
.contact-list{ list-style:none; padding:0; margin:28px 0; }
.contact-list li{ display:flex; align-items:center; gap:16px; padding:14px 0; border-bottom:1px solid var(--line); }
.ci-ico{ flex:none; width:46px; height:46px; border-radius:12px; background:var(--olive-tint); color:var(--olive-2); display:flex; align-items:center; justify-content:center; }
.ci-ico svg{ width:22px; height:22px; }
.ci-label{ display:block; font-size:.85rem; color:var(--muted); margin-bottom:1px; }
.contact-list a,.contact-list div span:last-child{ font-weight:600; color:var(--ink); font-size:1.08rem; transition:var(--t); }
.contact-list a:hover{ color:var(--olive); }
.location-card{ border-radius:var(--radius); border:1px solid var(--line); background:#fff; padding:22px 24px; box-shadow:var(--shadow-sm); }
.loc-head{ display:flex; align-items:center; gap:14px; }
.loc-head strong{ display:block; color:var(--ink); font-size:1.05rem; line-height:1.4; }
.loc-text{ color:var(--muted); margin:16px 0 12px; font-weight:300; }
.loc-actions{ display:flex; gap:10px; flex-wrap:wrap; }

.contact-form-wrap{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:36px 32px; box-shadow:var(--shadow); }
.contact-form h3{ font-size:1.55rem; margin-bottom:22px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:600; margin-bottom:7px; font-size:.98rem; color:var(--ink); }
.field input,.field select,.field textarea{
  width:100%; padding:13px 15px; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  font-family:inherit; font-size:1rem; color:var(--ink); background:var(--cream); transition:var(--t); resize:vertical;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--olive); background:#fff; box-shadow:0 0 0 3px rgba(90,106,53,.14); }
.field input.invalid,.field textarea.invalid{ border-color:#c0492f; background:#fdf3f1; }
.form-note{ font-size:.86rem; color:var(--muted); margin-top:12px; text-align:center; font-weight:300; }
.form-success{ margin-top:14px; text-align:center; font-weight:600; color:var(--olive-2); background:var(--olive-tint); border:1px solid var(--olive); border-radius:var(--radius-sm); padding:12px; }
.or-divider{ display:flex; align-items:center; gap:12px; color:var(--muted); font-size:.9rem; margin:14px 0; }
.or-divider::before,.or-divider::after{ content:""; height:1px; background:var(--line); flex:1; }
@media(max-width:860px){ .contact-grid{ grid-template-columns:1fr; gap:40px; } }

/* ---------- Social icons ---------- */
.socials{ display:flex; gap:12px; margin-top:24px; }
.socials a{ width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--olive-tint); color:var(--olive-2); transition:var(--t); }
.socials a:hover{ background:var(--olive); color:#fff; transform:translateY(-3px); }
.socials svg{ width:22px; height:22px; }
.footer-socials{ margin-top:18px; }
.footer-socials a{ background:rgba(255,255,255,.08); color:#fff; }
.footer-socials a:hover{ background:var(--olive-bright); }

/* ---------- Footer logo lockup ---------- */
.footer-logo{ display:flex; align-items:center; gap:11px; margin-bottom:14px; }
.footer-logo svg{ width:42px; height:42px; flex:none; }
.footer-logo .logo-text{ color:#fff; }
.footer-brand .logo-he{ font-family:var(--ff-display); font-weight:800; font-size:1.3rem; }
.footer-brand .logo-en{ font-family:var(--ff-display); font-size:.6rem; letter-spacing:.28em; color:var(--olive-bright); margin-top:3px; }

/* ---------- Testimonials ---------- */
.testimonials{ background:var(--cream); }
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.review{ margin:0; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px; box-shadow:var(--shadow-sm); transition:var(--t); display:flex; flex-direction:column; }
.review:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.stars{ color:#d8a534; font-size:1.15rem; letter-spacing:2px; margin-bottom:14px; }
.review blockquote{ margin:0 0 18px; color:var(--ink); font-size:1.06rem; line-height:1.75; font-weight:300; flex:1; }
.review figcaption{ display:flex; flex-direction:column; gap:2px; border-top:1px solid var(--line); padding-top:14px; }
.rv-name{ font-weight:700; color:var(--black); }
.rv-loc{ font-size:.9rem; color:var(--muted); }
@media(max-width:860px){ .reviews-grid{ grid-template-columns:1fr; } }

/* ---------- Footer ---------- */
.site-footer{ background:var(--black); color:rgba(255,255,255,.75); }
.footer-inner{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:36px; padding:60px 22px 40px; }
.footer-brand .logo-text{ color:#fff; margin-bottom:14px; }
.footer-brand .logo-en{ color:var(--olive-bright); }
.footer-brand p{ font-weight:300; max-width:360px; }
.footer-nav{ display:flex; flex-direction:column; gap:11px; }
.footer-nav a:hover,.footer-contact a:hover{ color:var(--olive-bright); }
.footer-contact{ display:flex; flex-direction:column; gap:11px; }
.footer-contact a,.footer-contact span{ color:rgba(255,255,255,.78); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); padding:18px 0; font-size:.9rem; color:rgba(255,255,255,.5); text-align:center; }
@media(max-width:740px){ .footer-inner{ grid-template-columns:1fr; gap:26px; } }

/* ---------- Floating WhatsApp ---------- */
.wa-float{
  position:fixed; bottom:22px; inset-inline-start:22px; z-index:90; width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,.45); transition:var(--t); animation:waPulse 2.6s infinite;
}
.wa-float svg{ width:32px; height:32px; }
.wa-float:hover{ transform:scale(1.08); }
@keyframes waPulse{ 0%{ box-shadow:0 10px 30px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.5);} 70%{ box-shadow:0 10px 30px rgba(37,211,102,.45),0 0 0 16px rgba(37,211,102,0);} 100%{ box-shadow:0 10px 30px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,0);} }

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(16,17,11,.94); display:none;
  align-items:center; justify-content:center; padding:40px; opacity:0; transition:opacity .25s;
}
.lightbox.open{ display:flex; opacity:1; }
.lb-stage{ max-width:92vw; max-height:82vh; display:flex; align-items:center; justify-content:center; }
.lb-stage img,.lb-stage video{ max-width:92vw; max-height:82vh; border-radius:8px; box-shadow:var(--shadow-lg); }
.lb-caption{ position:absolute; bottom:24px; inset-inline:0; text-align:center; color:rgba(255,255,255,.9); font-size:1.05rem; }
.lb-close{ position:absolute; top:18px; inset-inline-end:24px; background:none; border:0; color:#fff; font-size:2.6rem; line-height:1; opacity:.8; transition:var(--t); }
.lb-close:hover{ opacity:1; transform:rotate(90deg); }
.lb-nav{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.12); border:0; color:#fff; width:52px; height:52px; border-radius:50%; font-size:2rem; line-height:1; transition:var(--t); }
.lb-nav:hover{ background:var(--olive); }
.lb-prev{ inset-inline-start:18px; }
.lb-next{ inset-inline-end:18px; }
@media(max-width:600px){ .lb-nav{ width:42px; height:42px; font-size:1.5rem; } }

/* ---------- Mobile nav ---------- */
@media(max-width:900px){
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px); background:var(--black); flex-direction:column;
    padding:90px 30px 30px; gap:6px; transform:translateX(100%); transition:transform .35s cubic-bezier(.4,0,.2,1);
    box-shadow:var(--shadow-lg); margin:0;
  }
  .nav.open{ transform:translateX(0); }
  .nav a{ color:#fff !important; font-size:1.2rem; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.1); }
  .nav a::after{ display:none; }
  .nav-toggle{ display:flex; z-index:101; }
  .header-cta .btn-ghost span{ display:none; }
  .header-cta .btn-ghost{ padding:9px; }
  body.nav-open{ overflow:hidden; }
  .nav-toggle.active span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); background:#fff; }
  .nav-toggle.active span:nth-child(2){ opacity:0; }
  .nav-toggle.active span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); background:#fff; }
}

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.6,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
  .wa-float{ animation:none; }
}
