  :root{
    --red:#e10600;
    --red-dark:#a30400;
    --red-soft:#fff5f4;
    --ink:#1a1a1a;
    --ink-soft:#3d3d3d;
    --white:#ffffff;
    --cream:#faf7f2;
    --soft:#f5efe6;
    --blue-soft:#eef5fb;
    --warm:#ffd84d;
    --green:#1a8a3a;
    --muted:#6b6b6b;
    --line:rgba(0,0,0,.08);
    --shadow-sm:0 2px 8px rgba(0,0,0,.04);
    --shadow:0 10px 40px rgba(0,0,0,.06);
    --shadow-lg:0 30px 80px rgba(0,0,0,.1);
    --radius:14px;
    --ease:cubic-bezier(.2,.8,.2,1);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Inter',system-ui,sans-serif;
    background:var(--cream);
    color:var(--ink);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,h4{font-family:'Bebas Neue', Impact, 'Arial Narrow', 'Helvetica Neue Condensed', sans-serif;letter-spacing:.02em;line-height:1.05;font-weight:400;font-stretch:condensed}
  h1{font-size:clamp(3rem,8vw,7rem)}
  h2{font-size:clamp(2.2rem,5vw,4.2rem)}
  h3{font-size:clamp(1.5rem,2.5vw,2rem)}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .container{max-width:1200px;margin:0 auto;padding:0 24px}

  /* ---------- Nav ---------- */
  nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 32px;
    background:rgba(255,255,255,0);
    backdrop-filter:blur(0);
    transition:background .35s var(--ease),backdrop-filter .35s var(--ease),padding .35s var(--ease),box-shadow .35s var(--ease);
    color:#fff;
  }
  nav.scrolled{
    background:rgba(255,255,255,.95);
    backdrop-filter:blur(14px);
    padding:10px 32px;
    box-shadow:var(--shadow-sm);
    color:var(--ink);
  }
  nav.scrolled .logo,nav.scrolled .nav-links a{color:var(--ink)}
  .logo{display:flex;align-items:center;gap:14px;font-family:'Bebas Neue';font-size:1.85rem;letter-spacing:.08em}
  .logo-mark{
    width:60px;height:60px;display:block;flex-shrink:0;object-fit:contain;
    filter:drop-shadow(0 4px 14px rgba(225,6,0,.55));
    transition:transform .35s var(--ease);
  }
  nav.scrolled .logo-mark{width:48px;height:48px;transition:width .35s var(--ease),height .35s var(--ease),transform .35s var(--ease)}
  .logo:hover .logo-mark{transform:translateY(-2px) scale(1.08) rotate(-2deg)}
  footer .logo-mark{width:72px;height:72px}
  footer .logo{font-size:2rem}
  .nav-links{display:flex;gap:32px;font-size:.9rem;font-weight:500}
  .nav-links a{position:relative;opacity:.85;transition:opacity .2s}
  .nav-links a:hover{opacity:1}
  .nav-links a::after{
    content:'';position:absolute;left:0;bottom:-6px;height:2px;width:0;
    background:var(--red);transition:width .3s var(--ease);
  }
  .nav-links a:hover::after{width:100%}
  @media(max-width:880px){.nav-links{display:none}}

  /* ---------- Nav dropdown (Cities) ---------- */
  .nav-dropdown{position:relative}
  .nav-dropdown > a{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
  .nav-dropdown > a::after{
    content:'';
    position:static;            /* override .nav-links a::after */
    background:transparent;     /* override .nav-links a::after */
    left:auto;bottom:auto;
    display:inline-block;
    width:6px;height:6px;
    border-right:1.5px solid currentColor;
    border-bottom:1.5px solid currentColor;
    transform:rotate(45deg) translateY(-2px);
    transition:transform .2s var(--ease);
    margin-left:2px;
  }
  .nav-dropdown > a:hover::after{width:6px}  /* defeat the underline expand */
  .nav-dropdown.open > a::after,
  .nav-dropdown:hover > a::after{
    transform:rotate(-135deg) translateY(1px);
  }
  /* Bridge the hover gap by extending the dropdown's hit area UPWARD via the parent padding */
  .nav-dropdown{padding-bottom:18px;margin-bottom:-18px}
  .nav-dropdown-menu{
    position:absolute;top:100%;left:50%;
    transform:translateX(-50%) translateY(-8px);
    min-width:340px;
    background:rgba(255,255,255,.98);
    backdrop-filter:blur(16px);
    border:1px solid var(--line);
    border-radius:14px;
    padding:10px;
    box-shadow:0 20px 50px rgba(0,0,0,.15);
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:2px;
    opacity:0;
    pointer-events:none;
    transition:opacity .22s var(--ease),transform .22s var(--ease);
    z-index:60;
  }
  .nav-dropdown-menu::before{
    content:'';position:absolute;top:-6px;left:50%;
    transform:translateX(-50%) rotate(45deg);
    width:12px;height:12px;
    background:rgba(255,255,255,.98);
    border-left:1px solid var(--line);
    border-top:1px solid var(--line);
  }
  .nav-dropdown:hover .nav-dropdown-menu,
  .nav-dropdown.open .nav-dropdown-menu{
    opacity:1;
    pointer-events:auto;
    transform:translateX(-50%) translateY(0);
  }
  .nav-dropdown-menu a{
    display:block;
    padding:10px 14px;
    font-size:.88rem;
    color:var(--ink) !important;
    border-radius:8px;
    transition:background .15s var(--ease),color .15s var(--ease);
    opacity:1 !important;
  }
  .nav-dropdown-menu a::after{display:none !important}
  .nav-dropdown-menu a:hover{
    background:var(--red-soft);
    color:var(--red) !important;
  }

  /* ---------- Reasons to Sell ---------- */
  .reasons{background:var(--cream);padding:120px 0}
  .reasons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
  @media(max-width:860px){.reasons-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.reasons-grid{grid-template-columns:1fr}}
  .reason-card{
    display:block;padding:32px 28px;
    background:var(--white);
    border:1px solid var(--line);
    border-radius:var(--radius);
    text-decoration:none;color:var(--ink);
    transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
    position:relative;overflow:hidden;
  }
  .reason-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:3px;
    background:var(--red);
    transform:scaleX(0);transform-origin:left;
    transition:transform .35s var(--ease);
  }
  .reason-card:hover{
    transform:translateY(-6px);
    box-shadow:var(--shadow);
    border-color:var(--red);
  }
  .reason-card:hover::before{transform:scaleX(1)}
  .reason-icon{
    width:54px;height:54px;border-radius:14px;
    background:var(--red-soft);display:grid;place-items:center;
    margin-bottom:20px;
    transition:background .35s var(--ease);
  }
  .reason-card:hover .reason-icon{background:var(--red)}
  .reason-icon svg{width:26px;height:26px;color:var(--red);transition:color .35s var(--ease)}
  .reason-card:hover .reason-icon svg{color:#fff}
  .reason-card h3{
    font-family:'Inter';font-size:1.15rem;font-weight:700;
    margin-bottom:8px;color:var(--ink);
  }
  .reason-card p{color:var(--ink-soft);font-size:.92rem;line-height:1.55;margin-bottom:16px}
  .reason-link{
    display:inline-flex;align-items:center;gap:6px;
    color:var(--red);font-size:.85rem;font-weight:700;
    letter-spacing:.04em;text-transform:uppercase;
  }
  .reason-link svg{transition:transform .25s var(--ease)}
  .reason-card:hover .reason-link svg{transform:translateX(4px)}

  /* ---------- Buttons ---------- */
  .btn{
    --bg:var(--red);
    position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
    padding:16px 30px;background:var(--bg);color:var(--white);
    font-weight:700;font-size:.95rem;letter-spacing:.03em;
    border:none;border-radius:999px;cursor:pointer;overflow:hidden;
    transition:transform .25s var(--ease),box-shadow .25s var(--ease);
    box-shadow:0 10px 30px rgba(225,6,0,.28);
  }
  .btn::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);
    transform:translateX(-100%);
    transition:transform .6s var(--ease);
  }
  .btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(225,6,0,.4)}
  .btn:hover::before{transform:translateX(100%)}
  .btn:active{transform:translateY(0)}
  .btn .arrow{transition:transform .25s var(--ease)}
  .btn:hover .arrow{transform:translateX(4px)}
  .btn-ghost{
    background:transparent;border:1.5px solid rgba(255,255,255,.7);
    box-shadow:none;color:var(--white);
  }
  .btn-ghost:hover{background:var(--white);color:var(--ink);box-shadow:0 10px 30px rgba(255,255,255,.2)}
  .btn-ghost-dark{
    background:transparent;border:1.5px solid var(--ink);color:var(--ink);box-shadow:none;
  }
  .btn-ghost-dark:hover{background:var(--ink);color:var(--white)}

  /* ---------- Hero ---------- */
  .hero{
    position:relative;min-height:100vh;display:flex;align-items:center;
    overflow:hidden;
  }
  .hero picture{
    position:absolute;inset:-4%;width:108%;height:108%;
    z-index:0;display:block;overflow:hidden;
  }
  .hero-bg{
    width:100%;height:100%;display:block;
    object-fit:cover;object-position:center;
    filter:brightness(.85);
    animation:slowZoom 22s ease-in-out infinite alternate;
    will-change:transform;transform:translateZ(0);
    backface-visibility:hidden;
  }
  @keyframes slowZoom{
    from{transform:scale(1) translate(0,0)}
    to{transform:scale(1.08) translate(-1%,-1%)}
  }
  .hero::after{
    content:'';position:absolute;inset:0;z-index:1;
    background:
      linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.55) 100%),
      linear-gradient(90deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,0) 60%);
  }
  .hero-content{position:relative;z-index:2;width:100%;padding:120px 0 60px}
  .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
  @media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:40px}}

  /* ---------- Hero Quick Form ---------- */
  .quick-form{
    position:relative;
    padding:36px 32px;
    background:var(--white);
    border-radius:var(--radius);
    border:1px solid var(--line);
    box-shadow:0 30px 80px rgba(0,0,0,.25),0 0 0 8px rgba(255,255,255,.1);
    color:var(--ink);
    overflow:hidden;
    animation:cardIn 1s var(--ease) .2s both;
  }
  @keyframes cardIn{from{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:none}}
  .quick-form::before{
    content:'';position:absolute;top:0;left:0;right:0;height:5px;
    background:var(--red);
  }
  .quick-form::after{
    content:'';position:absolute;top:-50%;right:-30%;width:300px;height:300px;
    background:radial-gradient(circle,rgba(255,216,77,.15),transparent 60%);
    pointer-events:none;
  }
  .quick-form .qf-badge{
    display:inline-flex;align-items:center;gap:8px;
    padding:6px 12px;background:var(--red);color:#fff;
    font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
    margin-bottom:18px;
  }
  .quick-form .qf-badge::before{
    content:'';width:6px;height:6px;border-radius:50%;background:#fff;
    animation:pulse 2s infinite;
  }
  .quick-form h3{
    font-family:'Bebas Neue';font-size:2rem;line-height:1;margin-bottom:8px;
    letter-spacing:.02em;
  }
  .quick-form .qf-sub{color:var(--muted);font-size:.9rem;margin-bottom:22px}
  .quick-form .field{margin-bottom:14px}
  .quick-form .field input{
    padding:14px 16px;font-size:.95rem;
    background:var(--cream);
    border:1.5px solid var(--line);
    color:var(--ink);
    border-radius:10px;
  }
  .quick-form .field input:focus{
    border-color:var(--red);background:var(--white);
    box-shadow:0 0 0 4px rgba(225,6,0,.1);
  }
  .quick-form .field label{top:14px;left:16px;font-size:.95rem;color:var(--muted);background:transparent}
  .quick-form .field input:focus + label,
  .quick-form .field input:not(:placeholder-shown) + label{
    top:-7px;font-size:.65rem;background:var(--white);color:var(--red);
  }
  .quick-form .btn{width:100%;justify-content:center;padding:16px;margin-top:6px}
  .quick-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  @media(max-width:520px){.quick-form .form-row{grid-template-columns:1fr}}

  /* ---------- Address autocomplete ---------- */
  .field.with-suggest{position:relative}
  .suggest-list{
    position:absolute;top:calc(100% + 4px);left:0;right:0;
    background:var(--white);
    border:1px solid var(--line);
    border-radius:10px;
    max-height:260px;overflow-y:auto;
    z-index:30;
    box-shadow:0 16px 40px rgba(0,0,0,.12);
    display:none;
  }
  .suggest-list.open{display:block}
  .suggest-item{
    padding:12px 14px;
    cursor:pointer;
    border-bottom:1px solid var(--line);
    display:flex;align-items:flex-start;gap:10px;
    font-size:.9rem;
    transition:background .15s;
  }
  .suggest-item:last-child{border-bottom:none}
  .suggest-item:hover,.suggest-item.active{background:var(--red-soft)}
  .suggest-item svg{width:16px;height:16px;color:var(--red);flex-shrink:0;margin-top:3px}
  .suggest-item .addr-main{color:var(--ink);font-weight:600;display:block;line-height:1.3}
  .suggest-item .addr-ctx{color:var(--muted);font-size:.78rem;display:block;margin-top:2px}
  .suggest-empty{padding:14px;color:var(--muted);font-size:.85rem;text-align:center}
  .qf-trust{
    display:flex;justify-content:center;gap:18px;flex-wrap:wrap;
    margin-top:14px;font-size:.72rem;color:var(--muted);
    letter-spacing:.08em;text-transform:uppercase;
  }
  .qf-trust span{display:inline-flex;align-items:center;gap:6px}
  .qf-trust span::before{content:'✓';color:var(--green);font-weight:800}
  .eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    padding:8px 16px;border:1px solid rgba(255,255,255,.3);
    background:rgba(255,255,255,.15);backdrop-filter:blur(10px);
    border-radius:999px;font-size:.78rem;font-weight:600;
    text-transform:uppercase;letter-spacing:.15em;
    color:var(--white);margin-bottom:24px;
  }
  .eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red);animation:pulse 2s infinite}
  @keyframes pulse{
    0%,100%{opacity:1;transform:scale(1)}
    50%{opacity:.5;transform:scale(1.3)}
  }
  .hero h1{color:var(--white)}
  .hero h1 span{color:var(--red);display:inline-block;text-shadow:0 2px 20px rgba(0,0,0,.3)}
  .hero p.lead{
    max-width:560px;font-size:clamp(1rem,1.5vw,1.2rem);color:#f0f0f0;
    margin:24px 0 36px;
  }
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
  /* ---------- BBB seal ---------- */
  .trust-strip{
    display:flex;align-items:center;gap:14px;flex-wrap:wrap;
    margin-top:28px;
  }
  .bbb-seal{
    display:inline-block;line-height:0;
    transition:transform .25s var(--ease),filter .25s var(--ease);
    filter:drop-shadow(0 10px 24px rgba(0,0,0,.25));
  }
  .bbb-seal img{
    display:block;height:64px;width:auto;border:0;
    border-radius:6px;
  }
  .bbb-seal:hover{transform:translateY(-2px) scale(1.03);filter:drop-shadow(0 14px 30px rgba(0,0,0,.3))}
  footer .bbb-seal{margin-top:18px;filter:drop-shadow(0 6px 16px rgba(0,0,0,.4))}
  footer .bbb-seal img{height:58px}

  .hero-meta{
    display:flex;gap:32px;margin-top:64px;flex-wrap:wrap;
    border-top:1px solid rgba(255,255,255,.2);padding-top:32px;max-width:760px;
  }
  .hero-meta div{display:flex;flex-direction:column}
  .hero-meta strong{font-family:'Bebas Neue';font-size:2.4rem;color:var(--white);line-height:1}
  .hero-meta span{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:6px}

  .scroll-indicator{
    position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
    display:flex;flex-direction:column;align-items:center;gap:8px;
    font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.7);
  }
  .scroll-indicator .line{
    width:1px;height:50px;background:linear-gradient(var(--red),transparent);
    animation:scrollLine 2s infinite;
  }
  @keyframes scrollLine{
    0%{transform:scaleY(0);transform-origin:top}
    50%{transform:scaleY(1);transform-origin:top}
    51%{transform:scaleY(1);transform-origin:bottom}
    100%{transform:scaleY(0);transform-origin:bottom}
  }

  /* ---------- Sections ---------- */
  section{padding:120px 0;position:relative}
  .section-tag{
    color:var(--red);font-weight:700;font-size:.78rem;
    letter-spacing:.22em;text-transform:uppercase;margin-bottom:16px;
    display:inline-flex;align-items:center;gap:10px;
    padding:6px 14px;background:var(--red-soft);border-radius:999px;
  }
  .section-tag::before{
    content:'';width:6px;height:6px;border-radius:50%;background:var(--red);
  }
  .section-head{max-width:780px;margin-bottom:64px}
  .section-head h2{color:var(--ink)}
  .section-head p{color:var(--muted);font-size:1.1rem;margin-top:20px;line-height:1.6}

  /* reveal animation */
  .reveal{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
  .reveal-stagger.in > *{opacity:1;transform:none}
  .reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
  .reveal-stagger.in > *:nth-child(2){transition-delay:.15s}
  .reveal-stagger.in > *:nth-child(3){transition-delay:.25s}
  .reveal-stagger.in > *:nth-child(4){transition-delay:.35s}

  /* ---------- Process ---------- */
  .process{background:var(--white)}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  @media(max-width:860px){.steps{grid-template-columns:1fr}}
  .step{
    position:relative;padding:44px 32px 36px;
    background:var(--cream);
    border:1px solid var(--line);
    border-radius:var(--radius);
    transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .4s var(--ease);
  }
  .step:hover{transform:translateY(-6px);box-shadow:var(--shadow);background:var(--white)}
  .step-num{
    width:56px;height:56px;border-radius:50%;
    background:var(--red);color:var(--white);
    display:grid;place-items:center;
    font-family:'Bebas Neue';font-size:1.8rem;line-height:1;
    margin-bottom:22px;
    box-shadow:0 8px 20px rgba(225,6,0,.25);
  }
  .step h3{margin-bottom:10px;color:var(--ink)}
  .step p{color:var(--ink-soft)}

  /* ---------- Comparison ---------- */
  .compare-wrap{
    background:var(--cream);
    position:relative;
  }
  .compare-table{
    border:1px solid var(--line);
    background:var(--white);
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow);
  }
  .compare-row{
    display:grid;grid-template-columns:1.4fr 1fr 1fr;
    border-bottom:1px solid var(--line);
    transition:background .25s;
  }
  .compare-row:last-child{border-bottom:none}
  .compare-row.body:hover{background:var(--cream)}
  .compare-cell{
    padding:22px 28px;display:flex;align-items:center;gap:12px;
    border-right:1px solid var(--line);
    font-size:.98rem;color:var(--ink);
  }
  .compare-cell:last-child{border-right:none}
  .compare-row.head .compare-cell{
    font-family:'Bebas Neue';font-size:1.6rem;letter-spacing:.04em;
    background:var(--soft);padding:28px;
  }
  .compare-row.head .compare-cell.us{
    background:var(--red);color:var(--white);
    position:relative;
  }
  .compare-row.head .compare-cell.us::after{
    content:'RECOMMENDED';
    position:absolute;top:10px;right:10px;
    font-family:'Inter';font-size:.6rem;letter-spacing:.2em;font-weight:700;
    padding:4px 8px;background:rgba(255,255,255,.2);border-radius:999px;
  }
  .compare-row.body .compare-cell:first-child{font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;background:var(--soft)}
  .check,.cross{
    width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
    flex-shrink:0;font-weight:800;font-size:.85rem;
  }
  .check{background:var(--green);color:#fff;border:none}
  .cross{background:#f0f0f0;color:#999;border:none}
  .compare-cell .val{flex:1;font-weight:600}
  .compare-cell.us .val{color:var(--ink)}
  .compare-cell.them .val{color:var(--muted)}
  @media(max-width:760px){
    .compare-row{grid-template-columns:1fr;}
    .compare-cell{border-right:none;border-bottom:1px solid var(--line)}
    .compare-row.head{display:none}
    .compare-row.body{padding:14px 0}
    .compare-cell:first-child{background:rgba(225,6,0,.08);font-weight:700!important}
    .compare-cell.us::before{content:'Spartan Equity — ';color:var(--red);font-weight:700;margin-right:6px}
    .compare-cell.them::before{content:'Listing with Agent — ';color:var(--muted);font-weight:700;margin-right:6px}
  }

  /* ---------- Why ---------- */
  .why{
    position:relative;padding:140px 0;
    background:var(--white);
    overflow:hidden;
  }
  .why-bg{display:none}
  .why::after{display:none}
  .why .container{position:relative;z-index:2}
  .why-head-wrap{text-align:center;max-width:780px;margin:0 auto}
  .why-head-wrap .section-tag{margin-bottom:18px}
  .why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
  @media(max-width:860px){.why-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.why-grid{grid-template-columns:1fr}}
  .why-card{
    padding:36px 28px;text-align:center;
    background:var(--cream);
    border:1px solid var(--line);
    border-radius:var(--radius);
    transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .4s var(--ease);
  }
  .why-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);background:var(--white)}
  .why-card .icon-wrap{
    width:60px;height:60px;border-radius:18px;
    background:var(--red-soft);display:grid;place-items:center;
    margin:0 auto 20px;
  }
  .why-card svg{width:28px;height:28px;color:var(--red)}
  .why-card h4{font-family:'Inter';font-size:1.1rem;font-weight:700;margin-bottom:8px;color:var(--ink)}
  .why-card p{color:var(--ink-soft);font-size:.92rem;line-height:1.55}

  /* ---------- Form ---------- */
  .form-section{
    background:var(--white);
    position:relative;
  }
  .form-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
  @media(max-width:900px){.form-grid{grid-template-columns:1fr;gap:48px}}
  .form-card{
    padding:48px;
    background:var(--cream);
    border:1px solid var(--line);
    border-radius:var(--radius);
    box-shadow:var(--shadow-lg);
    position:relative;overflow:hidden;
  }
  .form-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:5px;
    background:var(--red);
  }
  .field{position:relative;margin-bottom:20px}
  .field input,.field select,.field textarea{
    width:100%;padding:18px;
    background:var(--white);
    border:1.5px solid var(--line);
    border-radius:10px;
    color:var(--ink);
    font-family:inherit;font-size:1rem;
    transition:border-color .25s,background .25s,box-shadow .25s;
    outline:none;
  }
  .field textarea{min-height:100px;resize:vertical;padding-top:24px}
  .field input:focus,.field select:focus,.field textarea:focus{
    border-color:var(--red);
    box-shadow:0 0 0 4px rgba(225,6,0,.1);
  }
  .field label{
    position:absolute;left:18px;top:18px;
    color:var(--muted);font-size:1rem;pointer-events:none;
    transition:all .2s var(--ease);
    background:transparent;padding:0 6px;
  }
  .field input:focus + label,
  .field input:not(:placeholder-shown) + label,
  .field textarea:focus + label,
  .field textarea:not(:placeholder-shown) + label,
  .field.filled label{
    top:-8px;font-size:.7rem;color:var(--red);
    background:var(--cream);letter-spacing:.08em;text-transform:uppercase;font-weight:700;
  }
  .field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%23e10600' stroke-width='2'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;background-size:12px;padding-right:42px;color:var(--ink)}
  .field select option{
    background:var(--white);color:var(--ink);
    padding:12px;font-size:1rem;
  }
  .field select option:checked,
  .field select option:hover{
    background:var(--red-soft);color:var(--ink);
  }
  .field select:invalid,.field select option[value=""]{color:var(--muted)}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  @media(max-width:520px){.form-row{grid-template-columns:1fr}}
  .form-card .btn{width:100%;justify-content:center;margin-top:8px;padding:20px}
  .form-disc{font-size:.78rem;color:var(--muted);margin-top:16px;text-align:center}

  .form-side h2{margin-bottom:20px;color:var(--ink)}
  .form-side p{color:var(--ink-soft);font-size:1.05rem;margin-bottom:32px}
  .form-side ul{list-style:none;display:flex;flex-direction:column;gap:14px}
  .form-side li{display:flex;gap:14px;align-items:flex-start;color:var(--ink)}
  .form-side li::before{
    content:'';width:24px;height:24px;border-radius:50%;
    background:var(--green);flex-shrink:0;margin-top:2px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
    background-position:center;background-repeat:no-repeat;background-size:14px;
  }

  /* ---------- FAQ ---------- */
  .faq{
    background:var(--white);
    padding:120px 0;
  }
  .faq-grid{
    display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start;
  }
  @media(max-width:900px){.faq-grid{grid-template-columns:1fr;gap:40px}}
  .faq-side h2{margin-bottom:20px;color:var(--ink)}
  .faq-side p{color:var(--ink-soft);font-size:1.05rem;margin-bottom:24px}
  .faq-list{display:flex;flex-direction:column;gap:14px}
  .faq-item{
    border:1px solid var(--line);
    border-radius:var(--radius);
    background:var(--cream);
    overflow:hidden;
    transition:box-shadow .3s var(--ease),background .3s var(--ease);
  }
  .faq-item[open]{background:var(--white);box-shadow:var(--shadow)}
  .faq-item summary{
    list-style:none;cursor:pointer;
    padding:22px 24px;
    display:flex;align-items:center;justify-content:space-between;gap:16px;
    font-weight:600;color:var(--ink);font-size:1.02rem;
    line-height:1.4;
  }
  .faq-item summary::-webkit-details-marker{display:none}
  .faq-item summary::after{
    content:'';
    width:28px;height:28px;border-radius:50%;
    background:var(--red-soft);
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e10600' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E");
    background-position:center;background-repeat:no-repeat;background-size:14px;
    flex-shrink:0;
    transition:transform .3s var(--ease),background .3s var(--ease);
  }
  .faq-item[open] summary::after{
    transform:rotate(45deg);
    background-color:var(--red);
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E");
  }
  .faq-item .faq-body{
    padding:0 24px 22px;color:var(--ink-soft);
    line-height:1.65;font-size:.96rem;
  }

  /* ---------- Reviews ---------- */
  .reviews{
    background:var(--cream);
    padding:120px 0;
    position:relative;
  }
  .review-rating{
    display:flex;align-items:center;gap:14px;margin-top:18px;flex-wrap:wrap;
    color:var(--muted);font-size:.92rem;
  }
  .review-rating .stars{display:inline-flex;gap:2px}
  .review-rating .stars svg{width:18px;height:18px;fill:var(--warm)}
  .review-rating strong{color:var(--ink);font-weight:700}
  .review-feature{
    text-align:center;max-width:900px;margin:0 auto 80px;padding:48px 32px;
    background:var(--white);border-radius:var(--radius);
    border:1px solid var(--line);box-shadow:var(--shadow);
    position:relative;
  }
  .review-feature::before{
    content:'"';position:absolute;top:-30px;left:32px;
    font-family:'Bebas Neue';font-size:8rem;color:var(--red);
    line-height:1;opacity:.18;
  }
  .review-feature .stars{justify-content:center;margin-bottom:24px;display:flex;gap:4px}
  .review-feature .stars svg{width:24px;height:24px;fill:var(--warm)}
  .review-feature blockquote{
    font-family:'Bebas Neue';font-size:clamp(1.8rem,4vw,2.6rem);
    line-height:1.18;letter-spacing:.01em;color:var(--ink);
  }
  .review-feature blockquote span{color:var(--red)}
  .review-feature cite{display:block;margin-top:28px;font-style:normal;color:var(--muted);font-size:.82rem;letter-spacing:.2em;text-transform:uppercase}
  .review-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  }
  @media(max-width:900px){.review-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:600px){.review-grid{grid-template-columns:1fr}}
  .review-card{
    position:relative;
    padding:32px 28px;
    background:var(--white);
    border:1px solid var(--line);
    border-radius:var(--radius);
    transition:transform .4s var(--ease),box-shadow .4s var(--ease);
    display:flex;flex-direction:column;gap:16px;
  }
  .review-card:hover{
    transform:translateY(-6px);
    box-shadow:var(--shadow);
  }
  .review-card .stars{display:flex;gap:2px}
  .review-card .stars svg{width:16px;height:16px;fill:var(--warm)}
  .review-card p{
    color:var(--ink-soft);font-size:.95rem;line-height:1.6;flex:1;
  }
  .review-card .who{
    display:flex;align-items:center;gap:12px;
    padding-top:18px;border-top:1px solid var(--line);
  }
  .review-card .avatar{
    width:44px;height:44px;border-radius:50%;
    background:linear-gradient(135deg,var(--red),var(--red-dark));
    display:grid;place-items:center;
    color:#fff;font-weight:800;font-size:.95rem;flex-shrink:0;
  }
  .review-card .meta{display:flex;flex-direction:column;line-height:1.3}
  .review-card .meta strong{color:var(--ink);font-size:.92rem}
  .review-card .meta span{color:var(--muted);font-size:.78rem;letter-spacing:.03em}
  .review-tag{
    position:absolute;top:0;right:20px;
    transform:translateY(-50%);
    background:var(--green);color:#fff;
    padding:5px 12px;font-size:.62rem;border-radius:999px;
    letter-spacing:.15em;text-transform:uppercase;font-weight:700;
  }

  /* ---------- Map / Service Area ---------- */
  .map-section{
    background:var(--cream);
    padding:120px 0;
    position:relative;
  }
  .map-grid{
    display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:center;
  }
  @media(max-width:900px){.map-grid{grid-template-columns:1fr;gap:40px}}
  .map-side h2{margin-bottom:20px;color:var(--ink)}
  .map-side p{color:var(--ink-soft);margin-bottom:32px;font-size:1.05rem}
  .area-list{
    display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;list-style:none;
  }
  .area-list li{
    display:flex;align-items:center;gap:10px;
    padding:10px 0;color:var(--ink);font-size:.95rem;
    border-bottom:1px solid var(--line);
  }
  .area-list li::before{
    content:'';width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0;
  }
  .map-frame{
    position:relative;
    border:1px solid var(--line);
    border-radius:var(--radius);
    box-shadow:var(--shadow-lg);
    overflow:hidden;
    aspect-ratio:4/3;
    background:var(--white);
  }
  .map-frame::before{
    content:'';position:absolute;top:0;left:0;right:0;height:5px;
    background:var(--red);z-index:3;
  }
  .map-frame iframe{
    width:100%;height:100%;border:0;
    transition:filter .4s var(--ease);
  }
  .map-pin{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);
    z-index:2;pointer-events:none;
    animation:bob 2.4s ease-in-out infinite;
  }
  @keyframes bob{0%,100%{transform:translate(-50%,-100%)}50%{transform:translate(-50%,-110%)}}
  .map-pin svg{width:42px;height:42px;filter:drop-shadow(0 4px 12px rgba(225,6,0,.6))}

  /* ---------- Footer ---------- */
  footer{
    background:var(--ink);color:#bcbcbc;
    padding:72px 0 28px;
  }
  footer .logo,footer .nav-links a{color:var(--white)}
  .foot-grid{
    display:grid;
    grid-template-columns:1.6fr 1fr 1fr 1fr;
    gap:48px;margin-bottom:48px;
  }
  @media(max-width:960px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
  @media(max-width:520px){.foot-grid{grid-template-columns:1fr;gap:28px}}
  .foot-col h5{
    font-family:'Bebas Neue', Impact, sans-serif;
    font-size:.95rem;letter-spacing:.18em;
    margin-bottom:18px;color:var(--white);
    text-transform:uppercase;
  }
  .foot-col p{color:#9a9a9a;font-size:.9rem;margin-bottom:8px;line-height:1.55}
  .foot-col a{
    color:#bcbcbc;font-size:.9rem;display:block;
    margin-bottom:8px;text-decoration:none;
    transition:color .2s,transform .2s;
  }
  .foot-col a:hover{color:var(--white);transform:translateX(2px)}
  .foot-tagline{
    color:#9a9a9a;font-size:.92rem;line-height:1.6;
    margin-bottom:20px;max-width:300px;
  }
  footer .bbb-seal{
    display:inline-block;margin-top:4px;
    filter:none;opacity:.95;
    transition:opacity .25s,transform .25s;
  }
  footer .bbb-seal:hover{opacity:1;transform:translateY(-1px)}
  footer .bbb-seal img{height:54px;border-radius:4px}
  .foot-bottom{
    border-top:1px solid rgba(255,255,255,.08);
    padding-top:24px;
    display:flex;justify-content:space-between;align-items:center;
    flex-wrap:wrap;gap:14px;
    font-size:.78rem;color:#7a7a7a;
    letter-spacing:.02em;
  }
  .foot-bottom a{color:#7a7a7a;display:inline;margin:0;font-size:.78rem;transition:color .2s}
  .foot-bottom a:hover{color:#bcbcbc;transform:none}
  .foot-bottom .foot-legal{display:flex;gap:16px;flex-wrap:wrap}
