/* ============================================================================
   GetMiamiSEO — Design System (shadcn/ui-inspired, adapted to the dark brand)
   Single source of truth for tokens + components. Loaded via partials/page-styles.
   ========================================================================== */

:root{
  /* ---- Brand colors (kept) ---- */
  --accent:#FF3C00; --accent-2:#00E5A0;
  --black:#0A0A0A; --dark:#111; --dark-2:#161616; --dark-3:#1E1E1E;
  --white:#fff; --gray:#8a8a8a; --gray-light:#bdbdbd;

  /* ---- Semantic tokens ---- */
  --background:var(--black);
  --foreground:var(--white);
  --muted-foreground:var(--gray-light);
  --card:#121212;
  --card-hover:#171717;
  --border:rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.14);
  --ring:rgba(255,60,0,.55);
  --primary:var(--accent);
  --primary-foreground:#fff;

  /* ---- Radius scale ---- */
  --radius:.75rem;
  --radius-sm:.5rem;
  --radius-lg:1rem;
  --radius-xl:1.25rem;
  --radius-full:999px;

  /* ---- Spacing scale ---- */
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-6:1.5rem; --space-8:2rem; --space-12:3rem; --space-16:4rem;

  /* ---- Shadows ---- */
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 8px 24px rgba(0,0,0,.35);
  --shadow-lg:0 24px 60px rgba(0,0,0,.5);

  /* ---- Typography (modern US SaaS/marketing feel) ---- */
  --font-display:'Sora','Inter',system-ui,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;

  --container:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--background);color:var(--foreground);font-family:var(--font-body);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto}
::selection{background:var(--accent);color:#fff}
/* Sora has no true italic — never synthesize oblique on headings */
:is(h1,h2,h3,h4,h5,h6) em,.sec-head h2 em,.cta-box h2 em{font-style:normal;color:var(--accent)}

/* ---- Accessibility: visible focus ring + reduced motion ---- */
:where(a,button,summary,input,textarea,[tabindex]):focus-visible{
  outline:2px solid var(--ring);outline-offset:2px;border-radius:var(--radius-sm)
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* ============================ NAV ============================ */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;background:rgba(10,10,10,.82);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--border)}
.nav-logo{font-family:var(--font-display);font-size:1.4rem;font-weight:900;color:#fff;letter-spacing:-.01em}
.nav-logo span{color:var(--accent)}
.nav-r{display:flex;align-items:center;gap:1.25rem}
.nav-r a{color:var(--muted-foreground);font-size:.88rem;font-weight:500;transition:color .15s}
.nav-r a:hover{color:#fff}
.nav-cta{background:var(--primary)!important;color:#fff!important;padding:.6rem 1.2rem;border-radius:var(--radius-sm);font-weight:700;font-size:.85rem;min-height:40px;display:inline-flex;align-items:center;box-shadow:0 6px 18px rgba(255,60,0,.25);transition:transform .15s,box-shadow .15s}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(255,60,0,.35)}
/* Pure-CSS mobile nav (checkbox toggle) */
.nav-burger{display:none;cursor:pointer;color:#fff;background:none;border:0;padding:.25rem}
#navtog{display:none}
@media(max-width:760px){
  .nav-burger{display:flex}
  .nav-collapse{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(10,10,10,.98);backdrop-filter:blur(14px);flex-direction:column;align-items:stretch;gap:0;padding:.5rem;border-bottom:1px solid var(--border)}
  #navtog:checked ~ .nav-collapse{display:flex}
  .nav-collapse a{padding:.9rem 1rem}
  .nav-collapse a.nav-cta{margin:.5rem;text-align:center;justify-content:center}
}
@media(max-width:680px){.nav-r a.hide-m{display:none}}

/* ============================ LAYOUT ============================ */
.wrap{max-width:920px;margin:0 auto;padding:0 1.5rem}

/* ============================ HERO ============================ */
.hero{padding:9rem 0 2.5rem;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,60,0,.08);border:1px solid rgba(255,60,0,.22);color:var(--accent);padding:.4rem 1rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:1.5rem}
h1{font-family:var(--font-display);font-size:clamp(2.3rem,5vw,3.7rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;margin-bottom:1rem}
h1 em{color:var(--accent);font-style:normal}
.lead{color:var(--muted-foreground);font-size:1.12rem;max-width:660px;margin:0 auto;line-height:1.7}

/* ============================ SECTION ============================ */
.sec{padding:3rem 0;border-top:1px solid var(--border)}
.sec h2{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.25rem);font-weight:800;letter-spacing:-.02em;margin-bottom:1rem}
.sec h2 em{color:var(--accent);font-style:normal}
.sec p{color:var(--muted-foreground);margin-bottom:1rem}
.sec ul{color:var(--muted-foreground);padding-left:1.2rem;margin-bottom:1rem}
.sec li{margin-bottom:.5rem}

/* ============================ CARD ============================ */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-top:1.5rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color .2s,transform .2s,background .2s}
.card:hover{border-color:var(--border-strong);background:var(--card-hover);transform:translateY(-2px)}
.card h3{font-size:1.05rem;font-weight:700;margin-bottom:.5rem}
.card p{color:var(--muted-foreground);font-size:.9rem;margin:0}

/* ============================ STEP / PROCESS ============================ */
.step{display:flex;gap:1rem;margin-bottom:1.25rem}
.step .n{width:38px;height:38px;border-radius:var(--radius-full);background:rgba(255,60,0,.12);color:var(--accent);font-weight:900;display:grid;place-items:center;flex-shrink:0}
.step .b h3{font-size:1.05rem;margin-bottom:.25rem}
.step .b p{color:var(--muted-foreground);font-size:.92rem;margin:0}

/* ============================ CTA ============================ */
.cta-box{background:linear-gradient(135deg,rgba(255,60,0,.13),rgba(0,229,160,.05));border:1px solid rgba(255,60,0,.22);border-radius:var(--radius-xl);padding:2.75rem 2rem;text-align:center;margin:3rem 0;box-shadow:var(--shadow)}
.cta-box h2{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2rem);font-weight:900;margin-bottom:.6rem;border:0}
.cta-box p{color:var(--muted-foreground);max-width:520px;margin:0 auto 1.5rem}

/* ============================ BUTTONS ============================ */
.btn-wa,.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:48px;padding:.85rem 1.75rem;border-radius:var(--radius);font-weight:800;font-size:1rem;cursor:pointer;border:1px solid transparent;transition:transform .15s,box-shadow .15s,background .15s,border-color .15s;line-height:1}
.btn-wa{background:var(--accent-2);color:#062;box-shadow:0 8px 22px rgba(0,229,160,.22)}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,229,160,.32)}
.ds-btn-primary{background:var(--primary);color:#fff;box-shadow:0 8px 22px rgba(255,60,0,.25)}
.ds-btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(255,60,0,.35)}
.ds-btn-outline{background:transparent;color:#fff;border-color:var(--border-strong)}
.ds-btn-outline:hover{border-color:var(--accent);background:rgba(255,60,0,.06)}
.ds-btn-ghost{background:var(--dark-2);color:#fff;border-color:var(--border)}
.ds-btn-ghost:hover{background:var(--dark-3)}

/* ============================ BADGE ============================ */
.ds-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:700;letter-spacing:.5px;padding:.28rem .7rem;border-radius:var(--radius-full);border:1px solid var(--border)}
.ds-badge-accent{background:rgba(255,60,0,.1);color:var(--accent);border-color:rgba(255,60,0,.25)}
.ds-badge-success{background:rgba(0,229,160,.1);color:var(--accent-2);border-color:rgba(0,229,160,.25)}
.badge-sample{display:inline-block;background:rgba(255,193,7,.15);color:#ffc107;font-size:.68rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:.22rem .6rem;border-radius:var(--radius-sm);margin-left:.5rem;vertical-align:middle}

/* ============================ ALERT / NOTICE ============================ */
.notice,.ds-alert{background:rgba(255,193,7,.08);border:1px solid rgba(255,193,7,.3);border-radius:var(--radius);padding:1rem 1.25rem;color:#ffce60;font-size:.9rem;margin-bottom:2rem;line-height:1.55}

/* ============================ FOOTER ============================ */
footer{border-top:1px solid var(--border);padding:2.5rem 0;text-align:center;color:var(--gray);font-size:.85rem}
footer a{color:var(--accent-2)}
footer a:hover{color:#fff}

/* ============================ FORMS ============================ */
input,textarea,select{font-family:inherit}
input::placeholder,textarea::placeholder{color:var(--gray)}

/* ============================================================================
   v4 — American-marketing layer: parallax, imagery, icons, reveal, CTA polish
   ========================================================================== */

/* ---- Inline SVG icon helper (custom icons, never emoji) ---- */
.i{display:inline-block;width:1em;height:1em;vertical-align:-.125em;flex:none}
.i-lg{width:28px;height:28px}
svg.i{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
svg.i.fill{fill:currentColor;stroke:none}

/* icon chip used in feature cards / trust rows */
.ichip{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:rgba(255,60,0,.1);border:1px solid rgba(255,60,0,.22);color:var(--accent);margin-bottom:1rem}
.ichip svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ichip.green{background:rgba(0,229,160,.1);border-color:rgba(0,229,160,.25);color:var(--accent-2)}

/* ---- Check list (custom SVG checkmark, replaces ✓ emoji) ---- */
.check{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;background:rgba(0,229,160,.14);color:var(--accent-2);flex:none}
.check svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}

/* ---- PARALLAX HERO with real imagery ---- */
.px{position:relative;isolation:isolate;overflow:hidden}
.px__bg{position:absolute;inset:-10% 0;z-index:-2;background-size:cover;background-position:center;will-change:transform;transform:translateZ(0)}
.px__bg img{width:100%;height:100%;object-fit:cover}
.px__veil{position:absolute;inset:0;z-index:-1;background:
   radial-gradient(1200px 600px at 75% -10%,rgba(255,60,0,.18),transparent 60%),
   linear-gradient(180deg,rgba(10,10,10,.72) 0%,rgba(10,10,10,.86) 55%,rgba(10,10,10,.97) 100%)}
@media(min-width:1000px){.px--fixed .px__bg{background-attachment:fixed}}

/* glow accents that bleed under sections to add depth */
.glow-top{position:relative}
.glow-top::before{content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:60%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,60,0,.5),transparent)}

/* ---- IMAGE BAND (industries / neighborhoods) ---- */
.imgcard{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);aspect-ratio:4/3;display:block}
.imgcard img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.imgcard:hover img{transform:scale(1.06)}
.imgcard__cap{position:absolute;inset:auto 0 0 0;padding:1.4rem 1.1rem .9rem;background:linear-gradient(180deg,transparent,rgba(8,8,8,.92));z-index:1}
.imgcard__cap h3{font-family:var(--font-display);font-size:1.02rem;font-weight:700;margin:0}
.imgcard__cap p{font-size:.8rem;color:var(--gray-light);margin:.15rem 0 0}
.imgcard__tag{position:absolute;top:.7rem;left:.7rem;z-index:1;font-size:.66rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#fff;background:rgba(255,60,0,.9);padding:.25rem .55rem;border-radius:var(--radius-sm)}

/* ---- TESTIMONIAL / SOCIAL PROOF ---- */
.quote{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.6rem;display:flex;flex-direction:column;gap:1rem}
.quote p{color:var(--foreground);font-size:.98rem;line-height:1.65;margin:0}
.quote .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.quote .who img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.quote .who b{display:block;font-size:.88rem}
.quote .who span{font-size:.76rem;color:var(--gray)}
.stars{display:inline-flex;gap:2px;color:#FFB020}
.stars svg{width:15px;height:15px;fill:currentColor;stroke:none}

/* ---- REVEAL ON SCROLL (storytelling flow) ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ---- CTA polish: animated gradient + glow ---- */
.ds-btn-primary{background:linear-gradient(120deg,#FF3C00,#FF6A2B);background-size:160% 160%;animation:ctaPan 6s ease infinite}
@keyframes ctaPan{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.btn-lg{min-height:54px;padding:1rem 2rem;font-size:1.05rem}
.btn-wa svg{width:20px;height:20px}

/* eyebrow live dot */
.dot{width:7px;height:7px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 0 0 rgba(0,229,160,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(0,229,160,.55)}70%{box-shadow:0 0 0 7px rgba(0,229,160,0)}100%{box-shadow:0 0 0 0 rgba(0,229,160,0)}}

/* trust row with icons (replaces emoji trustbar) */
.trustrow{display:flex;flex-wrap:wrap;gap:1rem 2.25rem;justify-content:center;align-items:center;padding:1.4rem 1.5rem;background:var(--dark-2);border-block:1px solid var(--border)}
.trustrow .t{display:inline-flex;align-items:center;gap:.55rem;font-size:.88rem;color:var(--muted-foreground)}
.trustrow .t b{color:#fff;font-weight:700}
.trustrow .t svg{width:18px;height:18px;color:var(--accent);stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* section eyebrow spacing helper */
.lead-trust .check,.lead-ok .check{vertical-align:middle}

/* ============================================================================
   v5 — editorial "journey" layer: scroll progress, sticky sub-nav,
   alternating feature rows, timeline, neighborhood band (bespoke, not AI-grid)
   ========================================================================== */

/* scroll progress bar — GPU-composited (scaleX, no layout/reflow) */
.scrollbar{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);transform-origin:0 50%;z-index:1200;background:linear-gradient(90deg,var(--accent),#FF8A3D);box-shadow:0 0 12px rgba(255,60,0,.6);will-change:transform}

/* sticky in-page section nav (GitHub-docs style) with scrollspy */
.subnav{position:sticky;top:60px;z-index:900;background:rgba(10,10,10,.86);backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--border)}
.subnav .in{max-width:var(--container);margin:0 auto;display:flex;gap:.35rem;padding:.55rem 1rem;overflow-x:auto;scrollbar-width:none}
.subnav .in::-webkit-scrollbar{display:none}
.subnav a{white-space:nowrap;font-size:.82rem;font-weight:600;color:var(--muted-foreground);padding:.45rem .85rem;border-radius:var(--radius-full);border:1px solid transparent;transition:.15s}
.subnav a:hover{color:#fff;background:var(--dark-2)}
.subnav a.act{color:#fff;background:rgba(255,60,0,.12);border-color:rgba(255,60,0,.3)}

/* alternating image + text feature rows (z-pattern, editorial) */
.featrow{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;padding:4.5rem 0;border-top:1px solid var(--border)}
.featrow.rev .media{order:2}
.featrow .media{position:relative;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-lg);aspect-ratio:4/3}
.featrow .media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.featrow:hover .media img{transform:scale(1.04)}
.featrow .media .float{position:absolute;left:1rem;bottom:1rem;display:inline-flex;align-items:center;gap:.5rem;background:rgba(10,10,10,.78);backdrop-filter:blur(8px);border:1px solid var(--border-strong);border-radius:var(--radius);padding:.55rem .9rem;font-size:.82rem;font-weight:700}
.featrow .media .float svg{width:16px;height:16px;color:var(--accent-2);stroke:currentColor;fill:none;stroke-width:2.2}
.featrow .copy .kicker{display:inline-flex;align-items:center;gap:.5rem;color:var(--accent);font-size:.72rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:1rem}
.featrow .copy h2{font-family:var(--font-display);font-size:clamp(1.6rem,2.8vw,2.2rem);font-weight:800;letter-spacing:-.02em;line-height:1.12;margin-bottom:1rem}
.featrow .copy p{color:var(--muted-foreground);font-size:1.02rem;line-height:1.7;margin-bottom:1rem}
.featrow .copy .ck{display:flex;flex-direction:column;gap:.6rem;margin:1.25rem 0}
.featrow .copy .ck div{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem}
@media(max-width:860px){.featrow{grid-template-columns:1fr;gap:1.75rem;padding:3rem 0}.featrow.rev .media{order:0}}

/* vertical process timeline (HowTo) */
.timeline{max-width:760px;margin:2rem auto 0;position:relative;padding-left:2.25rem}
.timeline::before{content:"";position:absolute;left:11px;top:.4rem;bottom:.4rem;width:2px;background:linear-gradient(180deg,var(--accent),rgba(255,60,0,.15))}
.tstep{position:relative;padding:0 0 2rem}
.tstep:last-child{padding-bottom:0}
.tstep .dot{position:absolute;left:-2.25rem;top:.1rem;width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:.78rem;font-weight:800;box-shadow:0 0 0 4px rgba(255,60,0,.18);animation:none}
.tstep h3{font-size:1.1rem;font-weight:700;margin-bottom:.3rem}
.tstep p{color:var(--muted-foreground);font-size:.95rem;line-height:1.65;margin:0}

/* neighborhood image band */
.nbhd{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.75rem}
.nbhd a{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);aspect-ratio:3/4}
.nbhd a img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.nbhd a:hover img{transform:scale(1.07)}
.nbhd a span{position:absolute;inset:auto 0 0 0;padding:1.1rem .9rem .8rem;background:linear-gradient(180deg,transparent,rgba(8,8,8,.9));font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:.4rem}
.nbhd a span svg{width:15px;height:15px;color:var(--accent);stroke:currentColor;fill:none;stroke-width:2}
@media(max-width:860px){.nbhd{grid-template-columns:repeat(2,1fr)}}

/* answer-first callout (AIO) */
.answer{background:linear-gradient(135deg,rgba(255,60,0,.08),rgba(0,229,160,.04));border:1px solid var(--border-strong);border-left:3px solid var(--accent);border-radius:var(--radius-lg);padding:1.5rem 1.6rem;margin:1.5rem 0}
.answer p{margin:0;color:var(--foreground);font-size:1.05rem;line-height:1.7}
.answer strong{color:var(--accent)}
