/* ===================================================================
   Golden Sand Factory — Black + Gold luxury theme
   Bilingual (LTR / RTL)
   =================================================================== */

:root {
  --black:      #050505;
  --black-2:    #0c0b0a;
  --panel:      #111110;
  --line:       rgba(212,175,55,.16);
  --text:       #ece7df;
  --muted:      #9a948a;

  --gold:       #d4af37;
  --gold-soft:  #f5d27a;
  --gold-deep:  #aa771c;
  --gold-grad:  linear-gradient(135deg,#bf953f 0%,#fcf6ba 28%,#d4af37 55%,#fbf5b7 75%,#aa771c 100%);

  --ff-en:  'Inter', sans-serif;
  --ff-head:'Playfair Display', serif;
  --ff-ar:  'Tajawal','Cairo', sans-serif;

  --maxw: 1180px;
}

* { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior:smooth; }

body {
  background:var(--black);
  color:var(--text);
  font-family:var(--ff-en);
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* Arabic typography when in RTL */
html[dir="rtl"] body,
html[dir="rtl"] .nav-links a,
html[dir="rtl"] .btn,
html[dir="rtl"] input,
html[dir="rtl"] textarea { font-family:var(--ff-ar); }

html[dir="rtl"] .section-title,
html[dir="rtl"] .hero-title { font-family:var(--ff-ar); font-weight:800; }

a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

/* ===== Loader ===== */
#loader{
  position:fixed; inset:0; z-index:9999;
  background:var(--black);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:26px;
  transition:opacity .8s ease, visibility .8s ease;
}
#loader.done{ opacity:0; visibility:hidden; }
.loader-logo{
  font-family:var(--ff-head); letter-spacing:.4em; font-size:1rem;
  background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.loader-bar-wrap{ width:200px; height:2px; background:rgba(255,255,255,.08); overflow:hidden; border-radius:2px; }
.loader-bar{ width:0; height:100%; background:var(--gold-grad); animation:load 1.6s ease forwards; }
@keyframes load{ to{ width:100%; } }

/* ===== Cursor glow ===== */
.cursor-glow{
  position:fixed; top:0; left:0; width:380px; height:380px; pointer-events:none; z-index:1;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(212,175,55,.10) 0%, transparent 60%);
  transition:opacity .3s; opacity:0;
}
@media(hover:hover){ .cursor-glow{ opacity:1; } }

/* ===== Navigation ===== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px clamp(20px,5vw,60px);
  transition:background .4s, padding .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(5,5,5,.78); backdrop-filter:blur(14px);
  padding-top:14px; padding-bottom:14px; border-bottom:1px solid var(--line);
}

.brand{ display:flex; align-items:center; gap:12px; }
.brand-logo{
  width:48px; height:48px; flex:0 0 48px; object-fit:contain;
  filter:drop-shadow(0 4px 12px rgba(212,175,55,.4));
}
.brand-text{ display:flex; flex-direction:column; line-height:1.15; }
.brand-text strong{ font-weight:600; letter-spacing:.04em; font-size:1.02rem; }
.brand-text small{ color:var(--muted); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; }
html[dir="rtl"] .brand-text small{ letter-spacing:0; }

.nav-links{ display:flex; gap:clamp(14px,2.4vw,34px); }
.nav-links a{
  font-size:.86rem; letter-spacing:.04em; color:#cdc6ba;
  position:relative; padding:4px 0; transition:color .3s;
  text-shadow:0 1px 8px rgba(0,0,0,.6);
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px;
  background:var(--gold-grad); transition:width .35s ease;
}
.nav-links a:hover,.nav-links a.active{ color:var(--gold-soft); }
.nav-links a:hover::after,.nav-links a.active::after{ width:100%; }

.nav-actions{ display:flex; align-items:center; gap:14px; }
.lang-btn{
  background:transparent; border:1px solid var(--line); color:var(--gold-soft);
  padding:8px 16px; border-radius:30px; cursor:pointer; font-size:.8rem; letter-spacing:.05em;
  transition:all .3s; font-family:var(--ff-ar);
}
.lang-btn:hover{ background:rgba(212,175,55,.1); border-color:var(--gold); }

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

/* ===== Buttons ===== */
.btn{
  display:inline-block; padding:14px 30px; border-radius:40px; font-size:.88rem;
  letter-spacing:.04em; cursor:pointer; transition:all .35s ease; border:1px solid transparent;
}
.btn-gold{
  background:var(--gold-grad); color:#1a1300; font-weight:600; border:none;
  box-shadow:0 8px 26px rgba(212,175,55,.28);
}
.btn-gold:hover{ transform:translateY(-3px); box-shadow:0 14px 36px rgba(212,175,55,.45); }
.btn-ghost{ border:1px solid var(--line); color:var(--text); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-soft); background:rgba(212,175,55,.06); }

/* ===== HERO ===== */
.hero{ position:relative; min-height:100vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--black); }

/* Floating gold "stars" layer (behind the ore) */
.stars-layer{ position:absolute; inset:0; z-index:0; width:100%; height:100%; pointer-events:none; }

/* Spline 3D scene — smaller, centred box so the starfield shows around it */
.spline-wrap{
  position:absolute; top:3vh; left:50%; transform:translateX(-50%);
  width:min(820px,92vw); height:70vh; z-index:1; overflow:hidden;
}
/* iframe full width (no side crop) but taller, so only the BOTTOM (with the "Built with Spline" badge) is cropped */
.spline-frame{
  position:absolute; top:0; left:0;
  width:100%; height:calc(100% + 110px); border:0; display:block; background:transparent;
}
@media(max-width:820px){ .spline-wrap{ height:50vh; top:7vh; width:94vw; } }
.hero-overlay{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(180deg,
      rgba(5,5,5,.45) 0%,
      rgba(5,5,5,.12) 12%,
      rgba(5,5,5,0)   30%,
      rgba(5,5,5,0)   54%,
      rgba(5,5,5,.5)  74%,
      rgba(5,5,5,.92) 88%,
      var(--black)    100%);
}
.hero-content{
  position:relative; z-index:3;
  max-width:var(--maxw); width:100%; margin:0 auto;
  padding:0 clamp(20px,5vw,60px) clamp(70px,9vh,110px);
}
.eyebrow{
  display:inline-block; font-size:.78rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--gold-soft); margin-bottom:22px; padding-left:2px;
  text-shadow:0 1px 12px rgba(0,0,0,.8);
}
html[dir="rtl"] .eyebrow{ letter-spacing:.05em; }
.hero-title{
  font-family:var(--ff-head); font-weight:600; line-height:1.08;
  font-size:clamp(1.8rem,3.6vw,2.9rem); margin-bottom:16px;
  text-shadow:0 2px 30px rgba(0,0,0,.9);
}
.hero-title .line{ display:block; }
.gold-text{
  background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-sub{ max-width:540px; color:#d8d2c6; font-size:clamp(.95rem,1.4vw,1.05rem); margin-bottom:30px; text-shadow:0 2px 16px rgba(0,0,0,.9); }
.hero-cta{ display:flex; gap:16px; flex-wrap:wrap; }

.scroll-hint{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2; display:none;
  color:var(--muted); font-size:.72rem; letter-spacing:.22em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.scroll-hint span{
  width:1px; height:42px; background:linear-gradient(var(--gold),transparent);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{ 0%{transform:scaleY(0);transform-origin:top;} 50%{transform:scaleY(1);transform-origin:top;} 50.1%{transform-origin:bottom;} 100%{transform:scaleY(0);transform-origin:bottom;} }

/* ===== Live price ticker ===== */
.price-bar{
  background:linear-gradient(90deg,#0d0c0a,#15130d,#0d0c0a);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.price-inner{
  max-width:var(--maxw); margin:0 auto; padding:12px clamp(20px,5vw,60px);
  display:flex; align-items:center; gap:clamp(16px,3vw,40px); flex-wrap:wrap; justify-content:center;
}
.price-live{ display:inline-flex; align-items:center; gap:8px; color:var(--gold); font-size:.72rem; letter-spacing:.18em; }
html[dir="rtl"] .price-live{ letter-spacing:.02em; }
.price-live .dot{ width:8px; height:8px; border-radius:50%; background:#3ad06a; box-shadow:0 0 0 0 rgba(58,208,106,.6); animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(58,208,106,.5);} 70%{box-shadow:0 0 0 8px rgba(58,208,106,0);} 100%{box-shadow:0 0 0 0 rgba(58,208,106,0);} }

.price-item{ display:inline-flex; align-items:center; gap:7px; font-size:.92rem; }
.price-metal{ color:var(--gold-soft); font-weight:600; }
.price-val{ color:var(--text); font-variant-numeric:tabular-nums; min-width:1.5ch; transition:color .4s; }
.price-val.flash{ color:#fff; }
.price-unit{ color:var(--muted); font-size:.78rem; }
.price-sep{ color:var(--gold-deep); }
.price-updated{ color:var(--muted); font-size:.74rem; }

@media(max-width:620px){
  .price-updated{ display:none; }
  .price-inner{ gap:14px; }
}

/* ===== Marquee ===== */
.marquee{ overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--black-2); padding:18px 0; }
.marquee-track{ display:flex; align-items:center; gap:34px; white-space:nowrap; width:max-content; animation:marquee 26s linear infinite; }
.marquee-track span{ font-family:var(--ff-head); letter-spacing:.16em; font-size:1.1rem; color:var(--gold-soft); }
.marquee-track i{ color:var(--gold-deep); font-style:normal; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
html[dir="rtl"] .marquee-track{ animation-direction:reverse; }

/* ===== Sections ===== */
.section{ max-width:var(--maxw); margin:0 auto; padding:clamp(70px,11vw,140px) clamp(20px,5vw,60px); }
.section-head{ margin-bottom:60px; max-width:680px; }
.kicker{ display:block; color:var(--gold); font-size:.8rem; letter-spacing:.22em; text-transform:uppercase; margin-bottom:16px; }
html[dir="rtl"] .kicker{ letter-spacing:.05em; }
.section-title{ font-family:var(--ff-head); font-weight:600; font-size:clamp(1.9rem,4.4vw,3.1rem); line-height:1.15; }

/* About */
.about-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:50px; align-items:start; }
.about-text p{ color:var(--muted); margin-bottom:22px; font-size:1.04rem; }
.about-cards{ display:flex; flex-direction:column; gap:22px; }
.vm-card{
  background:linear-gradient(160deg, rgba(212,175,55,.06), rgba(255,255,255,.01));
  border:1px solid var(--line); border-radius:18px; padding:30px;
  transition:transform .4s, border-color .4s;
}
.vm-card:hover{ transform:translateY(-5px); border-color:rgba(212,175,55,.4); }
.vm-icon{ font-size:1.5rem; color:var(--gold); margin-bottom:14px; }
.vm-card h3{ font-family:var(--ff-head); font-weight:600; margin-bottom:10px; font-size:1.25rem; }
.vm-card p{ color:var(--muted); font-size:.95rem; }

/* Capabilities */
.cap-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.cap-card{
  position:relative; background:var(--panel); border:1px solid var(--line); border-radius:18px;
  padding:38px 30px 32px; overflow:hidden; transition:transform .4s, border-color .4s, background .4s;
}
.cap-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--gold-grad); transform:scaleX(0); transform-origin:left; transition:transform .45s;
}
.cap-card:hover{ transform:translateY(-7px); border-color:rgba(212,175,55,.35); background:#15140f; }
.cap-card:hover::before{ transform:scaleX(1); }
.cap-num{ font-family:var(--ff-head); font-size:2rem; color:var(--gold-deep); opacity:.55; margin-bottom:16px; }
.cap-card h3{ font-family:var(--ff-head); font-weight:600; font-size:1.3rem; margin-bottom:10px; }
.cap-card p{ color:var(--muted); font-size:.93rem; }

/* Process timeline */
.timeline{ position:relative; padding-inline-start:34px; }
.timeline::before{ content:""; position:absolute; inset-inline-start:7px; top:6px; bottom:6px; width:2px; background:linear-gradient(var(--gold),transparent); }
.t-step{ position:relative; padding-bottom:42px; }
.t-step:last-child{ padding-bottom:0; }
.t-dot{
  position:absolute; inset-inline-start:-34px; top:0; width:34px; height:34px; border-radius:50%;
  display:grid; place-items:center; font-size:.74rem; font-weight:600; color:#1a1300;
  background:var(--gold-grad); transform:translateX(calc(-50% + 8px)); box-shadow:0 0 0 5px var(--black);
}
html[dir="rtl"] .t-dot{ transform:translateX(calc(50% - 8px)); }
.t-body h3{ font-family:var(--ff-head); font-weight:600; font-size:1.3rem; margin-bottom:8px; }
.t-body p{ color:var(--muted); font-size:.96rem; max-width:560px; }

/* Gallery */
.gallery-video{ margin:0 auto 30px; max-width:400px; border-radius:18px; overflow:hidden; border:1px solid var(--line); box-shadow:0 20px 60px rgba(0,0,0,.5); }
.gallery-video video{ display:block; width:100%; height:auto; background:#0b0a09; }
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.g-item{
  position:relative; margin:0; border-radius:16px; overflow:hidden; cursor:pointer;
  border:1px solid var(--line); aspect-ratio:4/3; background:#0b0a09;
}
.g-item img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; display:block; }
.g-item:hover img{ transform:scale(1.08); }
.g-item figcaption{
  position:absolute; inset-inline:0; bottom:0; padding:30px 18px 14px;
  color:var(--text); font-size:.92rem; font-weight:500;
  background:linear-gradient(transparent, rgba(5,5,5,.85));
  transform:translateY(6px); opacity:.9; transition:all .35s;
}
.g-item:hover figcaption{ transform:translateY(0); opacity:1; color:var(--gold-soft); }

/* Lightbox */
.lightbox{
  position:fixed; inset:0; z-index:1200; display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:16px; padding:30px;
  background:rgba(3,3,3,.92); backdrop-filter:blur(6px);
  opacity:0; visibility:hidden; transition:opacity .3s, visibility .3s;
}
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:min(90vw,1000px); max-height:80vh; border-radius:12px; border:1px solid var(--line); box-shadow:0 20px 60px rgba(0,0,0,.6); }
.lightbox-caption{ color:var(--gold-soft); font-size:1rem; letter-spacing:.04em; }
.lightbox-close{
  position:absolute; top:22px; right:28px; background:none; border:none; color:var(--text);
  font-size:2.4rem; line-height:1; cursor:pointer; transition:color .3s;
}
html[dir="rtl"] .lightbox-close{ right:auto; left:28px; }
.lightbox-close:hover{ color:var(--gold); }

@media(max-width:760px){ .gallery-grid{ grid-template-columns:repeat(2,1fr); gap:12px; } }

/* Stats */
.stats{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:center; }
.stat-num{ font-family:var(--ff-head); font-weight:700; font-size:clamp(2.4rem,5vw,3.6rem); background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; }
.stat-label{ color:var(--muted); font-size:.86rem; letter-spacing:.06em; margin-top:12px; }

/* Why */
.why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.why-card{ background:var(--panel); border:1px solid var(--line); border-radius:18px; padding:40px 32px; transition:transform .4s, border-color .4s; }
.why-card:hover{ transform:translateY(-6px); border-color:rgba(212,175,55,.35); }
.why-card h3{ font-family:var(--ff-head); font-weight:600; font-size:1.5rem; margin-bottom:14px; }
.why-card h3::before{ content:""; display:block; width:40px; height:3px; background:var(--gold-grad); border-radius:3px; margin-bottom:18px; }
.why-card p{ color:var(--muted); font-size:1rem; line-height:1.7; }

/* Contact */
.contact-grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:50px; align-items:start; }
.contact-info{ display:flex; flex-direction:column; gap:26px; }
.ci-item{ display:flex; flex-direction:column; gap:5px; border-inline-start:2px solid var(--line); padding-inline-start:18px; }
.ci-label{ color:var(--gold); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; }
.ci-val{ color:var(--text); font-size:1.02rem; transition:color .3s; }
a.ci-val:hover{ color:var(--gold-soft); }

.contact-form{ display:flex; flex-direction:column; gap:26px; }
.field{ position:relative; }
.field input,.field textarea{
  width:100%; background:var(--panel); border:1px solid var(--line); border-radius:12px;
  padding:18px 18px 8px; color:var(--text); font-size:1rem; resize:vertical; transition:border-color .3s;
}
.field textarea{ padding-top:22px; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--gold); }
.field label{
  position:absolute; inset-inline-start:18px; top:16px; color:var(--muted); font-size:1rem;
  pointer-events:none; transition:all .25s ease; background:transparent;
}
.field input:focus + label,.field input:valid + label,
.field textarea:focus + label,.field textarea:valid + label{
  top:6px; font-size:.7rem; color:var(--gold-soft); letter-spacing:.04em;
}
.form-note{ font-size:.9rem; color:var(--gold-soft); min-height:1.2em; }

/* Footer */
.footer{ border-top:1px solid var(--line); background:var(--black-2); padding:60px clamp(20px,5vw,60px) 30px; }
.footer-cols{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:34px; border-bottom:1px solid var(--line); }
.footer-tag{ color:var(--muted); max-width:340px; margin-top:16px; }
.footer-h{ font-family:var(--ff-head); font-weight:600; font-size:1.05rem; color:var(--gold-soft); margin-bottom:16px; letter-spacing:.02em; }
.footer-line{ color:var(--muted); font-size:.9rem; margin-bottom:10px; line-height:1.6; }
.footer-line a{ color:var(--muted); transition:color .3s; }
.footer-line a:hover{ color:var(--gold-soft); }
.footer-map{ display:inline-flex; align-items:center; gap:8px; margin-top:8px; color:var(--gold-soft); font-size:.9rem; border:1px solid var(--line); padding:9px 16px; border-radius:30px; transition:all .3s; }
.footer-map:hover{ background:rgba(212,175,55,.08); border-color:var(--gold); }
/* align-items:flex-start is direction-aware: left in LTR, right in RTL — so label + number stack on the same side */
.footer-reg{ display:flex; flex-direction:column; align-items:flex-start; gap:2px; margin-bottom:14px; }
.footer-reg .reg-label{ color:var(--muted); font-size:.82rem; }
.footer-reg .reg-num{ color:var(--gold-soft); font-size:1rem; font-variant-numeric:tabular-nums; letter-spacing:.02em; }
.footer-bottom{ max-width:var(--maxw); margin:24px auto 0; color:var(--muted); font-size:.82rem; text-align:center; }
@media(max-width:760px){ .footer-cols{ grid-template-columns:1fr; gap:30px; } }

/* ===== Floating WhatsApp button ===== */
.wa-float{
  position:fixed; bottom:24px; right:24px; z-index:900;
  width:58px; height:58px; border-radius:50%;
  background:#25d366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.45);
  transition:transform .3s, box-shadow .3s;
  animation:waPulse 2.4s infinite;
}
html[dir="rtl"] .wa-float{ right:auto; left:24px; }
.wa-float:hover{ transform:scale(1.08); box-shadow:0 12px 30px rgba(37,211,102,.6); }
.wa-label{
  position:absolute; right:70px; white-space:nowrap;
  background:rgba(10,10,10,.92); color:var(--text); border:1px solid var(--line);
  padding:8px 14px; border-radius:30px; font-size:.82rem;
  opacity:0; transform:translateX(10px); pointer-events:none; transition:all .3s;
}
html[dir="rtl"] .wa-label{ right:auto; left:70px; transform:translateX(-10px); }
.wa-float:hover .wa-label{ opacity:1; transform:translateX(0); }
@keyframes waPulse{ 0%{box-shadow:0 8px 24px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.5);} 70%{box-shadow:0 8px 24px rgba(37,211,102,.45),0 0 0 14px rgba(37,211,102,0);} 100%{box-shadow:0 8px 24px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,0);} }
@media(max-width:560px){ .wa-float{ width:52px; height:52px; bottom:18px; right:18px; } html[dir="rtl"] .wa-float{ left:18px; right:auto; } }

/* ===== Reveal animation ===== */
.reveal{ opacity:0; transform:translateY(32px); transition:opacity .8s ease, transform .8s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ===== Responsive ===== */
@media(max-width:900px){
  .menu-toggle{ display:flex; }
  .nav-links{
    position:fixed; top:0; inset-inline-end:0; height:100vh; width:min(78vw,320px);
    flex-direction:column; justify-content:center; gap:30px; padding:40px;
    background:rgba(8,8,7,.97); backdrop-filter:blur(16px);
    transform:translateX(100%); transition:transform .4s ease; border-inline-start:1px solid var(--line);
  }
  html[dir="rtl"] .nav-links{ transform:translateX(-100%); }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ font-size:1.1rem; }
  .menu-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .menu-toggle.open span:nth-child(2){ opacity:0; }
  .menu-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

  .about-grid,.contact-grid{ grid-template-columns:1fr; }
  .cap-grid,.why-grid{ grid-template-columns:repeat(2,1fr); }
  .stats-grid{ grid-template-columns:repeat(2,1fr); gap:40px 20px; }
}
@media(max-width:560px){
  .cap-grid,.why-grid{ grid-template-columns:1fr; }
  .brand-text small{ display:none; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .btn{ text-align:center; }
}
