/* seoambassador.com -- style.css
   DESIGN: 3-PART SPLIT NAV + EDITORIAL LEFT HERO -- Site 30
   Syne (geometric experimental display) + Work Sans (clean utilitarian) -- BOTH NEW in 30-site series
   Palette: White #FFFFFF + Jet Black #0A0A0A + Electric Teal #00C9A7 + Sand #F5F0E8 + Stone #6B7280 + Mist #9CA3AF
   CSS prefix: sab-  JS: SAB  PHP prefix: sab_  Image prefix: sab-
   NAV: 3-PART SPLIT -- left logo | center links | right CTA+lang -- first in 30-site series
   HERO: EDITORIAL LEFT SPLIT -- massive slab serif left + image panel right -- new in series
   /services/index.php: services listing in /services/ folder
   CONTAINED: sab-vessel max-width:1240px
   Location: C. la Luz, 29, 30580 Alquerias, Murcia, Spain
   Languages: EN + ES
*/

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Work+Sans:wght@300;400;500;600&display=swap');

:root {
  --sab-black:   #0A0A0A;
  --sab-black2:  #181818;
  --sab-teal:    #00C9A7;
  --sab-teal2:   #00A88C;
  --sab-teal-lo: rgba(0,201,167,.07);
  --sab-teal-md: rgba(0,201,167,.15);
  --sab-sand:    #F5F0E8;
  --sab-sand2:   #EDE7DC;
  --sab-white:   #FFFFFF;
  --sab-stone:   #6B7280;
  --sab-mist:    #9CA3AF;
  --sab-line:    rgba(10,10,10,.08);
  --sab-line2:   rgba(10,10,10,.04);
  --nav-h:       68px;
  --vessel-w:    1240px;
  --vessel-px:   2.5rem;
  --sab-ease:    .16s;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body { font-family:'Work Sans',system-ui,sans-serif; background:var(--sab-white); color:var(--sab-black); line-height:1.72; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
img { display:block; max-width:100%; height:auto; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
ul,ol { list-style:none; }
h1,h2,h3,h4 { font-family:'Syne',system-ui,sans-serif; font-weight:800; line-height:1; }
p { margin-bottom:.75rem; font-size:0.9rem; line-height:1.82; }
p:last-child { margin-bottom:0; }

/* =====================================================
   CONTAINED LAYOUT
   ===================================================== */
.sab-vessel { max-width:var(--vessel-w); margin:0 auto; padding:0 var(--vessel-px); }

/* Labels */
.sab-tag { font-family:'Work Sans',sans-serif; font-size:0.58rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--sab-teal); display:inline-flex; align-items:center; gap:.5rem; }
.sab-tag::before { content:''; display:block; width:18px; height:2px; background:var(--sab-teal); flex-shrink:0; }

/* Buttons */
.sab-btn-teal { display:inline-flex; align-items:center; gap:.3rem; font-family:'Work Sans',sans-serif; font-size:0.88rem; font-weight:600; background:var(--sab-teal); color:var(--sab-black); padding:.74rem 2rem; border-radius:2px; transition:background var(--sab-ease); white-space:nowrap; }
.sab-btn-teal:hover { background:var(--sab-teal2); }
.sab-btn-black { display:inline-flex; align-items:center; gap:.3rem; font-family:'Work Sans',sans-serif; font-size:0.88rem; font-weight:600; background:var(--sab-black); color:#fff; padding:.74rem 2rem; border-radius:2px; transition:background var(--sab-ease); white-space:nowrap; }
.sab-btn-black:hover { background:var(--sab-black2); }
.sab-btn-sand { display:inline-flex; align-items:center; gap:.3rem; font-family:'Work Sans',sans-serif; font-size:0.88rem; font-weight:600; background:var(--sab-sand); color:var(--sab-black); padding:.74rem 2rem; border-radius:2px; transition:background var(--sab-ease); white-space:nowrap; }
.sab-btn-sand:hover { background:var(--sab-sand2); }
.sab-btn-outline-dark { display:inline-flex; align-items:center; gap:.3rem; font-family:'Work Sans',sans-serif; font-size:0.88rem; font-weight:600; background:transparent; color:var(--sab-black); padding:.72rem 2rem; border:1.5px solid var(--sab-line); border-radius:2px; transition:all var(--sab-ease); white-space:nowrap; }
.sab-btn-outline-dark:hover { border-color:var(--sab-teal); color:var(--sab-teal2); }
.sab-btn-outline-light { display:inline-flex; align-items:center; gap:.3rem; font-family:'Work Sans',sans-serif; font-size:0.88rem; font-weight:600; background:transparent; color:rgba(255,255,255,.55); padding:.72rem 2rem; border:1.5px solid rgba(255,255,255,.15); border-radius:2px; transition:all var(--sab-ease); white-space:nowrap; }
.sab-btn-outline-light:hover { color:#fff; border-color:rgba(255,255,255,.4); }
.sab-tlink { font-family:'Work Sans',sans-serif; font-size:0.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--sab-teal2); display:inline-flex; align-items:center; gap:.25rem; transition:gap var(--sab-ease); }
.sab-tlink:hover { gap:.45rem; }

/* =====================================================
   3-PART SPLIT NAVIGATION
   Completely symmetrical: logo left | links center | CTA right
   Different from all previous nav styles in the 30-site series
   ===================================================== */
.sab-topnav { position:sticky; top:0; z-index:300; height:var(--nav-h); background:var(--sab-white); border-bottom:1px solid var(--sab-line); transition:box-shadow .25s; }
.sab-topnav.sab-scrolled { box-shadow:0 2px 20px rgba(10,10,10,.08); }
.sab-nav-inner { height:100%; max-width:var(--vessel-w); margin:0 auto; padding:0 var(--vessel-px); display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:2rem; }
/* Left: logo */
.sab-nav-logo { display:flex; align-items:center; text-decoration:none; }
.sab-nav-brand { font-family:'Syne',sans-serif; font-size:1.15rem; font-weight:800; color:var(--sab-black); letter-spacing:-.01em; }
.sab-nav-brand em { color:var(--sab-teal); font-style:normal; }
/* Center: links -- 0.93rem Work Sans 600 -- bigger than body p 0.9rem */
.sab-nav-center { display:flex; align-items:center; gap:.1rem; justify-content:center; }
.sab-nav-a { font-family:'Work Sans',sans-serif; font-size:0.93rem; font-weight:600; color:var(--sab-stone); padding:.28rem .72rem; border-radius:2px; transition:all var(--sab-ease); white-space:nowrap; }
.sab-nav-a:hover, .sab-nav-a.sab-cur { color:var(--sab-black); }
/* Right: lang + CTA */
.sab-nav-right { display:flex; align-items:center; gap:.55rem; justify-content:flex-end; }
.sab-lang-btn { font-family:'Work Sans',sans-serif; font-size:0.7rem; font-weight:600; color:var(--sab-stone); padding:.2rem .5rem; border:1px solid var(--sab-line); border-radius:2px; display:flex; align-items:center; gap:.2rem; transition:all var(--sab-ease); }
.sab-lang-btn svg { width:9px; height:9px; }
.sab-lang-btn:hover { color:var(--sab-teal); border-color:var(--sab-teal-md); }
.sab-nav-cta { font-family:'Work Sans',sans-serif; font-size:0.82rem; font-weight:600; background:var(--sab-teal); color:var(--sab-black); padding:.38rem 1.1rem; border-radius:2px; transition:background var(--sab-ease); white-space:nowrap; display:inline-flex; }
.sab-nav-cta:hover { background:var(--sab-teal2); }
.sab-nav-mob-btn { display:none; width:36px; height:36px; align-items:center; justify-content:center; border-radius:2px; }
.sab-nav-mob-btn svg { width:20px; height:20px; color:var(--sab-black); }
/* Mobile drawer */
.sab-mob-drawer { display:none; position:fixed; inset:0; background:var(--sab-white); z-index:299; overflow-y:auto; padding:5rem var(--vessel-px) 2rem; }
.sab-mob-drawer.sab-drw-open { display:block; }
.sab-mob-x { position:absolute; top:1.2rem; right:1.5rem; width:36px; height:36px; background:var(--sab-sand); border-radius:2px; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:1.1rem; color:var(--sab-stone); }
.sab-mob-lnk { display:block; font-family:'Syne',sans-serif; font-size:1.4rem; font-weight:800; color:var(--sab-black); padding:.45rem 0; border-bottom:1px solid var(--sab-line2); }
.sab-mob-sub { display:block; font-family:'Work Sans',sans-serif; font-size:0.85rem; color:var(--sab-stone); padding:.3rem .75rem; }

/* =====================================================
   EDITORIAL LEFT HERO
   Left panel: massive slab headline + lead + CTAs
   Right panel: image filling remaining space
   Separated by a single hairline -- first in 30-site series
   ===================================================== */
.sab-frontier { display:grid; grid-template-columns:1fr 1fr; min-height:calc(100vh - var(--nav-h)); background:var(--sab-white); }
.sab-frontier-copy { padding:5rem 4rem 5rem var(--vessel-px); display:flex; flex-direction:column; justify-content:flex-end; border-right:1px solid var(--sab-line); position:relative; background:var(--sab-white); }
.sab-frontier-eyebrow { margin-bottom:2rem; }
.sab-frontier-h1 { font-family:'Syne',sans-serif; font-size:clamp(4rem,7vw,8.5rem); font-weight:800; color:var(--sab-black); line-height:.88; letter-spacing:-.03em; margin-bottom:1.5rem; }
.sab-frontier-h1 span { display:block; }
.sab-frontier-h1 em { color:var(--sab-teal); font-style:normal; }
.sab-frontier-lead { font-family:'Work Sans',sans-serif; font-size:0.96rem; font-weight:300; color:var(--sab-stone); max-width:40ch; line-height:1.88; margin-bottom:2.5rem; }
.sab-frontier-btns { display:flex; gap:.6rem; flex-wrap:wrap; }
.sab-frontier-meta { margin-top:auto; padding-top:3rem; display:flex; gap:3rem; }
.sab-frontier-stat { }
.sab-frontier-stat-n { font-family:'Syne',sans-serif; font-size:2.2rem; font-weight:800; color:var(--sab-teal); line-height:1; }
.sab-frontier-stat-l { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--sab-mist); margin-top:.2rem; }
/* Right image panel */
.sab-frontier-visual { position:relative; overflow:hidden; background:var(--sab-sand); }
.sab-frontier-visual img { width:100%; height:100%; object-fit:cover; }
/* Teal accent bar at top of hero */
.sab-frontier::before { content:''; display:block; position:absolute; top:0; left:0; width:100%; height:3px; background:var(--sab-teal); z-index:2; }

/* Ticker */
.sab-run { background:var(--sab-black); padding:.32rem 0; overflow:hidden; }
.sab-run-belt { display:flex; white-space:nowrap; animation:sab-run 45s linear infinite; }
@keyframes sab-run { 0%{transform:translateX(0)}100%{transform:translateX(-50%)} }
.sab-run-tok { font-family:'Work Sans',sans-serif; font-size:0.54rem; font-weight:600; color:rgba(255,255,255,.15); letter-spacing:.2em; text-transform:uppercase; padding:0 1.5rem; }
.sab-run-tok span { color:var(--sab-teal); opacity:.6; }

/* =====================================================
   SERVICES -- asymmetric masonry grid 3+3 (not equal grid)
   ===================================================== */
.sab-services-zone { padding:7rem 0; background:var(--sab-white); }
.sab-services-top { display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:1.5rem; margin-bottom:4rem; }
.sab-services-h2 { font-family:'Syne',sans-serif; font-size:clamp(3rem,8vw,7.5rem); font-weight:800; color:var(--sab-black); line-height:.88; letter-spacing:-.03em; }
.sab-services-h2 em { color:var(--sab-teal); font-style:italic; }
.sab-svc-row { display:grid; grid-template-columns:1fr 1fr 1fr; gap:1px; background:var(--sab-line); margin-bottom:1px; }
.sab-svc-tile { background:var(--sab-white); padding:2.5rem 2rem; display:block; text-decoration:none; position:relative; transition:background var(--sab-ease); }
.sab-svc-tile:hover { background:var(--sab-sand); }
.sab-svc-tile-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:1.8rem; }
.sab-svc-ico { width:32px; height:32px; color:var(--sab-teal); transition:color var(--sab-ease); }
.sab-svc-ico svg { width:100%; height:100%; }
.sab-svc-tile:hover .sab-svc-ico { color:var(--sab-black); }
.sab-svc-num { font-family:'Syne',sans-serif; font-size:2.5rem; font-weight:800; color:rgba(10,10,10,.07); line-height:1; }
.sab-svc-name { font-family:'Syne',sans-serif; font-size:1.05rem; font-weight:800; color:var(--sab-black); margin-bottom:.4rem; line-height:1.2; }
.sab-svc-tile:hover .sab-svc-name { color:var(--sab-teal2); }
.sab-svc-desc { font-family:'Work Sans',sans-serif; font-size:0.82rem; color:var(--sab-stone); line-height:1.8; margin-bottom:1.5rem; }
.sab-svc-footer { display:flex; align-items:baseline; justify-content:space-between; }
.sab-svc-price { font-family:'Syne',sans-serif; font-size:1.8rem; font-weight:800; color:var(--sab-black); line-height:1; letter-spacing:-.02em; }
.sab-svc-tile:hover .sab-svc-price { color:var(--sab-teal2); }
.sab-svc-del { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--sab-mist); }

/* =====================================================
   BIG STATS BAND (sand bg)
   ===================================================== */
.sab-stats-band { background:var(--sab-sand); padding:4rem 0; }
.sab-stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.sab-stat-unit { padding:1.5rem 2rem; border-right:1px solid rgba(10,10,10,.08); }
.sab-stat-unit:last-child { border-right:none; }
.sab-stat-n { font-family:'Syne',sans-serif; font-size:3.5rem; font-weight:800; color:var(--sab-black); line-height:1; letter-spacing:-.04em; }
.sab-stat-n em { color:var(--sab-teal); font-style:normal; }
.sab-stat-label { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--sab-mist); margin-top:.3rem; }

/* =====================================================
   ZIGZAG CASE STUDIES (alternating alignment)
   ===================================================== */
.sab-cases-zone { padding:7rem 0; background:var(--sab-white); }
.sab-cases-h2 { font-family:'Syne',sans-serif; font-size:clamp(3rem,8vw,7.5rem); font-weight:800; color:var(--sab-black); line-height:.88; letter-spacing:-.03em; margin-bottom:5rem; }
.sab-cases-h2 em { color:var(--sab-teal); font-style:italic; }
.sab-case-row { display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--sab-line); }
.sab-case-row.sab-alt { direction:rtl; }
.sab-case-row.sab-alt > * { direction:ltr; }
.sab-case-visual { aspect-ratio:5/4; overflow:hidden; background:var(--sab-sand); }
.sab-case-visual img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.sab-case-row:hover .sab-case-visual img { transform:scale(1.03); }
.sab-case-content { padding:4rem; display:flex; flex-direction:column; justify-content:space-between; border-left:1px solid var(--sab-line); }
.sab-case-row.sab-alt .sab-case-content { border-left:none; border-right:1px solid var(--sab-line); }
.sab-case-kpi { font-family:'Syne',sans-serif; font-size:5rem; font-weight:800; color:var(--sab-teal); line-height:1; letter-spacing:-.04em; }
.sab-case-kpi-l { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--sab-mist); }
.sab-case-svc { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--sab-teal); margin-top:2rem; margin-bottom:.25rem; }
.sab-case-title { font-family:'Syne',sans-serif; font-size:1.4rem; font-weight:800; color:var(--sab-black); line-height:1.2; margin-bottom:.6rem; }
.sab-case-body { font-family:'Work Sans',sans-serif; font-size:0.86rem; font-weight:300; color:var(--sab-stone); line-height:1.9; }

/* =====================================================
   TESTIMONIALS (3-col text-only, black bg)
   ===================================================== */
.sab-praise-zone { padding:7rem 0; background:var(--sab-black); }
.sab-praise-h2 { font-family:'Syne',sans-serif; font-size:clamp(3rem,8vw,7.5rem); font-weight:800; color:#fff; line-height:.88; letter-spacing:-.03em; margin-bottom:4rem; }
.sab-praise-h2 em { color:var(--sab-teal); font-style:italic; }
.sab-praise-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:0; border-top:1px solid rgba(255,255,255,.06); }
.sab-praise-card { padding:2.5rem; border-right:1px solid rgba(255,255,255,.06); }
.sab-praise-card:last-child { border-right:none; }
.sab-praise-q { font-family:'Syne',sans-serif; font-size:2.5rem; font-weight:800; color:var(--sab-teal); line-height:1; opacity:.25; margin-bottom:.3rem; }
.sab-praise-body { font-family:'Work Sans',sans-serif; font-size:0.9rem; color:rgba(255,255,255,.55); line-height:1.9; margin-bottom:2rem; font-style:italic; }
.sab-praise-sig { font-family:'Work Sans',sans-serif; font-size:0.68rem; font-weight:600; color:rgba(255,255,255,.25); }
.sab-praise-win { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--sab-teal); opacity:.7; margin-top:.2rem; }

/* =====================================================
   PROCESS -- numbered timeline with teal connector
   ===================================================== */
.sab-process-zone { padding:7rem 0; background:var(--sab-sand); }
.sab-process-h2 { font-family:'Syne',sans-serif; font-size:clamp(3rem,8vw,7.5rem); font-weight:800; color:var(--sab-black); line-height:.88; letter-spacing:-.03em; margin-bottom:4rem; }
.sab-process-h2 em { color:var(--sab-teal); font-style:italic; }
.sab-proc-steps { display:grid; grid-template-columns:repeat(6,1fr); gap:0; position:relative; }
.sab-proc-steps::before { content:''; position:absolute; top:20px; left:10%; right:10%; height:1px; background:var(--sab-teal); opacity:.3; }
.sab-proc-step { padding:0 1.5rem 0 0; text-align:left; position:relative; }
.sab-proc-no { width:40px; height:40px; background:var(--sab-teal); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Syne',sans-serif; font-size:0.82rem; font-weight:800; color:var(--sab-black); margin-bottom:1.2rem; position:relative; z-index:2; flex-shrink:0; }
.sab-proc-ttl { font-family:'Syne',sans-serif; font-size:0.95rem; font-weight:800; color:var(--sab-black); margin-bottom:.3rem; line-height:1.25; }
.sab-proc-desc { font-family:'Work Sans',sans-serif; font-size:0.78rem; color:var(--sab-stone); line-height:1.8; }

/* =====================================================
   PRICING TABLE
   ===================================================== */
.sab-rates-zone { padding:7rem 0; background:var(--sab-white); }
.sab-rates-h2 { font-family:'Syne',sans-serif; font-size:clamp(3rem,8vw,7.5rem); font-weight:800; color:var(--sab-black); line-height:.88; letter-spacing:-.03em; margin-bottom:4rem; }
.sab-rates-h2 em { color:var(--sab-teal); font-style:italic; }
.sab-ptbl { width:100%; border-collapse:separate; border-spacing:0; border:1.5px solid var(--sab-line); border-radius:2px; overflow:hidden; }
.sab-ptbl th { font-family:'Work Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--sab-mist); background:var(--sab-sand); padding:.75rem 1.5rem; text-align:left; border-bottom:1.5px solid var(--sab-line); }
.sab-ptbl td { padding:1.1rem 1.5rem; border-bottom:1px solid var(--sab-line2); vertical-align:middle; }
.sab-ptbl tr:last-child td { border-bottom:none; }
.sab-ptbl tr:hover td { background:var(--sab-teal-lo); }
.sab-ptbl tr:hover .sab-ptnm { color:var(--sab-teal2); }
.sab-ptbl tr:hover .sab-ptpr { color:var(--sab-teal2); }
.sab-ptnm { font-family:'Syne',sans-serif; font-size:0.98rem; font-weight:800; color:var(--sab-black); transition:color var(--sab-ease); }
.sab-ptdel { font-family:'Work Sans',sans-serif; font-size:0.6rem; color:var(--sab-mist); }
.sab-ptpr { font-family:'Syne',sans-serif; font-size:1.5rem; font-weight:800; color:var(--sab-black); transition:color var(--sab-ease); letter-spacing:-.02em; }
.sab-ptlnk a { font-family:'Work Sans',sans-serif; font-size:0.66rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; color:var(--sab-teal); }

/* =====================================================
   FAQ -- 2-column category layout
   ===================================================== */
.sab-faq-zone { padding:7rem 0; background:var(--sab-sand); }
.sab-faq-h2 { font-family:'Syne',sans-serif; font-size:clamp(3rem,8vw,7.5rem); font-weight:800; color:var(--sab-black); line-height:.88; letter-spacing:-.03em; margin-bottom:4rem; }
.sab-faq-h2 em { color:var(--sab-teal); font-style:italic; }
.sab-faq-cols { display:grid; grid-template-columns:1fr 1fr; gap:4rem; }
.sab-faq-item { border-bottom:1px solid rgba(10,10,10,.08); }
.sab-faq-btn { width:100%; display:flex; justify-content:space-between; align-items:flex-start; gap:2rem; padding:1rem 0; background:none; border:none; cursor:pointer; text-align:left; }
.sab-fq { font-family:'Syne',sans-serif; font-size:0.96rem; font-weight:800; color:var(--sab-black); line-height:1.35; }
.sab-fq-tog { font-family:'Syne',sans-serif; font-size:1.4rem; font-weight:800; color:var(--sab-mist); flex-shrink:0; transition:transform .2s,color .2s; }
.sab-faq-item.sab-fq-open .sab-fq-tog { transform:rotate(45deg); color:var(--sab-teal); }
.sab-faq-ans { max-height:0; overflow:hidden; transition:max-height .35s ease; }
.sab-faq-item.sab-fq-open .sab-faq-ans { max-height:400px; }
.sab-faq-a { font-family:'Work Sans',sans-serif; font-size:0.88rem; color:var(--sab-stone); line-height:1.9; padding:0 0 1rem; }

/* =====================================================
   BUILDER PAGE
   ===================================================== */
.sab-build-pg { padding:5rem 0 6rem; background:var(--sab-white); min-height:100vh; }
.sab-build-h1 { font-family:'Syne',sans-serif; font-size:clamp(3.5rem,8vw,8rem); font-weight:800; color:var(--sab-black); line-height:.85; letter-spacing:-.03em; margin-bottom:.4rem; }
.sab-build-h1 em { color:var(--sab-teal); font-style:italic; }
.sab-build-sub { font-family:'Work Sans',sans-serif; font-size:0.96rem; font-weight:300; color:var(--sab-stone); max-width:44ch; line-height:1.82; margin:.5rem 0 3rem; }
.sab-build-cols { display:grid; grid-template-columns:1.7fr 1fr; gap:4rem; align-items:start; }
.sab-build-step { margin-bottom:2.5rem; }
.sab-build-step-hd { display:flex; align-items:center; gap:.6rem; padding-bottom:.5rem; border-bottom:2px solid var(--sab-teal); margin-bottom:1rem; }
.sab-build-step-no { font-family:'Syne',sans-serif; font-size:2rem; font-weight:800; color:rgba(10,10,10,.08); line-height:1; }
.sab-build-step-lbl { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--sab-stone); }
/* Service picker */
.sab-pick-list { display:flex; flex-direction:column; gap:.25rem; }
.sab-pick-item { display:flex; justify-content:space-between; align-items:center; padding:.85rem 1rem; border:1.5px solid var(--sab-line); border-radius:2px; cursor:pointer; user-select:none; background:var(--sab-white); transition:all var(--sab-ease); }
.sab-pick-item:hover { border-color:var(--sab-teal-md); background:var(--sab-teal-lo); }
.sab-pick-item.sab-chosen { border-color:var(--sab-teal); background:var(--sab-teal-lo); }
.sab-pick-lhs { display:flex; align-items:flex-start; gap:.5rem; }
.sab-pick-dot { width:12px; height:12px; border:1.5px solid var(--sab-mist); border-radius:50%; flex-shrink:0; margin-top:4px; transition:all var(--sab-ease); }
.sab-pick-item.sab-chosen .sab-pick-dot { background:var(--sab-teal); border-color:var(--sab-teal); }
.sab-pick-name { font-family:'Syne',sans-serif; font-size:0.88rem; font-weight:800; color:var(--sab-black); }
.sab-pick-item.sab-chosen .sab-pick-name { color:var(--sab-teal2); }
.sab-pick-inf { font-family:'Work Sans',sans-serif; font-size:0.58rem; color:var(--sab-mist); }
.sab-pick-price { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:800; color:var(--sab-black); letter-spacing:-.02em; }
.sab-pick-item.sab-chosen .sab-pick-price { color:var(--sab-teal2); }
/* Addons */
.sab-addon-row { display:flex; justify-content:space-between; align-items:center; border:1.5px solid var(--sab-line); border-radius:2px; padding:.6rem .9rem; cursor:pointer; user-select:none; transition:border-color var(--sab-ease); margin-bottom:.25rem; background:var(--sab-white); }
.sab-addon-row:hover { border-color:var(--sab-teal-md); }
.sab-addon-row.sab-addon-on { border-color:var(--sab-teal); background:var(--sab-teal-lo); }
.sab-addon-lhs { display:flex; align-items:center; gap:.4rem; }
.sab-addon-box { width:14px; height:14px; border:1.5px solid var(--sab-mist); border-radius:2px; display:flex; align-items:center; justify-content:center; transition:all var(--sab-ease); flex-shrink:0; }
.sab-addon-row.sab-addon-on .sab-addon-box { background:var(--sab-teal); border-color:var(--sab-teal); }
.sab-addon-row.sab-addon-on .sab-addon-box::after { content:'\2713'; font-size:0.52rem; color:var(--sab-black); font-weight:900; font-family:sans-serif; }
.sab-addon-nm { font-family:'Work Sans',sans-serif; font-size:0.86rem; font-weight:500; color:var(--sab-stone); }
.sab-addon-pr { font-family:'Syne',sans-serif; font-size:1rem; font-weight:800; color:var(--sab-black); letter-spacing:-.02em; }
.sab-addon-row.sab-addon-on .sab-addon-pr { color:var(--sab-teal2); }
/* Hours */
.sab-hrs-wrap { background:var(--sab-black); border-radius:2px; padding:1.5rem; }
.sab-hrs-ttl { font-family:'Syne',sans-serif; font-size:0.95rem; font-weight:800; color:#fff; }
.sab-hrs-sub { font-family:'Work Sans',sans-serif; font-size:0.62rem; color:rgba(255,255,255,.3); margin-bottom:.8rem; }
.sab-hrs-ctrl { display:flex; align-items:center; gap:.9rem; }
.sab-hrs-dig { font-family:'Syne',sans-serif; font-size:2.8rem; font-weight:800; color:var(--sab-teal); min-width:2ch; text-align:center; line-height:1; }
.sab-hrs-range { -webkit-appearance:none; appearance:none; flex:1; height:2px; background:rgba(255,255,255,.1); outline:none; cursor:pointer; border-radius:2px; }
.sab-hrs-range::-webkit-slider-thumb { -webkit-appearance:none; width:14px; height:14px; background:var(--sab-teal); cursor:pointer; border-radius:50%; }
.sab-hrs-rate { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:800; color:#fff; }
.sab-hrs-rate-l { font-family:'Work Sans',sans-serif; font-size:0.52rem; color:rgba(255,255,255,.25); }
/* Summary */
.sab-sumbox { background:var(--sab-black); border-radius:2px; padding:2rem; position:sticky; top:calc(var(--nav-h) + 1.5rem); }
.sab-sum-lbl { font-family:'Work Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.2); padding-bottom:.6rem; border-bottom:1px solid rgba(255,255,255,.06); margin-bottom:.6rem; }
.sab-sum-body { min-height:50px; margin-bottom:.6rem; }
.sab-sum-row { display:flex; justify-content:space-between; gap:1rem; font-family:'Work Sans',sans-serif; font-size:0.72rem; color:rgba(255,255,255,.4); padding:.2rem 0; border-bottom:1px solid rgba(255,255,255,.04); }
.sab-sum-rv { font-family:'Syne',sans-serif; font-size:0.95rem; font-weight:800; color:#fff; }
.sab-sum-empty { font-family:'Work Sans',sans-serif; font-size:0.85rem; font-style:italic; color:rgba(255,255,255,.2); }
.sab-sum-total { display:flex; justify-content:space-between; align-items:baseline; border-top:1px solid rgba(255,255,255,.07); padding-top:.7rem; margin-top:.3rem; }
.sab-sum-total-l { font-family:'Work Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.2); }
.sab-sum-total-v { font-family:'Syne',sans-serif; font-size:3.2rem; font-weight:800; color:var(--sab-teal); line-height:1; letter-spacing:-.04em; }
.sab-sum-go { width:100%; background:var(--sab-teal); color:var(--sab-black); font-family:'Work Sans',sans-serif; font-size:0.9rem; font-weight:600; padding:.9rem; border:none; cursor:pointer; border-radius:2px; margin-top:1rem; transition:background var(--sab-ease); }
.sab-sum-go:hover { background:var(--sab-teal2); }
.sab-sum-go:disabled { opacity:.2; pointer-events:none; }

/* =====================================================
   CHECKOUT
   ===================================================== */
.sab-co-pg { padding:5rem 0; min-height:100vh; background:var(--sab-white); }
.sab-co-h1 { font-family:'Syne',sans-serif; font-size:clamp(3rem,7vw,7.5rem); font-weight:800; color:var(--sab-black); line-height:.85; letter-spacing:-.03em; margin-bottom:.4rem; }
.sab-co-h1 em { color:var(--sab-teal); font-style:italic; }
.sab-co-sub { font-family:'Work Sans',sans-serif; font-size:0.92rem; font-weight:300; color:var(--sab-stone); max-width:44ch; margin:.5rem 0 2.5rem; line-height:1.82; }
.sab-co-cols { display:grid; grid-template-columns:1.5fr 1fr; gap:4rem; align-items:start; }
.sab-fld { display:flex; flex-direction:column; gap:.15rem; margin-bottom:.5rem; }
.sab-flbl { font-family:'Work Sans',sans-serif; font-size:0.52rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--sab-stone); }
.sab-finp,.sab-fsel,.sab-fta { background:var(--sab-white); border:1.5px solid var(--sab-line); border-radius:2px; padding:.72rem 1rem; color:var(--sab-black); font-family:'Work Sans',sans-serif; font-size:0.92rem; outline:none; width:100%; transition:border-color var(--sab-ease); }
.sab-finp:focus,.sab-fsel:focus,.sab-fta:focus { border-color:var(--sab-teal); }
.sab-fpair { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; }
.sab-ftos { display:flex; gap:.5rem; align-items:flex-start; font-family:'Work Sans',sans-serif; font-size:0.8rem; color:var(--sab-stone); cursor:pointer; margin:.8rem 0; line-height:1.65; }
.sab-ftos a { color:var(--sab-teal2); }
.sab-ftos input { accent-color:var(--sab-teal); flex-shrink:0; margin-top:3px; }
.sab-pay-btn { width:100%; background:var(--sab-teal); color:var(--sab-black); font-family:'Work Sans',sans-serif; font-size:0.9rem; font-weight:600; padding:1rem; border:none; cursor:pointer; border-radius:2px; transition:background var(--sab-ease); display:flex; align-items:center; justify-content:space-between; }
.sab-pay-btn:hover { background:var(--sab-teal2); }
.sab-order-box { background:var(--sab-black); border-radius:2px; padding:2rem; position:sticky; top:calc(var(--nav-h) + 2rem); }
.sab-order-lbl { font-family:'Work Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.2); padding-bottom:.5rem; border-bottom:1px solid rgba(255,255,255,.05); margin-bottom:.5rem; }
.sab-order-row { display:flex; justify-content:space-between; gap:1rem; font-family:'Work Sans',sans-serif; font-size:0.72rem; color:rgba(255,255,255,.35); padding:.2rem 0; border-bottom:1px solid rgba(255,255,255,.04); }
.sab-order-rv { font-family:'Syne',sans-serif; font-size:0.95rem; font-weight:800; color:#fff; }
.sab-order-total { font-family:'Syne',sans-serif; font-size:3rem; font-weight:800; color:var(--sab-teal); line-height:1; letter-spacing:-.04em; }

/* =====================================================
   MASTHEAD (inner pages) -- CENTERED
   ===================================================== */
.sab-mast { padding:6rem 0 5rem; background:var(--sab-black); position:relative; overflow:hidden; text-align:center; }
.sab-mast::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--sab-teal); }
.sab-mast-inner { position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; }
.sab-mast-h1 { font-family:'Syne',sans-serif; font-size:clamp(4rem,12vw,11rem); font-weight:800; color:#fff; line-height:.84; letter-spacing:-.04em; text-align:center; }
.sab-mast-h1 em { color:var(--sab-teal); font-style:italic; }
.sab-mast-sub { font-family:'Work Sans',sans-serif; font-size:0.96rem; font-weight:300; color:rgba(255,255,255,.4); max-width:46ch; line-height:1.9; margin-top:.8rem; text-align:center; }

/* =====================================================
   SERVICE DETAIL PAGE
   ===================================================== */
.sab-svc-detail { padding:5rem 0 6rem; background:var(--sab-white); }
.sab-svc-det-grid { display:grid; grid-template-columns:2fr 1fr; gap:5rem; }
.sab-svc-body p { font-family:'Work Sans',sans-serif; font-size:0.91rem; color:var(--sab-stone); line-height:1.9; margin-bottom:.85rem; }
.sab-svc-body h3 { font-family:'Syne',sans-serif; font-size:1.4rem; font-weight:800; color:var(--sab-black); margin:2.5rem 0 .6rem; line-height:1.1; }
.sab-svc-callout { border-left:3px solid var(--sab-teal); padding:.7rem 1.1rem; background:var(--sab-teal-lo); margin-bottom:.5rem; border-radius:0 2px 2px 0; font-family:'Work Sans',sans-serif; font-size:0.88rem; color:var(--sab-stone); line-height:1.65; }
.sab-incl-it { display:flex; gap:.4rem; align-items:flex-start; font-family:'Work Sans',sans-serif; font-size:0.82rem; color:var(--sab-stone); padding:.18rem 0; }
.sab-incl-it::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--sab-teal); flex-shrink:0; margin-top:7px; }
.sab-price-card { background:var(--sab-black); border-radius:2px; padding:2rem; margin-bottom:1rem; }
.sab-pc-lbl { font-family:'Work Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.3); }
.sab-pc-amt { font-family:'Syne',sans-serif; font-size:4rem; font-weight:800; color:var(--sab-teal); line-height:1; letter-spacing:-.04em; }
.sab-pc-del { font-family:'Work Sans',sans-serif; font-size:0.56rem; font-weight:600; color:rgba(255,255,255,.25); letter-spacing:.1em; text-transform:uppercase; margin-bottom:1.5rem; }
.sab-img-frame { aspect-ratio:4/3; border-radius:2px; overflow:hidden; background:var(--sab-sand); }
.sab-img-frame img { width:100%; height:100%; object-fit:cover; }

/* =====================================================
   LEGAL
   ===================================================== */
.sab-legal-pg { padding:5rem 0; background:var(--sab-white); }
.sab-legal-doc { max-width:760px; }
.sab-legal-doc h2 { font-family:'Syne',sans-serif; font-size:1.2rem; font-weight:800; color:var(--sab-black); margin:2.5rem 0 .5rem; padding-top:2rem; border-top:1px solid var(--sab-line); }
.sab-legal-doc h2:first-child { margin-top:0; padding-top:0; border:none; }
.sab-legal-doc p { font-family:'Work Sans',sans-serif; font-size:0.88rem; color:var(--sab-stone); line-height:1.9; margin-bottom:.85rem; }
.sab-legal-doc ul { font-family:'Work Sans',sans-serif; font-size:0.88rem; color:var(--sab-stone); padding-left:1.5rem; list-style:disc; margin-bottom:.85rem; line-height:1.8; }
.sab-legal-doc a { color:var(--sab-teal2); }
.sab-legal-meta { font-family:'Work Sans',sans-serif; font-size:0.72rem; color:var(--sab-mist); margin-bottom:2rem; padding-bottom:.8rem; border-bottom:1px solid var(--sab-line); }

/* =====================================================
   FOOTER
   ===================================================== */
.sab-foot { background:var(--sab-black); padding:5.5rem 0 3rem; }
.sab-foot-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:3rem; padding-bottom:4rem; border-bottom:1px solid rgba(255,255,255,.05); margin-bottom:2rem; }
.sab-foot-brand { font-family:'Syne',sans-serif; font-size:1.2rem; font-weight:800; color:#fff; margin-bottom:.4rem; letter-spacing:-.01em; }
.sab-foot-brand em { color:var(--sab-teal); font-style:normal; }
.sab-foot-blurb { font-family:'Work Sans',sans-serif; font-size:0.72rem; color:rgba(255,255,255,.2); max-width:22ch; line-height:1.82; margin-bottom:.8rem; }
.sab-foot-biz { font-family:'Work Sans',sans-serif; font-size:0.62rem; color:rgba(255,255,255,.13); line-height:2.2; }
.sab-foot-biz a { color:rgba(255,255,255,.13); transition:color var(--sab-ease); }
.sab-foot-biz a:hover { color:var(--sab-teal); }
.sab-foot-col-h { font-family:'Work Sans',sans-serif; font-size:0.5rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.2); margin-bottom:.9rem; }
.sab-foot-nav { display:flex; flex-direction:column; gap:.45rem; }
.sab-foot-nav a { font-family:'Work Sans',sans-serif; font-size:0.75rem; color:rgba(255,255,255,.16); transition:color var(--sab-ease); }
.sab-foot-nav a:hover { color:var(--sab-teal); }
.sab-foot-btm { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.sab-foot-copy { font-family:'Work Sans',sans-serif; font-size:0.62rem; color:rgba(255,255,255,.09); }
.sab-foot-legal { display:flex; gap:1.2rem; }
.sab-foot-legal a { font-family:'Work Sans',sans-serif; font-size:0.62rem; color:rgba(255,255,255,.09); transition:color var(--sab-ease); }
.sab-foot-legal a:hover { color:var(--sab-teal); }

/* =====================================================
   COOKIE & CHAT
   ===================================================== */
.sab-cookie { position:fixed; bottom:0; left:0; right:0; z-index:400; background:var(--sab-black2); border-top:2px solid var(--sab-teal); padding:.6rem var(--vessel-px); display:flex; align-items:center; justify-content:center; gap:2rem; flex-wrap:wrap; transition:transform .3s; }
.sab-cookie.sab-ck-gone { transform:translateY(110%); pointer-events:none; }
.sab-ck-txt { font-family:'Work Sans',sans-serif; font-size:0.72rem; color:rgba(255,255,255,.4); }
.sab-ck-txt a { color:var(--sab-teal); }
.sab-ck-actions { display:flex; gap:.4rem; }
.sab-ck-yes { background:var(--sab-teal); color:var(--sab-black); font-family:'Work Sans',sans-serif; font-size:0.64rem; font-weight:600; padding:.32rem .9rem; border:none; cursor:pointer; border-radius:2px; }
.sab-ck-no  { background:transparent; color:rgba(255,255,255,.3); font-family:'Work Sans',sans-serif; font-size:0.64rem; padding:.32rem .75rem; border:1px solid rgba(255,255,255,.1); cursor:pointer; border-radius:2px; }
.sab-chat-fab { position:fixed; bottom:4.5rem; right:2rem; z-index:399; width:48px; height:48px; background:var(--sab-teal); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; border:none; box-shadow:0 4px 20px rgba(0,201,167,.35); transition:transform .2s; }
.sab-chat-fab:hover { transform:scale(1.08); }
.sab-chat-fab svg { width:18px; height:18px; color:var(--sab-black); }
.sab-chat-win { position:fixed; bottom:7.5rem; right:2rem; z-index:399; width:290px; background:var(--sab-white); border:1px solid var(--sab-line); border-top:2px solid var(--sab-teal); border-radius:2px; box-shadow:0 12px 40px rgba(10,10,10,.15); opacity:0; pointer-events:none; transform:translateY(6px) scale(.97); transform-origin:bottom right; transition:opacity .2s,transform .2s; }
.sab-chat-win.sab-chat-vis { opacity:1; pointer-events:auto; transform:none; }
.sab-chat-top { padding:.7rem 1rem; background:var(--sab-sand); display:flex; justify-content:space-between; align-items:center; }
.sab-chat-dot { width:7px; height:7px; border-radius:50%; background:var(--sab-teal); animation:sab-blink 2s infinite; }
@keyframes sab-blink { 0%,100%{opacity:1}50%{opacity:.3} }
.sab-chat-name { font-family:'Syne',sans-serif; font-size:0.9rem; font-weight:800; color:var(--sab-black); }
.sab-chat-role { font-family:'Work Sans',sans-serif; font-size:0.52rem; color:var(--sab-mist); }
.sab-chat-x { background:none; border:none; cursor:pointer; color:var(--sab-mist); }
.sab-chat-log { padding:.7rem; height:145px; overflow-y:auto; display:flex; flex-direction:column; gap:.38rem; }
.sab-chat-msg { max-width:92%; padding:.38rem .78rem; font-family:'Work Sans',sans-serif; font-size:0.74rem; line-height:1.55; border-radius:2px; }
.sab-chat-msg--bot { background:var(--sab-sand); color:var(--sab-stone); align-self:flex-start; }
.sab-chat-msg--me  { background:var(--sab-teal); color:var(--sab-black); font-weight:500; align-self:flex-end; }
.sab-chat-form { display:flex; border-top:1px solid var(--sab-line2); }
.sab-chat-inp { flex:1; background:none; border:none; padding:.5rem .78rem; font-family:'Work Sans',sans-serif; font-size:0.74rem; color:var(--sab-stone); outline:none; }
.sab-chat-send { background:var(--sab-teal); color:var(--sab-black); border:none; padding:0 .78rem; font-family:'Work Sans',sans-serif; font-size:0.62rem; font-weight:600; cursor:pointer; border-radius:2px; }

/* =====================================================
   CONFIRM PAGES
   ===================================================== */
.sab-confirm-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:6rem 2rem; background:var(--sab-sand); }
.sab-confirm-box { max-width:440px; width:100%; background:var(--sab-white); border-radius:2px; border-top:3px solid var(--sab-teal); padding:3.5rem; text-align:center; border:1px solid var(--sab-line); }

/* -- Reveal -- */
.sab-rv { opacity:0; transform:translateY(14px); transition:opacity .5s ease,transform .5s ease; }
.sab-rv.sab-vis { opacity:1; transform:none; }
.sab-d1{transition-delay:.07s}.sab-d2{transition-delay:.14s}.sab-d3{transition-delay:.21s}

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media(max-width:1100px) {
  .sab-frontier { grid-template-columns:1fr; min-height:auto; }
  .sab-frontier-visual { display:none; }
  .sab-nav-center { display:none; }
  .sab-nav-mob-btn { display:flex; }
  .sab-svc-row { grid-template-columns:1fr 1fr; }
  .sab-case-row { grid-template-columns:1fr; }
  .sab-case-visual { display:none; }
  .sab-praise-3 { grid-template-columns:1fr 1fr; }
  .sab-proc-steps { grid-template-columns:1fr 1fr; }
  .sab-proc-steps::before { display:none; }
  .sab-foot-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .sab-build-cols,.sab-co-cols { grid-template-columns:1fr; }
  .sab-svc-det-grid { grid-template-columns:1fr; }
  .sab-faq-cols { grid-template-columns:1fr; }
  .sab-stats-row { grid-template-columns:1fr 1fr; }
}
@media(max-width:720px) {
  :root { --vessel-px:1.25rem; }
  .sab-svc-row { grid-template-columns:1fr; }
  .sab-praise-3 { grid-template-columns:1fr; }
  .sab-proc-steps { grid-template-columns:1fr; }
  .sab-foot-grid { grid-template-columns:1fr; }
  .sab-fpair { grid-template-columns:1fr; }
}
