/*
  seoexpertpath.com (Build 56) | SEO Agency | Cologne, Germany | EUR | English
  LEFT SIDEBAR NAV - FIRST IN 56 BUILDS! Changes entire page architecture!
  Theme: Deep Slate #1C2B3A + Terracotta #C4664E + Warm Cream #F7F3EE (FIRST terracotta in 56!)
  Fonts: Syne (heading) + Manrope (body) - BOTH FIRST IN 56!
  Hero: OVERSIZED TYPOGRAPHY on cream (FIRST in 56!)
  Services: DIAGONAL CORNER ACCENT CARDS (FIRST in 56!)
  Pricing: COMPARISON TABLE format (FIRST in 56!)
  Testimonials: NEWSPAPER COLUMN format (FIRST in 56!)
  FAQ: TWO-COLUMN ACCORDION (FIRST in 56!)
  CSS prefix: sep-
*/
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Manrope:wght@300;400;500;600;700&display=swap');

:root {
  --sep-slate:   #1C2B3A;
  --sep-slate2:  #152130;
  --sep-slate3:  #243547;
  --sep-slatet:  rgba(28,43,58,.9);
  --sep-terra:   #C4664E;
  --sep-terra2:  #A85540;
  --sep-terrat:  rgba(196,102,78,.12);
  --sep-terrat2: rgba(196,102,78,.20);
  --sep-cream:   #F7F3EE;
  --sep-cream2:  #EDE8E1;
  --sep-white:   #FFFFFF;
  --sep-ink:     #1C2B3A;
  --sep-mid:     #4A5568;
  --sep-muted:   #8896A8;
  --sep-border:  #E4DED7;
  --sep-border2: #D4CEC7;
  --sep-max:     1060px;
  --sep-rail-w:  240px;
  --sep-r:       4px;
  --sep-r2:      8px;
  --sep-r3:      16px;
  --sep-r4:      24px;
  --sep-rp:      100px;
  --sep-fh:      'Syne', system-ui, sans-serif;
  --sep-fb:      'Manrope', system-ui, sans-serif;
  --sep-ease:    all 0.22s cubic-bezier(.4,0,.2,1);
  --sep-sh:      0 4px 20px rgba(28,43,58,.08);
  --sep-sh2:     0 12px 48px rgba(28,43,58,.14);
  --sep-tsh:     0 6px 24px rgba(196,102,78,.2);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--sep-cream); color:var(--sep-ink); font-family:var(--sep-fb); font-size:1rem; line-height:1.72; overflow-x:hidden; }
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
input,textarea,select { font-family:inherit; }
address { font-style:normal; }

h1 { font-family:var(--sep-fh); font-size:clamp(2.8rem,5.5vw,7rem); font-weight:800; line-height:1.02; letter-spacing:-.025em; }
h2 { font-family:var(--sep-fh); font-size:clamp(1.9rem,3vw,3.2rem); font-weight:700; line-height:1.1; letter-spacing:-.015em; }
h3 { font-family:var(--sep-fh); font-size:1.1rem; font-weight:700; }
p  { font-size:.92rem; line-height:1.82; color:var(--sep-mid); }

/* ============================================================
   LEFT SIDEBAR LAYOUT - FIRST IN 56 BUILDS!
   Entire page architecture: 240px fixed rail + fluid content body
   ============================================================ */
.sep-layout { display:flex; min-height:100vh; }

/* THE SIDEBAR RAIL */
.sep-rail { width:var(--sep-rail-w); flex-shrink:0; position:fixed; left:0; top:0; bottom:0; background:var(--sep-slate); display:flex; flex-direction:column; z-index:200; overflow-y:auto; border-right:1px solid rgba(255,255,255,.04); }
.sep-rail-head { padding:1.8rem 1.4rem 1rem; border-bottom:1px solid rgba(255,255,255,.06); }
/* BIGGER LOGO in sidebar (new requirement!) */
.sep-rail-logo { display:block; font-family:var(--sep-fh); font-size:1.1rem; font-weight:800; color:var(--sep-cream); letter-spacing:-.02em; line-height:1.2; }
.sep-rail-logo em { font-style:normal; color:var(--sep-terra); }
.sep-rail-tagline { font-size:.54rem; color:rgba(255,255,255,.2); text-transform:uppercase; letter-spacing:.18em; margin-top:.3rem; }
.sep-rail-nav { flex:1; padding:1.2rem 0; }
.sep-rnl { display:flex; align-items:center; gap:.55rem; font-family:var(--sep-fb); font-size:1.0rem; font-weight:600; color:rgba(255,255,255,.4); padding:.56rem 1.4rem; transition:var(--sep-ease); position:relative; }
.sep-rnl:hover { color:rgba(255,255,255,.82); background:rgba(255,255,255,.04); }
.sep-rnl.sep-on { color:var(--sep-cream); font-weight:600; }
.sep-rnl.sep-on::before { content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); width:3px; height:18px; background:var(--sep-terra); border-radius:0 2px 2px 0; }
.sep-rnl svg { flex-shrink:0; }
.sep-rail-svc-h { font-family:var(--sep-fb); font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.28em; color:rgba(255,255,255,.15); padding:.7rem 1.4rem .3rem; }
.sep-rail-svc-lk { display:flex; align-items:center; gap:.4rem; font-size:.76rem; color:rgba(255,255,255,.26); padding:.32rem 1.4rem .32rem 2rem; transition:color .14s; }
.sep-rail-svc-lk:hover { color:var(--sep-terra); }
.sep-rail-foot { padding:1.2rem 1.4rem; border-top:1px solid rgba(255,255,255,.06); }
.sep-rail-soc { display:flex; gap:.4rem; margin-bottom:.8rem; }
.sep-rail-soc a { width:26px; height:26px; border:1px solid rgba(255,255,255,.1); border-radius:var(--sep-r); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.25); transition:var(--sep-ease); }
.sep-rail-soc a:hover { border-color:var(--sep-terra); color:var(--sep-terra); }
.sep-rail-ct a { display:flex; align-items:center; gap:.3rem; font-size:.62rem; color:rgba(255,255,255,.22); margin-bottom:.25rem; transition:color .14s; }
.sep-rail-ct a:hover { color:var(--sep-terra); }

/* MOBILE HAMBURGER + OVERLAY */
.sep-ham { display:none; position:fixed; top:1rem; left:1rem; z-index:300; width:40px; height:40px; background:var(--sep-slate); border-radius:var(--sep-r2); flex-direction:column; align-items:center; justify-content:center; gap:4px; box-shadow:var(--sep-sh); }
.sep-ham span { width:16px; height:1.5px; background:rgba(255,255,255,.7); border-radius:2px; display:block; transition:var(--sep-ease); }
.sep-mob-ov { position:fixed; inset:0; background:rgba(28,43,58,.55); z-index:190; opacity:0; pointer-events:none; transition:opacity .22s; }
.sep-mob-ov.sep-ov-on { opacity:1; pointer-events:auto; }
.sep-ham-close { display:none; color:rgba(255,255,255,.5); padding:.4rem; }

/* THE CONTENT BODY */
.sep-body { margin-left:var(--sep-rail-w); flex:1; min-width:0; background:var(--sep-cream); }

/* ============================================================
   OVERSIZED TYPOGRAPHY HERO (FIRST in 56 builds!)
   ============================================================ */
.sep-hero-type { background:var(--sep-cream); padding:7rem 3rem 5rem; position:relative; overflow:hidden; }
.sep-hero-type::before { content:''; position:absolute; top:-80px; right:-80px; width:400px; height:400px; border:1.5px solid var(--sep-border2); border-radius:50%; pointer-events:none; }
.sep-hero-type::after  { content:''; position:absolute; top:-20px; right:-20px; width:220px; height:220px; border:1.5px solid var(--sep-border); border-radius:50%; pointer-events:none; }
.sep-hero-eyebrow { display:inline-flex; align-items:center; gap:.55rem; font-family:var(--sep-fb); font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.26em; color:var(--sep-terra); margin-bottom:1.2rem; }
.sep-hero-eyebrow::after { content:''; width:40px; height:1.5px; background:var(--sep-terra); border-radius:2px; }
.sep-hero-hed { max-width:16ch; margin-bottom:1.6rem; position:relative; z-index:1; }
.sep-hero-hed .sep-terra-txt { color:var(--sep-terra); }
.sep-hero-sub { max-width:52ch; font-size:1.02rem; color:var(--sep-mid); line-height:1.82; margin-bottom:2.5rem; position:relative; z-index:1; }
.sep-hero-acts { display:flex; gap:.7rem; flex-wrap:wrap; margin-bottom:3.5rem; position:relative; z-index:1; }
.sep-hero-nums { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--sep-border); border:1px solid var(--sep-border); border-radius:var(--sep-r2); overflow:hidden; }
.sep-hero-stat { background:var(--sep-white); padding:1rem 1.2rem; }
.sep-hero-stat-n { font-family:var(--sep-fh); font-size:2rem; font-weight:800; color:var(--sep-slate); line-height:1; }
.sep-hero-stat-l { font-size:.56rem; color:var(--sep-muted); text-transform:uppercase; letter-spacing:.1em; margin-top:.2rem; }

/* ============================================================
   HORIZONTAL MARQUEE BAND (different from B55's lime ticker)
   ============================================================ */
.sep-band { background:var(--sep-slate); overflow:hidden; padding:.6rem 0; }
.sep-band-track { display:flex; width:max-content; animation:sepBand 40s linear infinite; }
.sep-band:hover .sep-band-track { animation-play-state:paused; }
@keyframes sepBand { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.sep-band-item { font-family:var(--sep-fh); font-size:.66rem; font-weight:600; color:rgba(255,255,255,.35); padding:0 2rem; white-space:nowrap; }
.sep-band-dot  { font-size:.66rem; color:var(--sep-terra); padding:0 .4rem; }

/* ============================================================
   DIAGONAL CORNER ACCENT SERVICE CARDS (FIRST in 56!)
   ============================================================ */
.sep-svc-mosaic { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--sep-border); margin-top:2rem; border:1px solid var(--sep-border); border-radius:var(--sep-r3); overflow:hidden; }
.sep-svc-card { background:var(--sep-white); padding:2rem 1.6rem; position:relative; overflow:hidden; transition:background .18s; display:block; }
.sep-svc-card:hover { background:var(--sep-cream); }
/* DIAGONAL CORNER ACCENT - FIRST in 56! */
.sep-svc-card::before { content:''; position:absolute; top:0; right:0; width:0; height:0; border-style:solid; border-width:0 52px 52px 0; border-color:transparent var(--sep-terra) transparent transparent; opacity:0; transition:opacity .18s; }
.sep-svc-card:hover::before { opacity:1; }
.sep-svc-card-num { font-family:var(--sep-fb); font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.22em; color:var(--sep-terra); margin-bottom:.5rem; }
.sep-svc-card-nm { font-family:var(--sep-fh); font-size:1rem; font-weight:700; color:var(--sep-slate); margin-bottom:.35rem; }
.sep-svc-card-brief { font-size:.78rem; color:var(--sep-mid); line-height:1.72; max-width:30ch; }
.sep-svc-card-ft { display:flex; align-items:center; justify-content:space-between; margin-top:.8rem; padding-top:.6rem; border-top:1px solid var(--sep-border); }
.sep-svc-card-price { font-family:var(--sep-fh); font-size:.9rem; font-weight:700; color:var(--sep-slate); }
.sep-svc-card-arr { color:var(--sep-terra); transition:transform .14s; }
.sep-svc-card:hover .sep-svc-card-arr { transform:translateX(4px); }

/* ============================================================
   NEWSPAPER COLUMN TESTIMONIALS (FIRST in 56!)
   ============================================================ */
.sep-testi-cols { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1.5px solid var(--sep-border2); border-radius:var(--sep-r3); overflow:hidden; margin-top:2rem; }
.sep-testi-col { padding:2rem 1.6rem; border-right:1.5px solid var(--sep-border2); position:relative; }
.sep-testi-col:last-child { border-right:none; }
.sep-testi-dropcap { font-family:var(--sep-fh); font-size:4.5rem; font-weight:800; color:var(--sep-terra); line-height:.85; float:left; margin:.12rem .4rem 0 0; }
.sep-testi-body { font-size:.84rem; color:var(--sep-mid); line-height:1.82; font-style:italic; overflow:hidden; margin-bottom:.9rem; }
.sep-testi-body::after { content:''; display:table; clear:both; }
.sep-testi-who { font-family:var(--sep-fh); font-size:.8rem; font-weight:700; color:var(--sep-slate); }
.sep-testi-role { font-size:.66rem; color:var(--sep-muted); margin-top:.12rem; }
.sep-testi-badge { display:inline-block; font-size:.54rem; font-weight:700; color:var(--sep-terra); background:var(--sep-terrat); border:1px solid var(--sep-terrat2); padding:.16rem .56rem; border-radius:var(--sep-rp); margin-top:.4rem; font-family:var(--sep-fb); }

/* ============================================================
   COMPARISON TABLE PRICING (FIRST in 56!)
   ============================================================ */
.sep-price-tbl { width:100%; border-collapse:collapse; margin-top:2rem; }
.sep-price-tbl thead tr th { padding:1.2rem 1.4rem; font-family:var(--sep-fh); }
.sep-price-tbl .sep-pt-empty { width:30%; }
.sep-price-tbl .sep-pt-tier { text-align:center; border-radius:var(--sep-r3) var(--sep-r3) 0 0; }
.sep-pt-tier.sep-pt-feat { background:var(--sep-slate); color:var(--sep-cream); }
.sep-pt-tier.sep-pt-plain { background:var(--sep-cream2); color:var(--sep-slate); }
.sep-pt-tier-badge { display:inline-block; font-size:.42rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; background:var(--sep-terra); color:white; padding:.18rem .7rem; border-radius:var(--sep-rp); margin-bottom:.4rem; }
.sep-pt-nm { font-size:1.2rem; font-weight:700; display:block; }
.sep-pt-price { font-size:2.2rem; font-weight:800; line-height:1; display:block; margin-top:.3rem; }
.sep-pt-per { font-size:.48rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; opacity:.4; }
.sep-price-tbl tbody tr { border-top:1px solid var(--sep-border); }
.sep-price-tbl tbody tr:hover { background:rgba(196,102,78,.03); }
.sep-pt-feat-nm { background:var(--sep-slate3); }
.sep-price-tbl td { padding:.72rem 1.4rem; font-size:.84rem; color:var(--sep-mid); }
.sep-pt-label { font-weight:500; color:var(--sep-ink); }
.sep-pt-cell { text-align:center; }
.sep-pt-cell svg { color:var(--sep-terra); margin:0 auto; }
.sep-pt-cell.sep-pt-no svg { color:var(--sep-border2); }
.sep-price-tbl tfoot tr td { padding:1.4rem; text-align:center; background:var(--sep-white); }
.sep-price-tbl tfoot .sep-pt-feat-nm { background:var(--sep-slate3); }

/* ============================================================
   TWO-COLUMN FAQ (FIRST in 56!)
   ============================================================ */
.sep-faq-2col { display:grid; grid-template-columns:1fr 1fr; gap:0 1px; background:var(--sep-border); border:1px solid var(--sep-border); border-radius:var(--sep-r3); overflow:hidden; margin-top:2rem; }
.sep-faq-item { background:var(--sep-white); border-bottom:1px solid var(--sep-border); }
.sep-faq-item:last-child { border-bottom:none; }
.sep-faq-item.sep-fq-even:last-child { border-bottom:none; }
.sep-faq-qbtn { display:flex; align-items:center; justify-content:space-between; gap:.5rem; padding:.82rem 1rem; cursor:pointer; background:none; border:none; width:100%; text-align:left; transition:background .12s; }
.sep-faq-qbtn:hover { background:var(--sep-cream); }
.sep-faq-item.sep-fq-on .sep-faq-qbtn { background:var(--sep-cream); }
.sep-faq-qtext { font-family:var(--sep-fh); font-size:.86rem; font-weight:600; color:var(--sep-mid); transition:color .12s; line-height:1.4; flex:1; }
.sep-faq-item.sep-fq-on .sep-faq-qtext { color:var(--sep-slate); }
.sep-faq-tog { width:20px; height:20px; border:1.5px solid var(--sep-border2); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:var(--sep-ease); }
.sep-faq-item.sep-fq-on .sep-faq-tog { background:var(--sep-terra); border-color:var(--sep-terra); color:white; }
.sep-faq-ans-wrap { max-height:0; overflow:hidden; transition:max-height .3s ease; }
.sep-faq-item.sep-fq-on .sep-faq-ans-wrap { max-height:180px; }
.sep-faq-ans { font-size:.82rem; color:var(--sep-mid); padding:.3rem 1rem .9rem; line-height:1.84; }

/* ============================================================
   BUILDER
   ============================================================ */
.sep-bld-shell { max-width:var(--sep-max); margin:0 auto; padding:4rem 2rem 8rem; display:grid; grid-template-columns:1fr 256px; gap:4rem; align-items:start; }
.sep-bgrp { margin-bottom:1.8rem; }
.sep-bgrp-label { display:block; font-family:var(--sep-fb); font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.24em; color:var(--sep-terra); margin-bottom:.8rem; }
.sep-pick-row { background:var(--sep-white); border:1.5px solid var(--sep-border); border-radius:var(--sep-r2); padding:.72rem 1rem; display:flex; align-items:center; gap:.6rem; cursor:pointer; user-select:none; transition:var(--sep-ease); margin-bottom:.4rem; }
.sep-pick-row:hover { border-color:var(--sep-border2); }
.sep-pick-row.sep-picked { border-color:var(--sep-terra); background:var(--sep-terrat); }
.sep-pick-dot { width:16px; height:16px; border:1.5px solid var(--sep-border2); border-radius:var(--sep-r); flex-shrink:0; transition:var(--sep-ease); }
.sep-pick-row.sep-picked .sep-pick-dot { background:var(--sep-terra); border-color:var(--sep-terra); }
.sep-pick-nm { font-size:.84rem; color:var(--sep-mid); flex:1; }
.sep-pick-row.sep-picked .sep-pick-nm { color:var(--sep-ink); font-weight:600; }
.sep-pick-pr { font-size:.7rem; font-weight:700; color:var(--sep-terra2); white-space:nowrap; }
.sep-adn-chips { display:flex; flex-wrap:wrap; gap:.4rem; }
.sep-adn-chip { background:var(--sep-white); border:1.5px solid var(--sep-border); border-radius:var(--sep-rp); padding:.42rem .9rem; cursor:pointer; user-select:none; transition:var(--sep-ease); }
.sep-adn-chip.sep-adn-on { border-color:var(--sep-terra); background:var(--sep-terrat); }
.sep-adn-cn { font-size:.8rem; font-weight:600; color:var(--sep-mid); }
.sep-adn-chip.sep-adn-on .sep-adn-cn { color:var(--sep-ink); }
.sep-adn-cp { font-size:.6rem; color:var(--sep-muted); }
.sep-adn-chip.sep-adn-on .sep-adn-cp { color:var(--sep-terra2); }
.sep-hrs-panel { background:var(--sep-white); border:1.5px solid var(--sep-border); border-radius:var(--sep-r2); padding:.9rem 1rem; }
.sep-hrs-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:.5rem; }
.sep-hrs-lbl { font-size:.82rem; color:var(--sep-mid); }
.sep-hrs-num { font-family:var(--sep-fh); font-size:1.8rem; font-weight:800; color:var(--sep-terra); line-height:1; }
.sep-hrs-range { -webkit-appearance:none; width:100%; height:3px; background:var(--sep-border); border-radius:2px; cursor:pointer; }
.sep-hrs-range::-webkit-slider-thumb { -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--sep-terra); cursor:pointer; }
.sep-hrs-note { font-size:.64rem; color:var(--sep-muted); margin-top:.4rem; }
/* Slate receipt panel */
.sep-receipt { background:var(--sep-slate); border-radius:var(--sep-r3); overflow:hidden; position:sticky; top:2rem; }
.sep-receipt-hd { background:rgba(255,255,255,.04); padding:.82rem 1.1rem; border-bottom:1px solid rgba(255,255,255,.07); }
.sep-receipt-hl { font-family:var(--sep-fb); font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.16em; color:rgba(255,255,255,.28); }
.sep-receipt-body { padding:.8rem 1.1rem; min-height:60px; }
.sep-receipt-empty { font-size:.74rem; color:rgba(255,255,255,.18); font-style:italic; }
.sep-receipt-ln { display:flex; justify-content:space-between; gap:.5rem; font-size:.74rem; margin-bottom:.35rem; }
.sep-receipt-lnm { color:rgba(255,255,255,.38); }
.sep-receipt-lpr { font-weight:700; color:var(--sep-terra); }
.sep-receipt-ft { border-top:1px solid rgba(255,255,255,.07); padding:.82rem 1.1rem; }
.sep-receipt-tot { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:.82rem; }
.sep-receipt-totl { font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.2); }
.sep-receipt-tota { font-family:var(--sep-fh); font-size:2.6rem; font-weight:800; color:var(--sep-terra); line-height:1; }
.sep-receipt-go { display:block; width:100%; background:var(--sep-terra); color:white; font-family:var(--sep-fh); font-size:.88rem; font-weight:700; padding:.76rem; border-radius:var(--sep-rp); border:none; cursor:pointer; transition:background .14s; }
.sep-receipt-go:hover:not(:disabled) { background:var(--sep-terra2); }
.sep-receipt-go:disabled { opacity:.22; cursor:not-allowed; }

/* ============================================================
   SERVICE PAGE
   ============================================================ */
.sep-svc-hero { background:var(--sep-slate); padding:6rem 3rem 4.5rem; position:relative; overflow:hidden; }
.sep-svc-hero::before { content:''; position:absolute; bottom:-60px; right:-60px; width:280px; height:280px; border:1.5px solid rgba(196,102,78,.1); border-radius:50%; }
.sep-svc-hero-num { font-family:var(--sep-fb); font-size:.46rem; font-weight:700; text-transform:uppercase; letter-spacing:.26em; color:var(--sep-terra); display:inline-block; margin-bottom:.5rem; position:relative; z-index:1; }
.sep-svc-hero h1 { color:var(--sep-cream); max-width:20ch; position:relative; z-index:1; }
.sep-svc-hero-sub { color:rgba(247,243,238,.45); max-width:52ch; margin:.6rem 0 1.8rem; position:relative; z-index:1; font-size:.96rem; }
.sep-svc-layout { max-width:var(--sep-max); margin:0 auto; padding:5rem 2rem; display:grid; grid-template-columns:1fr 260px; gap:5rem; align-items:start; }
.sep-svc-main h2 { font-family:var(--sep-fh); font-size:1.4rem; color:var(--sep-terra); margin:2.5rem 0 .5rem; }
.sep-svc-main p { margin-bottom:.86rem; }
.sep-deliv-list { display:flex; flex-direction:column; gap:.38rem; margin-bottom:1.2rem; }
.sep-deliv-row { display:flex; align-items:flex-start; gap:.44rem; font-size:.86rem; color:var(--sep-mid); }
.sep-deliv-row svg { color:var(--sep-terra); flex-shrink:0; margin-top:.1rem; }
.sep-svc-aside { background:var(--sep-slate); border-radius:var(--sep-r3); overflow:hidden; position:sticky; top:2rem; }
.sep-aside-top { padding:1.2rem; }
.sep-aside-from { font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:rgba(255,255,255,.28); margin-bottom:.2rem; }
.sep-aside-price { font-family:var(--sep-fh); font-size:1.1rem; font-weight:800; color:var(--sep-terra); margin-bottom:.8rem; }
.sep-aside-img img { width:100%; height:100px; object-fit:cover; display:block; }
.sep-other-h { font-size:.42rem; font-weight:700; text-transform:uppercase; letter-spacing:.22em; color:rgba(255,255,255,.2); margin:1.2rem 1.2rem .5rem; }
.sep-other-lk { display:flex; align-items:center; gap:.38rem; font-size:.78rem; color:rgba(255,255,255,.3); padding:.34rem 1.2rem; border-top:1px solid rgba(255,255,255,.05); transition:color .14s; }
.sep-other-lk:hover { color:var(--sep-terra); }

/* ============================================================
   CHECKOUT
   ============================================================ */
.sep-co-frame { max-width:860px; margin:0 auto; padding:5rem 2rem; display:grid; grid-template-columns:1fr 250px; gap:4rem; align-items:start; }
.sep-fg { margin-bottom:.6rem; }
.sep-fl { display:block; font-family:var(--sep-fb); font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--sep-muted); margin-bottom:.28rem; }
.sep-fi { width:100%; background:var(--sep-white); border:1.5px solid var(--sep-border); border-radius:var(--sep-r2); padding:.66rem .92rem; color:var(--sep-ink); font-size:.9rem; transition:border-color .15s; }
.sep-fi:focus { outline:none; border-color:var(--sep-terra); box-shadow:0 0 0 3px rgba(196,102,78,.1); }
.sep-fi::placeholder { color:var(--sep-muted); }
.sep-agree { display:flex; align-items:flex-start; gap:.5rem; font-size:.78rem; color:var(--sep-mid); margin:.88rem 0; line-height:1.6; }
.sep-agree input { margin-top:.12rem; accent-color:var(--sep-terra); }
.sep-agree a { color:var(--sep-terra2); }
.sep-co-recap { background:var(--sep-slate); border-radius:var(--sep-r3); overflow:hidden; position:sticky; top:2rem; }
.sep-co-recap-hd { background:rgba(255,255,255,.04); padding:.7rem 1rem; border-bottom:1px solid rgba(255,255,255,.07); }
.sep-co-hl { font-family:var(--sep-fb); font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.25); }
.sep-co-body { padding:.84rem 1rem; }
.sep-co-ln { display:flex; justify-content:space-between; gap:1rem; font-size:.74rem; margin-bottom:.35rem; }
.sep-co-lnm { color:rgba(255,255,255,.38); }
.sep-co-lpr { font-weight:700; color:var(--sep-terra); }
.sep-co-div { border:none; border-top:1px solid rgba(255,255,255,.07); margin:.5rem 0; }
.sep-co-tot { display:flex; justify-content:space-between; align-items:flex-end; }
.sep-co-totl { font-size:.44rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.2); }
.sep-co-totv { font-family:var(--sep-fh); font-size:2.2rem; font-weight:800; color:var(--sep-terra); line-height:1; }

/* ============================================================
   PAGE CAP (inner pages)
   ============================================================ */
.sep-pagecap { background:var(--sep-slate); padding:5rem 3rem 4rem; position:relative; overflow:hidden; }
.sep-pagecap::after { content:''; position:absolute; top:-40px; right:-40px; width:200px; height:200px; border:1.5px solid rgba(196,102,78,.08); border-radius:50%; }
.sep-pagecap-tag { font-family:var(--sep-fb); font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.24em; color:var(--sep-terra); display:inline-block; margin-bottom:.7rem; position:relative; z-index:1; }
.sep-pagecap h1 { color:var(--sep-cream); max-width:22ch; position:relative; z-index:1; }
.sep-pagecap-sub { color:rgba(247,243,238,.4); max-width:56ch; margin:.6rem 0 0; font-size:.95rem; position:relative; z-index:1; }

/* ============================================================
   LEGAL
   ============================================================ */
.sep-legal { max-width:800px; margin:0 auto; padding:5rem 2rem 8rem; }
.sep-legal h2 { font-family:var(--sep-fh); font-size:1.4rem; font-weight:700; color:var(--sep-terra2); margin:2.8rem 0 .5rem; }
.sep-legal h3 { font-family:var(--sep-fh); font-size:.92rem; font-weight:700; color:var(--sep-slate); margin:1.4rem 0 .3rem; }
.sep-legal p { margin-bottom:.88rem; font-size:.9rem; }
.sep-legal ul { padding-left:1.2rem; margin:.4rem 0 .88rem; }
.sep-legal li { font-size:.9rem; list-style:disc; color:var(--sep-mid); line-height:1.72; margin-bottom:.26rem; }
.sep-legal a { color:var(--sep-terra2); }
.sep-legal address { background:var(--sep-cream2); border-left:3px solid var(--sep-terra); padding:.88rem 1.1rem; font-size:.86rem; color:var(--sep-mid); line-height:1.86; margin:.88rem 0; border-radius:0 var(--sep-r) var(--sep-r) 0; }
.sep-legal-eff { display:inline-block; font-size:.68rem; color:var(--sep-muted); background:var(--sep-cream2); border:1px solid var(--sep-border); padding:.24rem .7rem; border-radius:var(--sep-rp); margin-bottom:1.5rem; }
.sep-legal table { width:100%; border-collapse:collapse; font-size:.84rem; margin:.88rem 0; }
.sep-legal th { background:var(--sep-cream2); color:var(--sep-slate); padding:.5rem .9rem; font-size:.56rem; text-transform:uppercase; letter-spacing:.06em; border:1px solid var(--sep-border); }
.sep-legal td { padding:.5rem .9rem; border:1px solid var(--sep-border); color:var(--sep-mid); }
.sep-result-page { min-height:72vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:6rem 2rem; background:var(--sep-slate); }

/* ============================================================
   PROCESS
   ============================================================ */
.sep-proc-list { margin-top:2rem; }
.sep-proc-item { display:grid; grid-template-columns:64px 1fr; gap:1.5rem; padding:1.5rem 0; border-bottom:1px solid var(--sep-border); align-items:start; }
.sep-proc-item:last-child { border-bottom:none; }
.sep-proc-n { font-family:var(--sep-fh); font-size:2.8rem; font-weight:800; color:var(--sep-terra); line-height:1; opacity:.25; transition:opacity .2s; }
.sep-proc-item:hover .sep-proc-n { opacity:1; }
.sep-proc-nm { font-family:var(--sep-fh); font-size:1.1rem; font-weight:700; color:var(--sep-slate); margin-bottom:.3rem; }
.sep-proc-txt { font-size:.86rem; color:var(--sep-mid); }

/* ============================================================
   BUTTONS
   ============================================================ */
.sep-btn-terra { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--sep-fh); font-size:.92rem; font-weight:700; color:white; background:var(--sep-terra); padding:.7rem 2rem; border-radius:var(--sep-rp); transition:background .14s; border:none; cursor:pointer; white-space:nowrap; box-shadow:var(--sep-tsh); }
.sep-btn-terra:hover { background:var(--sep-terra2); }
.sep-btn-slate { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--sep-fh); font-size:.92rem; font-weight:700; color:white; background:var(--sep-slate); padding:.7rem 2rem; border-radius:var(--sep-rp); transition:opacity .14s; border:none; cursor:pointer; white-space:nowrap; }
.sep-btn-slate:hover { opacity:.84; }
.sep-btn-outline { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--sep-fh); font-size:.92rem; font-weight:700; color:var(--sep-slate); background:transparent; padding:.68rem 1.9rem; border-radius:var(--sep-rp); border:1.5px solid var(--sep-slate); transition:var(--sep-ease); white-space:nowrap; }
.sep-btn-outline:hover { background:var(--sep-slate); color:white; }
.sep-btn-outline-w { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--sep-fh); font-size:.92rem; font-weight:700; color:rgba(255,255,255,.7); background:transparent; padding:.68rem 1.9rem; border-radius:var(--sep-rp); border:1.5px solid rgba(255,255,255,.2); transition:var(--sep-ease); white-space:nowrap; }
.sep-btn-outline-w:hover { color:white; border-color:rgba(255,255,255,.5); }
.sep-btn-sm-terra { display:inline-flex; align-items:center; gap:.35rem; font-family:var(--sep-fh); font-size:.82rem; font-weight:700; color:white; background:var(--sep-terra); padding:.5rem 1.1rem; border-radius:var(--sep-rp); transition:background .14s; border:none; cursor:pointer; white-space:nowrap; }
.sep-btn-sm-terra:hover { background:var(--sep-terra2); }
.sep-btn-sm-out { display:inline-flex; align-items:center; gap:.35rem; font-family:var(--sep-fh); font-size:.82rem; font-weight:700; color:var(--sep-mid); background:transparent; padding:.48rem 1.2rem; border-radius:var(--sep-rp); border:1.5px solid var(--sep-border); transition:var(--sep-ease); white-space:nowrap; }
.sep-btn-sm-out:hover { border-color:var(--sep-terra); color:var(--sep-terra2); }
.sep-btn-sm-w { display:inline-flex; align-items:center; gap:.35rem; font-family:var(--sep-fh); font-size:.82rem; font-weight:700; color:rgba(255,255,255,.6); background:transparent; padding:.48rem 1.2rem; border-radius:var(--sep-rp); border:1.5px solid rgba(255,255,255,.15); transition:var(--sep-ease); white-space:nowrap; }
.sep-btn-sm-w:hover { border-color:var(--sep-terra); color:var(--sep-terra); }

/* ============================================================
   UTILITIES
   ============================================================ */
.sep-hull { max-width:var(--sep-max); margin:0 auto; padding:0 2.5rem; }
.sep-slab { padding:7rem 0; }
.sep-slab-sm { padding:4.5rem 0; }
.sep-eyebrow { font-family:var(--sep-fb); font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.24em; color:var(--sep-terra); display:inline-block; }
.sep-float { opacity:0; transform:translateY(14px); transition:opacity .44s ease,transform .44s ease; }
.sep-float.sep-vis { opacity:1; transform:none; }

/* ============================================================
   COOKIE + CHAT
   ============================================================ */
.sep-ck-bar { position:fixed; bottom:0; left:0; right:0; background:var(--sep-slate); border-top:2px solid var(--sep-terra); z-index:9999; padding:.9rem 2rem; display:none; gap:1rem; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.sep-ck-bar p { font-size:.78rem; color:rgba(255,255,255,.35); margin:0; }
.sep-ck-bar a { color:var(--sep-terra); }
.sep-ck-btns { display:flex; gap:.4rem; flex-shrink:0; }
.sep-ck-yes { background:var(--sep-terra); color:white; font-family:var(--sep-fh); font-size:.76rem; font-weight:700; padding:.38rem .92rem; border:none; border-radius:var(--sep-r); cursor:pointer; }
.sep-ck-no { background:transparent; color:rgba(255,255,255,.3); font-family:var(--sep-fb); font-size:.76rem; padding:.38rem .92rem; border:1px solid rgba(255,255,255,.12); border-radius:var(--sep-r); cursor:pointer; }
.sep-chat-fab { position:fixed; bottom:4.5rem; right:1.5rem; z-index:9990; width:52px; height:52px; background:var(--sep-terra); border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:var(--sep-tsh); cursor:pointer; border:none; transition:var(--sep-ease); }
.sep-chat-fab:hover { background:var(--sep-terra2); transform:scale(1.06); }
.sep-chatpop { position:fixed; bottom:7.5rem; right:1.5rem; z-index:9989; width:272px; background:white; border:1px solid var(--sep-border); border-radius:var(--sep-r3); box-shadow:var(--sep-sh2); opacity:0; pointer-events:none; transform:translateY(8px) scale(.97); transition:opacity .2s,transform .22s; overflow:hidden; }
.sep-chatpop.sep-cp-on { opacity:1; pointer-events:auto; transform:none; }
.sep-chatpop-hd { background:var(--sep-slate); padding:.9rem 1rem; display:flex; align-items:center; justify-content:space-between; }
.sep-chatpop-nm { font-family:var(--sep-fh); font-size:.9rem; font-weight:700; color:white; }
.sep-chatpop-sub { font-size:.52rem; color:rgba(255,255,255,.35); }
.sep-chat-done { display:none; text-align:center; padding:.7rem; font-size:.82rem; color:var(--sep-terra2); font-weight:700; }
.sep-chat-inp { width:100%; background:var(--sep-cream); border:1px solid var(--sep-border); border-radius:var(--sep-r); padding:.44rem .76rem; font-size:.8rem; color:var(--sep-ink); margin-bottom:.36rem; resize:none; }
.sep-chat-send { width:100%; background:var(--sep-terra); color:white; font-family:var(--sep-fh); font-size:.78rem; font-weight:700; padding:.48rem; border-radius:var(--sep-rp); border:none; cursor:pointer; }

/* ============================================================
   FOOTER (below sep-body, inside sidebar layout)
   ============================================================ */
.sep-foot { background:var(--sep-slate2); border-top:1px solid rgba(255,255,255,.04); }
.sep-foot-body { max-width:var(--sep-max); margin:0 auto; padding:4.5rem 2.5rem 2rem; display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:2rem; }
/* BIGGER LOGO in footer (new requirement!) */
.sep-foot-logo { font-family:var(--sep-fh); font-size:1.5rem; font-weight:800; color:var(--sep-cream); letter-spacing:-.02em; }
.sep-foot-logo em { font-style:normal; color:var(--sep-terra); }
.sep-foot-tagline { font-size:.74rem; color:rgba(255,255,255,.25); margin-top:.2rem; max-width:24ch; line-height:1.72; margin-bottom:.9rem; }
.sep-foot-soc { display:flex; gap:.38rem; flex-wrap:wrap; }
.sep-foot-soc a { width:29px; height:29px; border:1px solid rgba(255,255,255,.08); border-radius:var(--sep-r); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.26); transition:var(--sep-ease); }
.sep-foot-soc a:hover { border-color:var(--sep-terra); color:var(--sep-terra); }
.sep-foot-col-h { font-family:var(--sep-fb); font-size:.42rem; font-weight:700; text-transform:uppercase; letter-spacing:.28em; color:rgba(255,255,255,.16); margin-bottom:.8rem; }
.sep-foot-navs { display:flex; flex-direction:column; gap:.44rem; }
.sep-foot-navs a { font-size:.78rem; color:rgba(255,255,255,.3); transition:color .14s; }
.sep-foot-navs a:hover { color:var(--sep-terra); }
.sep-foot-ct a { display:flex; align-items:flex-start; gap:.34rem; font-size:.76rem; color:rgba(255,255,255,.3); margin-bottom:.4rem; transition:color .14s; }
.sep-foot-ct a:hover { color:var(--sep-terra); }
.sep-foot-ct svg { color:rgba(255,255,255,.18); flex-shrink:0; margin-top:.06rem; }
.sep-foot-btm { border-top:1px solid rgba(255,255,255,.04); max-width:var(--sep-max); margin:0 auto; padding:.9rem 2.5rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.sep-foot-copy { font-size:.6rem; color:rgba(255,255,255,.16); }
.sep-foot-legal { display:flex; gap:1rem; flex-wrap:wrap; }
.sep-foot-legal a { font-size:.6rem; color:rgba(255,255,255,.16); transition:color .14s; }
.sep-foot-legal a:hover { color:var(--sep-terra); }

/* ============================================================
   RESPONSIVE - sidebar collapses on mobile
   ============================================================ */
@media (max-width:1024px) {
  .sep-rail { transform:translateX(-100%); transition:transform .26s cubic-bezier(.4,0,.2,1); }
  .sep-rail.sep-rail-open { transform:none; }
  .sep-body { margin-left:0; }
  .sep-ham { display:flex; }
  .sep-hero-type { padding:5rem 2rem 4rem; }
  .sep-hero-nums { grid-template-columns:repeat(2,1fr); }
  .sep-svc-mosaic { grid-template-columns:1fr 1fr; }
  .sep-testi-cols { grid-template-columns:1fr; }
  .sep-testi-col { border-right:none; border-bottom:1px solid var(--sep-border2); }
  .sep-testi-col:last-child { border-bottom:none; }
  .sep-price-tbl { font-size:.78rem; }
  .sep-price-tbl thead { display:none; }
  .sep-price-tbl tbody td:first-child { font-weight:600; background:var(--sep-cream2); }
  .sep-faq-2col { grid-template-columns:1fr; }
  .sep-bld-shell,.sep-co-frame,.sep-svc-layout { grid-template-columns:1fr; gap:2.5rem; }
  .sep-foot-body { grid-template-columns:1fr 1fr; gap:1.8rem; }
  .sep-hull { padding-left:1.4rem; padding-right:1.4rem; }
  .sep-svc-layout,.sep-bld-shell,.sep-co-frame { padding-left:1.4rem; padding-right:1.4rem; }
}
@media (max-width:640px) {
  .sep-svc-mosaic { grid-template-columns:1fr; }
  .sep-foot-body { grid-template-columns:1fr; }
  .sep-hero-nums { grid-template-columns:repeat(2,1fr); }
  .sep-pagecap { padding:4.5rem 1.4rem 3rem; }
}
