/* =========================================================
   السياحة الذكية | Tourism Intelligence — design system
   Brand-led by the Arab Tourism Organization (green/gold),
   bridged with Transformix navy/teal. RTL, mobile-first.
   ========================================================= */

:root{
  /* Heritage (primary — Arab Tourism Organization) */
  --green:        #1F6432;
  --green-deep:   #143F20;
  --green-saudi:  #006C35;
  --green-fe:     #2EB675;
  --gold:         #ECC45C;
  --gold-deep:    #D8B843;
  --sand:         #F3EEDF;
  --sand-2:       #F7F3EA;
  /* Tech bridge (secondary — Transformix) */
  --navy:         #1D4497;
  --teal:         #28C0D4;
  --orange:       #E28A3B;
  /* Neutrals */
  --ink:          #102A43;
  --ink-2:        #0B2A17;
  --muted:        #5B6B61;
  --line:         #E4DECE;
  --white:        #ffffff;

  --maxw: 1180px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow-sm: 0 4px 14px rgba(16,42,67,.06);
  --shadow:    0 18px 50px rgba(15,63,32,.12);
  --shadow-lg: 0 28px 70px rgba(15,63,32,.20);
  --ease: cubic-bezier(.22,.61,.36,1);
  --font: "Cairo", "Segoe UI", Tahoma, system-ui, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--font); color:var(--ink);
  background:var(--white); line-height:1.7; font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ margin:0; line-height:1.25; font-weight:800; color:var(--ink-2); }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

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

.skip-link{
  position:absolute; right:-9999px; top:8px; background:var(--green); color:#fff;
  padding:10px 16px; border-radius:8px; z-index:200;
}
.skip-link:focus{ right:12px; }

/* ---------------- Buttons ---------------- */
.btn{
  --btn-bg:var(--green); --btn-fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  background:var(--btn-bg); color:var(--btn-fg);
  font-family:var(--font); font-weight:700; font-size:1rem;
  padding:.82rem 1.5rem; border-radius:999px; border:2px solid transparent;
  cursor:pointer; transition:transform .18s var(--ease), box-shadow .18s var(--ease), background .18s;
  box-shadow:0 8px 22px rgba(31,100,50,.22); white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 14px 30px rgba(31,100,50,.30); }
.btn:active{ transform:translateY(0); }
.btn:focus-visible{ outline:3px solid var(--gold); outline-offset:2px; }
.btn--primary{ --btn-bg:var(--green); }
.btn--gold{ --btn-bg:var(--gold); --btn-fg:#3a2c00; box-shadow:0 10px 26px rgba(216,184,67,.4); }
.btn--orange{ --btn-bg:var(--orange); box-shadow:0 10px 26px rgba(226,138,59,.35); }
.btn--ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.6); box-shadow:none; }
.btn--ghost:hover{ background:rgba(255,255,255,.12); }
.btn--ghost-dark{ background:transparent; color:var(--green); border-color:var(--green); box-shadow:none; }
.btn--sm{ padding:.55rem 1.05rem; font-size:.92rem; }
.btn--lg{ padding:1rem 2rem; font-size:1.08rem; }
.btn--block{ width:100%; }

/* ---------------- Header ---------------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.88); backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{ display:flex; align-items:center; gap:18px; min-height:72px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand__logo{ width:48px; height:48px; object-fit:contain; }
.brand__text{ display:flex; flex-direction:column; line-height:1.1; }
.brand__text strong{ font-size:1.18rem; font-weight:900; color:var(--green); }
.brand__text small{ font-size:.72rem; color:var(--muted); letter-spacing:.06em; }
.main-nav{ display:flex; gap:24px; margin-inline-start:auto; }
.main-nav a{ font-weight:600; color:var(--ink); font-size:.98rem; position:relative; padding:6px 0; }
.main-nav a::after{ content:""; position:absolute; bottom:0; inset-inline:0; height:2px; background:var(--gold); transform:scaleX(0); transition:transform .2s var(--ease); }
.main-nav a:hover::after{ transform:scaleX(1); }
.header-cta{ margin-inline-start:6px; }

/* ---------------- Hero ---------------- */
.hero{ position:relative; overflow:hidden; color:#fff; isolation:isolate; }
.hero__bg{ position:absolute; inset:0; z-index:-2;
  background:
    radial-gradient(1100px 540px at 88% -10%, rgba(40,192,212,.30), transparent 60%),
    radial-gradient(900px 500px at 6% 110%, rgba(236,196,92,.22), transparent 55%),
    linear-gradient(155deg, #0c3a1f 0%, #1F6432 42%, #16386e 100%);
}
.hero__pattern{ position:absolute; inset:0; opacity:.16;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='1.1'%3E%3Cpath d='M30 0l30 30-30 30L0 30z'/%3E%3Cpath d='M30 14l16 16-16 16-16-16z'/%3E%3C/g%3E%3C/svg%3E");
  background-size:46px 46px;
}
.hero__journey{ position:absolute; inset:0; width:100%; height:100%; z-index:-1; }
.hero__journey path{ fill:none; stroke:rgba(236,196,92,.7); stroke-width:2.5; stroke-dasharray:10 12; }
.hero__journey .node{ fill:var(--teal); stroke:#fff; stroke-width:2.5; }
.hero__inner{ display:grid; grid-template-columns:1.05fr .95fr; gap:46px; align-items:center; padding:74px 22px 86px; }
.hero__text{ text-align:start; }
.hero__eyebrow{
  display:inline-block; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.28);
  padding:.5rem 1.1rem; border-radius:999px; font-size:.92rem; font-weight:600; margin-bottom:24px;
}
.hero__eyebrow span{ color:var(--gold); font-weight:800; }
.hero__title{ font-size:clamp(2rem,4.6vw,3.4rem); font-weight:900; color:#fff; letter-spacing:-.01em; }
.hero__subtitle{ max-width:560px; margin:20px 0 0; font-size:clamp(1.02rem,2.2vw,1.18rem); color:rgba(255,255,255,.92); }
.hero__actions{ display:flex; gap:14px; justify-content:flex-start; flex-wrap:wrap; margin-top:30px; }
.hero__stats{ display:flex; justify-content:flex-start; flex-wrap:wrap; gap:12px; margin-top:42px; }
.hero__stats li{
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius); padding:16px 22px; min-width:170px;
  display:flex; flex-direction:column; align-items:center; gap:4px; backdrop-filter:blur(4px);
}
.hero__stats strong{ font-size:1.7rem; font-weight:900; color:var(--gold); }
.hero__stats span{ font-size:.85rem; color:rgba(255,255,255,.86); text-align:center; }

/* ---------------- Trust / context strip ---------------- */
.trust{ background:var(--white); border-bottom:1px solid var(--line); padding:30px 0; }
.trust__context{ text-align:center; color:var(--muted); font-size:.98rem; margin-bottom:22px; }
.trust__context strong{ color:var(--green); }
.trust__logos{ display:flex; align-items:center; justify-content:center; gap:30px; flex-wrap:wrap; }
.trust__primary{ display:flex; align-items:center; gap:14px; }
.trust__primary img{ width:74px; height:74px; object-fit:contain; }
.trust__primary span{ font-weight:800; color:var(--green); font-size:1.05rem; max-width:160px; }
.trust__divider{ width:1px; height:56px; background:var(--line); }
.trust__partners{ display:flex; flex-direction:column; gap:8px; align-items:flex-start; }
.trust__label{ font-size:.78rem; color:var(--muted); font-weight:600; }
.trust__partner-logos{ display:flex; align-items:center; gap:24px; }
.trust__partner-logos img{ height:30px; width:auto; object-fit:contain; opacity:.92; }

/* ---------------- Generic section ---------------- */
.section{ padding:78px 0; }
.section--sand{ background:var(--sand-2); }
.section__head{ max-width:760px; margin:0 auto 46px; text-align:center; }
.section__head--light h2,.section__head--light .section__lead{ color:#fff; }
.kicker{
  display:inline-block; font-weight:800; font-size:.82rem; letter-spacing:.12em;
  color:var(--green); background:rgba(31,100,50,.10); padding:.35rem .9rem; border-radius:999px; margin-bottom:14px;
}
.kicker--gold{ color:#7a5d00; background:rgba(236,196,92,.28); }
.section__head h2{ font-size:clamp(1.55rem,3.6vw,2.4rem); }
.section__lead{ margin-top:14px; color:var(--muted); font-size:1.08rem; }

/* ---------------- Why grid ---------------- */
.why-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; }
.why-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 24px; box-shadow:var(--shadow-sm); transition:transform .2s var(--ease), box-shadow .2s;
  position:relative; overflow:hidden;
}
.why-card::before{ content:""; position:absolute; inset-inline-start:0; top:0; bottom:0; width:4px; background:linear-gradient(var(--green),var(--teal)); }
.why-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.why-card__num{ font-size:1.4rem; font-weight:900; color:var(--gold-deep); }
.why-card h3{ font-size:1.12rem; margin:8px 0 8px; }
.why-card p{ color:var(--muted); font-size:.98rem; }

/* ---------------- Tracks ---------------- */
.tracks{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:26px; max-width:920px; margin-inline:auto; }
.track{
  background:var(--white); border:1px solid var(--line); border-radius:20px; padding:34px 30px;
  box-shadow:var(--shadow); position:relative; overflow:hidden; display:flex; flex-direction:column;
}
.track::after{ content:""; position:absolute; top:-40px; inset-inline-end:-40px; width:150px; height:150px; border-radius:50%; opacity:.10; }
.track--framework::after{ background:var(--green); }
.track--masterclass::after{ background:var(--orange); }
.track__tag{ align-self:flex-start; background:rgba(31,100,50,.12); color:var(--green); font-weight:800; font-size:.8rem; padding:.35rem .9rem; border-radius:999px; }
.track__tag--orange{ background:rgba(226,138,59,.16); color:#b8631c; }
.track h3{ font-size:1.4rem; margin:16px 0 12px; color:var(--ink-2); }
.track h3 span{ font-size:.92rem; color:var(--navy); font-weight:700; }
.track p{ color:var(--muted); }
.track__list{ margin:18px 0 24px; display:flex; flex-direction:column; gap:10px; }
.track__list li{ position:relative; padding-inline-start:26px; color:var(--ink); font-weight:600; }
.track__list li::before{ content:"✓"; position:absolute; inset-inline-start:0; color:var(--green-fe); font-weight:900; }
.track--masterclass .track__list li::before{ color:var(--orange); }
.track .btn{ margin-top:auto; }

/* ---------------- Gain grid ---------------- */
.gain-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:18px; }
.gain-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:24px 22px; transition:transform .2s var(--ease), box-shadow .2s, border-color .2s;
}
.gain-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--gold); }
.gain-card__icon{ font-size:1.7rem; display:inline-flex; width:54px; height:54px; align-items:center; justify-content:center; background:var(--sand); border-radius:14px; margin-bottom:14px; }
.gain-card h3{ font-size:1.06rem; margin-bottom:6px; }
.gain-card p{ color:var(--muted); font-size:.94rem; }

/* ---------------- Pillars (dark) ---------------- */
.section--dark{ position:relative; overflow:hidden;
  background:linear-gradient(150deg,#0c3a1f,#143F20 55%,#16386e); color:#fff; }
.section--dark::before{ content:""; position:absolute; inset:0; opacity:.10;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M20 0l20 20-20 20L0 20z' fill='none' stroke='%23ECC45C' stroke-width='1'/%3E%3C/svg%3E");
  background-size:40px 40px; }
.pillars{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:22px; position:relative; }
.pillar{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:20px; padding:34px 28px; backdrop-filter:blur(4px); transition:transform .2s var(--ease);
}
.pillar:hover{ transform:translateY(-5px); }
.pillar__index{
  display:inline-flex; width:54px; height:54px; align-items:center; justify-content:center;
  font-size:1.5rem; font-weight:900; color:var(--ink-2);
  background:var(--gold); border-radius:50%; margin-bottom:18px;
}
.pillar h3{ color:#fff; font-size:1.3rem; margin-bottom:10px; }
.pillar p{ color:rgba(255,255,255,.85); }

/* ---------------- Agent ---------------- */
.agent{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:46px; align-items:start; }
.agent__intro h2{ font-size:clamp(1.6rem,3.4vw,2.3rem); margin:12px 0 14px; }
.grad-text{ background:linear-gradient(90deg,var(--navy),var(--teal)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.agent__intro .btn{ margin-top:24px; }
.agent__steps{ display:grid; grid-template-columns:1fr 1fr; gap:16px; counter-reset:none; }
.agent__steps li{ display:flex; gap:14px; background:var(--white); border:1px solid var(--line); border-radius:14px; padding:18px; box-shadow:var(--shadow-sm); }
.agent__step-num{
  flex:0 0 auto; width:38px; height:38px; border-radius:10px; font-weight:900; color:#fff;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--green),var(--teal));
}
.agent__steps h3{ font-size:1.02rem; margin-bottom:4px; }
.agent__steps p{ color:var(--muted); font-size:.9rem; }

/* ---------------- Who grid ---------------- */
.who-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; max-width:920px; margin-inline:auto; }
.who-chip{
  background:var(--white); border:1px solid var(--line); border-radius:14px; padding:20px 18px;
  font-weight:700; text-align:center; color:var(--ink-2); position:relative; padding-inline-start:44px;
  transition:transform .18s var(--ease), border-color .2s;
}
.who-chip::before{ content:"📍"; position:absolute; inset-inline-start:16px; top:50%; transform:translateY(-50%); font-size:1.1rem; }
.who-chip:hover{ transform:translateY(-3px); border-color:var(--green); }

/* ---------------- Registration ---------------- */
.registration{ background:
  radial-gradient(800px 400px at 100% 0%, rgba(40,192,212,.10), transparent 60%),
  var(--sand); }
.registration__inner{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:40px; align-items:start; }
.registration__copy h2{ font-size:clamp(1.6rem,3.6vw,2.3rem); margin:12px 0 14px; }
.registration__copy p{ color:var(--muted); }
.registration__assure{ margin-top:22px; display:flex; flex-direction:column; gap:12px; }
.registration__assure li{ position:relative; padding-inline-start:30px; font-weight:600; color:var(--ink); }
.registration__assure li::before{ content:"✓"; position:absolute; inset-inline-start:0; width:20px; height:20px; background:var(--green); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.75rem; }

.registration__form-wrap{ background:var(--white); border:1px solid var(--line); border-radius:22px; padding:32px; box-shadow:var(--shadow-lg); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:16px; }
.field label{ font-weight:700; font-size:.94rem; color:var(--ink-2); }
.req{ color:#c0392b; }
.field input, .field select, .field textarea{
  font-family:var(--font); font-size:1rem; color:var(--ink);
  padding:.78rem .9rem; border:1.6px solid var(--line); border-radius:12px; background:#fdfcf8;
  transition:border-color .18s, box-shadow .18s; width:100%;
}
.field textarea{ resize:vertical; }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--green); box-shadow:0 0 0 4px rgba(31,100,50,.12); background:#fff;
}
.field input.invalid, .field select.invalid{ border-color:#c0392b; box-shadow:0 0 0 4px rgba(192,57,43,.10); }
.field .field-error{ color:#c0392b; font-size:.82rem; font-weight:600; }

.consent{ display:flex; gap:12px; align-items:flex-start; margin:6px 0 20px; font-size:.94rem; color:var(--ink); cursor:pointer; }
.consent input{ margin-top:4px; width:20px; height:20px; accent-color:var(--green); flex:0 0 auto; }

.hp-field{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

#submit-btn{ position:relative; }
.btn__spinner{ display:none; width:18px; height:18px; border:2.5px solid rgba(255,255,255,.45); border-top-color:#fff; border-radius:50%; animation:spin .7s linear infinite; }
.is-loading .btn__label{ opacity:.7; }
.is-loading .btn__spinner{ display:inline-block; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.form-status{ margin-top:16px; font-weight:700; text-align:center; min-height:1.4em; }
.form-status.success{ color:var(--green); }
.form-status.error{ color:#c0392b; }

/* ---------------- Footer ---------------- */
.site-footer{ background:#0c2a16; color:rgba(255,255,255,.86); }
.footer__inner{ display:grid; grid-template-columns:1.1fr 1.4fr auto; gap:40px; padding:56px 22px; align-items:start; }
.footer__logo-main{ width:88px; height:88px; object-fit:contain; margin-bottom:14px; }
.footer__org{ font-weight:800; color:#fff; }
.footer__tag{ color:var(--gold); font-size:.92rem; margin-top:4px; }
.footer__contacts h4{ color:#fff; font-size:1rem; margin-bottom:18px; }
.footer__partner{ display:flex; align-items:center; gap:16px; margin-bottom:18px; }
.footer__partner img{ height:26px; width:auto; object-fit:contain; filter:brightness(0) invert(1); opacity:.92; }
.footer__partner ul{ display:flex; flex-direction:column; gap:4px; }
.footer__partner a{ color:rgba(255,255,255,.82); font-size:.92rem; }
.footer__partner a:hover{ color:var(--gold); }
.footer__cta{ align-self:center; }

.powered{ border-top:1px solid rgba(255,255,255,.12); background:#081f10; }
.powered__inner{ display:flex; align-items:center; justify-content:center; gap:14px; padding:26px 22px; flex-wrap:wrap; }
.powered__by{ color:rgba(255,255,255,.6); font-size:1rem; letter-spacing:.04em; }
.powered__brand{
  font-size:clamp(1.5rem,4vw,2.4rem); font-weight:900; letter-spacing:.01em;
  background:linear-gradient(90deg,#fff,var(--gold)); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.powered__brand:hover{ background:linear-gradient(90deg,var(--gold),var(--teal)); -webkit-background-clip:text; background-clip:text; }

/* ---------------- Sticky mobile CTA ---------------- */
.sticky-cta{ display:none; }

/* ---------------- Reveal animation ---------------- */
/* Reveal only hides when JS is present (progressive enhancement — no-JS shows everything) */
.js .reveal{ opacity:0; transform:translateY(24px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ---------------- Responsive ---------------- */
@media (max-width:880px){
  .agent{ grid-template-columns:1fr; gap:30px; }
  .agent__steps{ grid-template-columns:1fr; }
  .registration__inner{ grid-template-columns:1fr; gap:28px; }
  .footer__inner{ grid-template-columns:1fr; gap:28px; }
  .footer__cta{ align-self:start; }
}
@media (max-width:760px){
  .main-nav{ display:none; }
  .header-cta{ margin-inline-start:auto; }
  .trust__logos{ gap:18px; }
  .trust__divider{ display:none; }
  .section{ padding:56px 0; }
  .form-row{ grid-template-columns:1fr; gap:0; }
  .registration__form-wrap{ padding:24px; }
  body{ padding-bottom:84px; } /* room for sticky CTA */
  .sticky-cta{
    display:flex; gap:10px; position:fixed; inset-inline:0; bottom:0; z-index:90;
    padding:12px 16px calc(12px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.96); backdrop-filter:blur(8px); border-top:1px solid var(--line);
    box-shadow:0 -8px 24px rgba(15,63,32,.10);
  }
  .sticky-cta .btn{ flex:1; padding:.8rem .6rem; font-size:.96rem; }
}
@media (max-width:420px){
  .hero__stats li{ min-width:140px; }
  .brand__text small{ display:none; }
}

/* =====================================================
   Added components (erp-matched depth)
   ===================================================== */

/* Hero dashboard preview */
.hero__dash{ display:flex; justify-content:center; }
.dash{
  width:100%; max-width:430px; background:rgba(255,255,255,.97); color:var(--ink);
  border:1px solid rgba(255,255,255,.5); border-radius:20px; padding:20px;
  box-shadow:0 34px 80px rgba(8,30,16,.42);
}
.dash__top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.dash__title{ font-weight:800; color:var(--green); }
.dash__live{ font-size:.72rem; color:#1a8f4c; font-weight:700; }
.dash__tiles{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.dash__tile{ background:var(--sand); border-radius:12px; padding:12px; text-align:center; }
.dash__tile b{ display:block; font-size:1.45rem; color:var(--navy); font-weight:900; }
.dash__tile small{ font-size:.72rem; color:var(--muted); }
.dash__sent{ margin-top:14px; }
.dash__sent-label{ font-size:.78rem; font-weight:700; color:var(--ink-2); }
.dash__bar{ display:flex; height:12px; border-radius:8px; overflow:hidden; margin:8px 0 6px; }
.dash__bar i{ background:var(--green-fe); }
.dash__bar u{ background:var(--gold); }
.dash__bar s{ background:#e0837a; }
.dash__legend{ display:flex; justify-content:space-between; font-size:.68rem; color:var(--muted); }
.dash__note{ margin-top:12px; font-size:.66rem; color:#9aa39c; text-align:center; }

/* Vision / sector strip */
.vision{ background:linear-gradient(135deg,#0c3a1f,#16386e); color:#fff; padding:48px 0; }
.vision__inner{ display:grid; grid-template-columns:1fr 1.2fr; gap:36px; align-items:center; }
.vision__head h2{ color:#fff; font-size:clamp(1.4rem,3vw,2rem); margin:10px 0; }
.vision__head p{ color:rgba(255,255,255,.85); }
.vision__head strong{ color:var(--gold); }
.vision__stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.vision__stats li{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); border-radius:14px; padding:18px 12px; text-align:center; }
.vision__stats strong{ display:block; font-size:1.85rem; font-weight:900; color:var(--gold); line-height:1; }
.vision__stats strong span{ font-size:1rem; }
.vision__stats small{ display:block; margin-top:8px; font-size:.74rem; color:rgba(255,255,255,.82); }

/* Before / after journey */
.shift{ max-width:780px; margin-inline:auto; display:flex; flex-direction:column; gap:12px; }
.shift__row{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:14px;
  background:#fff; border:1px solid var(--line); border-radius:14px; padding:14px 18px; box-shadow:var(--shadow-sm);
  transition:transform .18s var(--ease); }
.shift__row:hover{ transform:translateY(-2px); }
.shift__from{ color:var(--muted); }
.shift__to{ color:var(--green); font-weight:800; }
.shift__arrow{ color:var(--gold-deep); font-weight:900; font-size:1.3rem; }

/* AI chat demo */
.chat{ background:#f4f7f4; border:1px solid var(--line); border-radius:16px; padding:16px; margin:22px 0 24px; display:flex; flex-direction:column; gap:10px; }
.chat__msg{ max-width:88%; padding:10px 14px; border-radius:14px; font-size:.92rem; line-height:1.6; }
.chat__msg--user{ align-self:flex-start; background:var(--green); color:#fff; border-top-right-radius:4px; }
.chat__msg--bot{ align-self:flex-end; background:#fff; border:1px solid var(--line); border-top-left-radius:4px; }
.chat__msg--bot b{ color:var(--navy); }
.chat__note{ align-self:center; font-size:.64rem; color:#9aa39c; }

/* How-we-work phases */
.phases{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.phase{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:26px 18px; text-align:center; box-shadow:var(--shadow-sm); transition:transform .18s var(--ease); }
.phase:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.phase__n{ display:inline-flex; width:46px; height:46px; align-items:center; justify-content:center; font-size:1.3rem; font-weight:900; color:#fff; background:linear-gradient(135deg,var(--green),var(--teal)); border-radius:50%; margin-bottom:14px; }
.phase h3{ font-size:1rem; margin-bottom:6px; }
.phase p{ color:var(--muted); font-size:.85rem; }

/* Final CTA */
.final-cta{ position:relative; overflow:hidden; background:linear-gradient(135deg,#1F6432,#16386e); color:#fff; text-align:center; padding:66px 0; }
.final-cta::before{ content:""; position:absolute; inset:0; opacity:.12;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M20 0l20 20-20 20L0 20z' fill='none' stroke='%23ECC45C' stroke-width='1'/%3E%3C/svg%3E");
  background-size:40px 40px; }
.final-cta__inner{ position:relative; }
.final-cta h2{ color:#fff; font-size:clamp(1.6rem,3.6vw,2.4rem); }
.final-cta p{ color:rgba(255,255,255,.88); margin-top:12px; }
.final-cta__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:26px; }

/* Responsive for added components */
@media (max-width:920px){
  .hero__inner{ grid-template-columns:1fr; gap:34px; }
  .hero__text{ text-align:center; }
  .hero__subtitle{ margin-inline:auto; }
  .hero__actions, .hero__stats{ justify-content:center; }
  .vision__inner{ grid-template-columns:1fr; gap:22px; }
  .phases{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px){
  .vision__stats{ grid-template-columns:repeat(2,1fr); }
  .shift__row{ grid-template-columns:1fr; gap:6px; text-align:center; }
  .shift__arrow{ transform:rotate(-90deg); }
  .dash{ max-width:none; }
}
@media (max-width:520px){
  .phases{ grid-template-columns:1fr; }
}
