/*
Theme Name: NOLA Dumpster Rentals
Theme URI: https://nola-dumpsters.com/
Author: NOLA Dumpster Rentals
Author URI: https://nola-dumpsters.com/
Description: Lead-generation microsite + blog for fast, affordable roll-off dumpster rental across Greater New Orleans. Service-area business, 24/7 phone booking.
Version: 2.0.0
Requires at least: 5.5
Tested up to: 6.5
Requires PHP: 7.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: nola-dumpsters
*/

:root{
    --purple:#3d1a6e; --purple-dark:#240f45; --purple-deep:#1a0b32; --purple-mid:#5a2d9a;
    --gold:#c9960c; --gold-light:#e8b922; --gold-pale:#f7e9b0;
    --green:#145c2e; --green-mid:#1e7d3e;
    --cream:#fdfaf3; --white:#ffffff;
    --ink:#1a1030; --ink-mid:#3d3452; --ink-light:#6b6080;
    --line:#ece6f0;
    --shadow-sm:0 1px 3px rgba(36,15,69,.08), 0 1px 2px rgba(36,15,69,.06);
    --shadow-md:0 8px 24px rgba(36,15,69,.10);
    --shadow-lg:0 20px 50px rgba(36,15,69,.18);
    --container:1200px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;max-width:100%}
  body{
    font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--white);
    -webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden;width:100%;max-width:100%;position:relative;
  }
  h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.1;color:var(--ink);letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .container{max-width:var(--container);margin:0 auto;padding:0 24px}
  .font-ui{font-family:'Inter',sans-serif}
  .eyebrow{font-family:'Inter',sans-serif;font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}

  /* ---- decorative ---- */
  .tricolor-bar{height:3px;background:linear-gradient(90deg,var(--purple) 33.33%,var(--gold) 33.33%,var(--gold) 66.66%,var(--green) 66.66%)}
  .fleur-bg{background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Ctext x='50%25' y='55%25' dominant-baseline='middle' text-anchor='middle' font-size='34' fill='%23ffffff' opacity='0.05'%3E⚜%3C/text%3E%3C/svg%3E");background-size:80px 80px}

  /* ---- buttons ---- */
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:'Inter',sans-serif;
    font-weight:800;border:none;border-radius:11px;cursor:pointer;transition:transform .12s ease,box-shadow .2s ease,filter .2s ease;
    white-space:nowrap;font-size:15px;padding:13px 22px;line-height:1}
  .btn:active{transform:translateY(1px)}
  .btn-gold{background:linear-gradient(135deg,#b8850a,#c9960c,#e8b922);color:#1a1030;box-shadow:0 6px 18px rgba(201,150,12,.35)}
  .btn-gold:hover{filter:brightness(1.05);box-shadow:0 10px 26px rgba(201,150,12,.45)}
  .btn-purple{background:linear-gradient(135deg,var(--purple-dark),var(--purple));color:#fff;box-shadow:0 6px 18px rgba(61,26,110,.3)}
  .btn-purple:hover{filter:brightness(1.08)}
  .btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
  .btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}
  .btn-lg{font-size:17px;padding:17px 30px;border-radius:13px}
  .btn-block{width:100%}

  /* ============ TOP UTILITY BAR ============ */
  .utilbar{background:var(--purple-deep);color:#fff;font-size:13px;font-weight:600}
  .utilbar .container{display:flex;align-items:center;justify-content:space-between;height:38px;min-width:0}
  .utilbar .left{display:flex;align-items:center;gap:22px;color:rgba(255,255,255,.7);min-width:0;overflow:hidden}
  .utilbar a{flex-shrink:0}
  .utilbar .left span{display:inline-flex;align-items:center;gap:7px}
  .utilbar .gold-dot{color:var(--gold-light)}
  .utilbar a{color:var(--gold-light);font-weight:800;display:inline-flex;align-items:center;gap:7px}
  @media(max-width:760px){.utilbar .left span.hide-sm{display:none}}

  /* ============ HEADER ============ */
  header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .2s ease}
  header.site.scrolled{box-shadow:var(--shadow-md)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:18px}
  .brand{display:flex;align-items:center;gap:12px}
  .brand .mark{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,#240f45,#3d1a6e);box-shadow:var(--shadow-sm);flex-shrink:0}
  .brand .mark span{color:var(--gold-light);font-size:22px;line-height:1}
  .brand .name{font-family:'Inter',sans-serif;font-weight:800;font-size:18px;color:var(--purple-dark);letter-spacing:-.02em;line-height:1.05;white-space:nowrap}
  .brand .name em{font-style:normal;color:var(--green)}
  .brand .tag{font-size:10px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--gold);margin-top:2px;white-space:nowrap}
  nav.links{display:flex;align-items:center;gap:30px}
  nav.links a{font-size:15px;font-weight:600;color:var(--ink-mid);transition:color .15s}
  nav.links a:hover{color:var(--purple)}
  .nav-cta{display:flex;align-items:center;gap:16px}
  .nav-phone{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--purple-dark);font-size:15px}
  .nav-phone .ico{color:var(--gold)}
  .burger{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--purple-dark)}
  @media(max-width:980px){
    nav.links{display:none}
    .nav-phone{display:none}
    .burger{display:block}
  }
  /* mobile drawer */
  .drawer{display:none;border-top:1px solid var(--line);background:#fff}
  .drawer.open{display:block}
  .drawer a{display:block;padding:14px 24px;font-weight:700;color:var(--ink-mid);border-bottom:1px solid var(--line)}
  .drawer .dcta{padding:16px 24px;display:flex;flex-direction:column;gap:10px}

  /* ============ HERO ============ */
  .hero{position:relative;background:linear-gradient(155deg,#1a0b32 0%,#240f45 48%,#2a1550 100%);color:#fff;overflow:hidden}
  .hero .fleur-bg{position:absolute;inset:0;opacity:1;pointer-events:none}
  .hero .glow{position:absolute;width:620px;height:620px;border-radius:50%;filter:blur(80px);opacity:.4;pointer-events:none}
  .hero .glow.g1{background:#5a2d9a;top:-220px;right:-120px}
  .hero .glow.g2{background:#145c2e;bottom:-260px;left:-160px;opacity:.32}
  .hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding-top:64px;padding-bottom:72px}
  .hero-eyebrow{display:inline-flex;align-items:center;gap:9px;color:var(--gold-light);margin-bottom:20px}
  .hero-eyebrow::before{content:"⚜";font-size:15px}
  .hero h1{font-size:clamp(34px,4.4vw,54px);font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:22px}
  .hero h1 .gold{color:var(--gold-light)}
  .hero .sub{font-size:19px;color:rgba(255,255,255,.78);max-width:540px;margin-bottom:30px;line-height:1.6}
  .hero .cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:26px}
  .hero .callbig{font-size:19px;padding:19px 32px}
  .hero .callbig .num{font-size:21px}
  .trust-inline{display:flex;flex-wrap:wrap;gap:10px 22px;color:rgba(255,255,255,.72);font-size:14px;font-weight:600}
  .trust-inline span{display:inline-flex;align-items:center;gap:8px}
  .trust-inline .chk{color:var(--green-mid);background:rgba(30,125,62,.18);width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}

  /* hero quote card */
  .quote-card{background:#fff;color:var(--ink);border-radius:18px;padding:26px;box-shadow:var(--shadow-lg);position:relative}
  .quote-card .qhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
  .quote-card h3{font-family:'Inter',sans-serif;font-weight:800;font-size:20px;color:var(--purple-dark)}
  .quote-card .qbadge{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green);background:#e8f3ec;padding:5px 10px;border-radius:999px}
  .quote-card p.qsub{font-size:13.5px;color:var(--ink-light);margin-bottom:18px}
  .field{margin-bottom:13px}
  .field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-mid);margin-bottom:6px}
  .field input,.field select{width:100%;padding:12px 13px;border:1.5px solid var(--line);border-radius:10px;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s}
  .field input:focus,.field select:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(61,26,110,.14)}
  .field-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
  .quote-card .ortext{text-align:center;font-size:13px;color:var(--ink-light);margin-top:14px}
  .quote-card .ortext a{font-weight:800;color:var(--purple)}
  .call-card{text-align:center}
  .call-card .cc-eyebrow{color:var(--gold);display:block;margin-bottom:12px}
  .call-card .cc-head{font-family:'Playfair Display',serif;font-weight:800;font-size:26px;color:var(--purple-dark);line-height:1.12;margin-bottom:8px}
  .call-card .cc-sub{font-size:14.5px;color:var(--ink-light);margin-bottom:18px}
  .call-card .cc-number{display:block;font-family:'Playfair Display',serif;font-weight:800;font-size:clamp(26px,7vw,38px);color:var(--purple);letter-spacing:-.01em;margin-bottom:16px;line-height:1;white-space:nowrap}
  .call-card .cc-number:hover{color:var(--purple-mid)}
  .call-card .cc-rows{margin-top:20px;padding-top:18px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:11px;text-align:left}
  .call-card .cc-row{display:flex;align-items:center;gap:11px;font-size:13.5px;font-weight:600;color:var(--ink-mid)}
  .call-card .cc-ic{width:30px;height:30px;border-radius:8px;background:#f3eef8;color:var(--purple);display:flex;align-items:center;justify-content:center;flex-shrink:0}
  @media(max-width:920px){
    .hero .container{grid-template-columns:1fr;gap:38px;padding-top:48px;padding-bottom:54px}
    .hero .sub{max-width:none}
  }

  /* ============ TRUST STRIP ============ */
  .trust-strip{background:var(--cream);border-bottom:1px solid var(--line)}
  .trust-strip .container{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:26px 24px}
  .trust-item{display:flex;align-items:center;gap:14px}
  .trust-item .ti-ic{width:46px;height:46px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);color:var(--purple)}
  .trust-item .ti-t{font-weight:800;font-size:15px;color:var(--purple-dark);line-height:1.2}
  .trust-item .ti-s{font-size:12.5px;color:var(--ink-light);font-weight:600}
  @media(max-width:880px){.trust-strip .container{grid-template-columns:1fr 1fr;gap:18px}}
  @media(max-width:480px){.trust-strip .container{grid-template-columns:1fr}}

  /* ============ SECTION SHELL ============ */
  section.block{padding:84px 0}
  .sec-head{text-align:center;max-width:680px;margin:0 auto 52px}
  .sec-head .eyebrow{color:var(--gold);margin-bottom:14px;display:block}
  .sec-head h2{font-size:clamp(30px,3.6vw,44px);font-weight:800;margin-bottom:16px;line-height:1.16}
  .sec-head p{font-size:18px;color:var(--ink-light);line-height:1.6}
  .sec-head.left{text-align:left;margin-left:0}

  /* ============ SIZE CARDS ============ */
  .sizes{background:var(--white)}
  .size-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
  .size-card{border:1px solid var(--line);border-radius:16px;padding:26px 22px 24px;background:#fff;transition:transform .18s ease,box-shadow .2s ease,border-color .2s;position:relative;display:flex;flex-direction:column}
  .size-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#e0d6ea}
  .size-card.popular{border-color:var(--gold);box-shadow:0 10px 30px rgba(201,150,12,.16)}
  .size-card .poptag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#b8850a,#e8b922);color:#1a1030;font-family:'Inter',sans-serif;font-size:11px;font-weight:900;letter-spacing:.07em;text-transform:uppercase;padding:5px 14px;border-radius:999px;white-space:nowrap;box-shadow:var(--shadow-sm)}
  .dumpster-ico{height:62px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:14px}
  .size-card h3{font-family:'Inter',sans-serif;font-weight:900;font-size:30px;color:var(--purple-dark);line-height:1;text-align:center}
  .size-card h3 .yd{font-size:14px;font-weight:800;color:var(--ink-light);display:block;margin-top:5px;letter-spacing:.04em;text-transform:uppercase}
  .size-card .dims{text-align:center;font-size:12.5px;font-weight:700;color:var(--green);margin:10px 0 14px;font-family:'Inter',sans-serif}
  .size-card ul{list-style:none;margin:0 0 18px;padding-top:14px;border-top:1px solid var(--line)}
  .size-card ul li{font-size:13.5px;color:var(--ink-mid);font-weight:600;padding:5px 0 5px 22px;position:relative}
  .size-card ul li::before{content:"";position:absolute;left:0;top:10px;width:13px;height:13px;border-radius:50%;background:#e8f3ec;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%23145c2e' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
  .size-card .scta{margin-top:auto}
  @media(max-width:980px){.size-grid{grid-template-columns:1fr 1fr;gap:26px}}
  @media(max-width:520px){.size-grid{grid-template-columns:1fr}}

  /* ============ HOW IT WORKS ============ */
  .how{background:var(--cream)}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;position:relative}
  .step{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 26px;text-align:center;position:relative}
  .step .snum{width:54px;height:54px;border-radius:50%;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;
    font-family:'Playfair Display',serif;font-weight:800;font-size:24px;color:#fff;background:linear-gradient(135deg,var(--purple-dark),var(--purple))}
  .step.s2 .snum{background:linear-gradient(135deg,#b8850a,#c9960c)}
  .step.s2 .snum{color:#1a1030}
  .step.s3 .snum{background:linear-gradient(135deg,var(--green),var(--green-mid))}
  .step h3{font-family:'Inter',sans-serif;font-weight:800;font-size:20px;color:var(--purple-dark);margin-bottom:10px}
  .step p{font-size:15px;color:var(--ink-light)}
  @media(max-width:820px){.steps{grid-template-columns:1fr;gap:18px}}

  /* ============ WHY / LOCAL ============ */
  .why .container{display:grid;grid-template-columns:1.04fr 1fr;gap:54px;align-items:center}
  .why-photo{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);min-height:430px;position:relative;
    background:linear-gradient(160deg,#2a1550,#3d1a6e)}
  .why-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  .why-list{display:flex;flex-direction:column;gap:22px;margin-top:8px}
  .why-item{display:flex;gap:16px}
  .why-item .wi-ic{width:46px;height:46px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#f3eef8;color:var(--purple)}
  .why-item h4{font-family:'Inter',sans-serif;font-weight:800;font-size:17px;color:var(--purple-dark);margin-bottom:4px}
  .why-item p{font-size:14.5px;color:var(--ink-light)}
  @media(max-width:880px){.why .container{grid-template-columns:1fr;gap:34px}.why-photo{min-height:300px;order:-1}}

  /* ============ GALLERY / SEEN AROUND TOWN ============ */
  .gallery{background:#fff}
  .gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:242px;gap:18px;margin-top:44px}
  .gal-item{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);margin:0}
  .gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
  .gal-item:hover img{transform:scale(1.045)}
  .gal-wide{grid-column:span 2}
  .gal-tall{grid-row:span 2}
  .gal-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:34px 18px 15px;background:linear-gradient(transparent,rgba(26,11,50,.55) 45%,rgba(26,11,50,.88))}
  .gal-loc{color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:14.5px;display:flex;align-items:center;gap:8px;line-height:1.3}
  .gal-loc .pin{color:var(--gold-light);flex-shrink:0;display:inline-flex}
  .gal-note{text-align:center;margin-top:30px;font-size:15px;color:var(--ink-light)}
  @media(max-width:880px){.gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}.gal-wide{grid-column:span 2}.gal-tall{grid-row:span 1}}
  @media(max-width:560px){.gal-grid{grid-template-columns:1fr;grid-auto-rows:230px}.gal-wide{grid-column:span 1}}

  /* branded panel (no-photo) */
  .why-panel{display:flex;align-items:center;justify-content:center;overflow:hidden}
  .why-panel .wp-fleur{position:absolute;font-size:340px;line-height:1;color:rgba(232,185,34,.06);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
  .why-panel .wp-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px}
  .why-panel .wp-dumpster{margin-bottom:22px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.25))}
  .why-panel .wp-name{font-family:'Playfair Display',serif;font-weight:800;font-size:30px;color:#fff;letter-spacing:-.01em}
  .why-panel .wp-name span{color:var(--gold-light)}
  .why-panel .wp-tag{font-family:'Inter',sans-serif;font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:10px}
  .why-panel .wp-bar{display:flex;gap:0;margin-top:22px;width:140px;height:5px;border-radius:3px;overflow:hidden}
  .why-panel .wp-bar span{flex:1}
  .why-panel .wp-bar span:nth-child(1){background:var(--purple-mid)}
  .why-panel .wp-bar span:nth-child(2){background:var(--gold)}
  .why-panel .wp-bar span:nth-child(3){background:var(--green-mid)}

  /* ============ SERVICE AREAS ============ */
  .areas{background:var(--white)}
  .area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .area-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:12px;padding:15px 16px;font-weight:700;font-size:14.5px;color:var(--ink-mid);background:#fff;transition:border-color .15s,background .15s,color .15s}
  .area-chip:hover{border-color:var(--purple);background:#faf7fd;color:var(--purple-dark)}
  .area-chip .pin{color:var(--gold);flex-shrink:0}
  @media(max-width:820px){.area-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:420px){.area-grid{grid-template-columns:1fr}}
  .areas-note{text-align:center;margin-top:26px;font-size:15px;color:var(--ink-light)}
  .areas-note a{color:var(--purple);font-weight:800}

  /* ============ TESTIMONIALS ============ */
  .reviews{background:var(--cream)}
  .rev-top{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}
  .rev-stars{color:var(--gold);font-size:22px;letter-spacing:2px}
  .rev-score{font-weight:800;color:var(--purple-dark);font-size:16px}
  .rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
  .rev-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;flex-direction:column}
  .rev-card .rstars{color:var(--gold);font-size:15px;letter-spacing:1px;margin-bottom:13px}
  .rev-card p.body{font-size:15px;color:var(--ink-mid);line-height:1.6;margin-bottom:18px;flex:1}
  .rev-card .who{display:flex;align-items:center;gap:12px}
  .rev-card .av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-weight:800;color:#fff;font-size:15px}
  .rev-card .who .nm{font-family:'Inter',sans-serif;font-weight:800;font-size:14.5px;color:var(--purple-dark)}
  .rev-card .who .loc{font-size:12.5px;color:var(--ink-light);font-weight:600}
  @media(max-width:880px){.rev-grid{grid-template-columns:1fr}}

  /* ============ FAQ ============ */
  .faq{background:var(--white)}
  .faq-wrap{max-width:820px;margin:0 auto}
  .faq-item{border:1px solid var(--line);border-radius:14px;margin-bottom:12px;overflow:hidden;background:#fff;transition:box-shadow .2s,border-color .2s}
  .faq-item.open{box-shadow:var(--shadow-sm);border-color:#e0d6ea}
  .faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;font-family:'Inter',sans-serif;font-weight:700;font-size:16.5px;color:var(--purple-dark)}
  .faq-q .pm{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:#f3eef8;color:var(--purple);display:flex;align-items:center;justify-content:center;transition:transform .25s ease,background .2s}
  .faq-item.open .pm{transform:rotate(45deg);background:var(--purple);color:#fff}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
  .faq-a .inner{padding:0 24px 22px;font-size:15px;color:var(--ink-light);line-height:1.65}
  .faq-a .inner a{color:var(--purple);font-weight:700}

  /* ============ BIG CTA BAND ============ */
  .ctaband{position:relative;background:linear-gradient(150deg,#1a0b32,#240f45 55%,#0e3d1e);color:#fff;overflow:hidden}
  .ctaband .fleur-bg{position:absolute;inset:0}
  .ctaband .container{position:relative;z-index:2;text-align:center;padding:74px 24px}
  .ctaband h2{font-size:clamp(30px,4vw,46px);font-weight:800;color:#fff;margin-bottom:16px}
  .ctaband h2 .gold{color:var(--gold-light)}
  .ctaband p{font-size:19px;color:rgba(255,255,255,.78);max-width:600px;margin:0 auto 30px}
  .ctaband .cta-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
  .ctaband .phone-xl{font-family:'Playfair Display',serif;font-weight:800;font-size:clamp(28px,4vw,40px);color:var(--gold-light);display:inline-flex;align-items:center;gap:12px;margin-bottom:22px}

  /* ============ SEO CONTENT ============ */
  .seo{background:var(--cream);border-top:1px solid var(--line)}
  .seo .container{max-width:880px}
  .seo h2{font-size:30px;font-weight:800;margin-bottom:18px}
  .seo h3{font-family:'Inter',sans-serif;font-size:19px;font-weight:800;color:var(--purple-dark);margin:28px 0 10px}
  .seo p{font-size:15.5px;color:var(--ink-mid);margin-bottom:14px;line-height:1.7}
  .seo p a{color:var(--purple);font-weight:700;text-decoration:underline;text-decoration-color:rgba(61,26,110,.3)}

  /* ============ FOOTER ============ */
  footer.site{background:linear-gradient(160deg,#1a0b32 0%,#240f45 60%,#0e3d1e 100%);color:#fff;position:relative}
  footer.site .fleur-bg{position:absolute;inset:0}
  footer.site .container{position:relative;z-index:2;padding:64px 24px 0}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
  .foot-brand .fb-top{display:flex;align-items:center;gap:12px;margin-bottom:18px}
  .foot-brand .fb-mark{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3d1a6e,#5a2d9a)}
  .foot-brand .fb-mark span{color:var(--gold-light);font-size:19px}
  .foot-brand .fb-name{font-family:'Inter',sans-serif;font-weight:800;font-size:17px}
  .foot-brand .fb-name em{font-style:normal;color:var(--gold-light)}
  .foot-brand p{color:rgba(255,255,255,.5);font-size:14px;max-width:280px;margin-top:4px}
  footer.site h4{font-family:'Inter',sans-serif;font-weight:800;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-light);margin-bottom:16px}
  footer.site .fcol a,footer.site .fcol p{display:block;color:rgba(255,255,255,.55);font-size:14.5px;margin-bottom:11px;transition:color .15s}
  footer.site .fcol a:hover{color:#fff}
  footer.site .fcol .ic{color:var(--gold-light);display:inline-flex;align-items:center;gap:9px}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;font-size:12.5px;color:rgba(255,255,255,.32)}
  @media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
  @media(max-width:480px){.foot-grid{grid-template-columns:1fr}}

  /* ============ MOBILE STICKY CALL BAR ============ */
  .mobile-callbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(36,15,69,.12);padding:10px 14px;gap:10px}
  .mobile-callbar a{flex:1}
  @media(max-width:760px){
    .mobile-callbar{display:flex}
    body{padding-bottom:72px}
  }

  .ico{display:inline-flex;flex-shrink:0}

  /* ============ MOBILE OPTIMIZATION ============ */
  @media(max-width:760px){
    .container{padding:0 18px}
    section.block{padding:56px 0}
    .sec-head{margin-bottom:36px}
    .sec-head h2{font-size:clamp(26px,7vw,34px)}
    .sec-head p{font-size:16px}
    .hero h1{font-size:clamp(29px,8vw,40px);margin-bottom:18px}
    .hero .sub{font-size:16.5px;margin-bottom:24px}
    .hero .cta-row{gap:11px}
    .hero .cta-row .btn{width:100%}
    .hero .callbig{font-size:17px;padding:16px 20px}
    .hero .callbig .num{font-size:18px}
    .trust-inline{gap:9px 18px;font-size:13.5px}
    .quote-card.call-card{padding:22px}
    .call-card .cc-head{font-size:23px}
    .call-card .cc-number{font-size:32px}
    .step{padding:26px 22px}
    .why h2{font-size:clamp(26px,7vw,32px)!important}
    .rev-card{padding:22px}
    .faq-q{padding:17px 18px;font-size:15.5px}
    .faq-a .inner{padding:0 18px 20px}
    .ctaband .container{padding:54px 18px}
    .ctaband p{font-size:17px}
    .seo .container{padding:0 18px}
    .seo h2{font-size:25px}
    .seo h3{font-size:18px}
    footer.site .container{padding:48px 18px 0}
  }
  @media(max-width:420px){
    .hero .callbig .num{font-size:16px}
    .call-card .cc-number{font-size:27px}
    .utilbar{font-size:11.5px}
    .utilbar .container{height:34px}
    .brand .name{font-size:16px}
    .brand .mark{width:42px;height:42px}
    .btn{font-size:14.5px}
  }

  /* ============ BLOG ============ */
  .container-narrow{max-width:760px}
  .blog-hero{background:linear-gradient(155deg,#1a0b32,#240f45 60%,#2a1550);color:#fff;padding:64px 0 56px;position:relative;overflow:hidden}
  .blog-hero .fleur-bg{position:absolute;inset:0}
  .blog-hero .container{position:relative;z-index:2}
  .blog-hero .eyebrow{color:var(--gold-light);display:block;margin-bottom:14px}
  .blog-hero h1{font-size:clamp(32px,4.4vw,48px);font-weight:800;color:#fff;margin-bottom:14px}
  .blog-hero p{font-size:18px;color:rgba(255,255,255,.78);max-width:640px}
  .blog-list{background:var(--cream)}
  .post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .18s ease,box-shadow .2s ease,border-color .2s}
  .post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#e0d6ea}
  .pc-thumb{display:block;aspect-ratio:3/2;background:linear-gradient(160deg,#2a1550,#3d1a6e);overflow:hidden;position:relative}
  .pc-thumb img{width:100%;height:100%;object-fit:cover}
  .pc-thumb .pc-fleur{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:96px;color:rgba(232,185,34,.18)}
  .pc-body{padding:22px;display:flex;flex-direction:column;flex:1}
  .pc-meta{font-family:'Inter',sans-serif;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:flex;gap:9px;align-items:center;flex-wrap:wrap}
  .pc-meta > *{white-space:nowrap}
  .pc-meta .date{color:var(--ink-light);font-weight:700;letter-spacing:.02em;text-transform:none}
  .pc-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:800;line-height:1.2;margin-bottom:10px;color:var(--ink)}
  .pc-title a{color:inherit}
  .pc-title a:hover{color:var(--purple)}
  .pc-excerpt{font-size:14.5px;color:var(--ink-light);line-height:1.6;margin-bottom:16px;flex:1}
  .pc-more{font-weight:800;color:var(--purple);font-size:14.5px;display:inline-flex;align-items:center;gap:7px;transition:gap .15s}
  .pc-more:hover{gap:11px}
  .blog-empty{text-align:center;padding:60px 0;color:var(--ink-light);font-size:17px}
  .pagination{display:flex;gap:8px;justify-content:center;margin-top:48px;flex-wrap:wrap}
  .pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 14px;border:1px solid var(--line);border-radius:10px;font-weight:700;color:var(--ink-mid);background:#fff}
  .pagination .page-numbers.current{background:var(--purple);color:#fff;border-color:var(--purple)}
  .pagination a.page-numbers:hover{border-color:var(--purple);color:var(--purple)}

  /* single post */
  .postmain{background:#fff}
  .post-head{padding:54px 0 0}
  .post-head .pc-meta{margin-bottom:14px;font-size:12px}
  .post-title{font-size:clamp(30px,4vw,46px);font-weight:800;line-height:1.12;color:var(--ink)}
  .post-hero{margin:34px 0 0}
  .post-hero img{width:100%;border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow-md);display:block}
  .post-content{padding:36px 0 8px;font-size:18px;line-height:1.75;color:var(--ink-mid)}
  .post-content > *{margin-bottom:22px}
  .post-content h2{font-family:'Playfair Display',serif;font-size:30px;font-weight:800;color:var(--purple-dark);margin:38px 0 4px;line-height:1.2}
  .post-content h3{font-family:'Inter',sans-serif;font-size:21px;font-weight:800;color:var(--purple-dark);margin:28px 0 2px}
  .post-content a{color:var(--purple);font-weight:700;text-decoration:underline;text-decoration-color:rgba(61,26,110,.3)}
  .post-content ul,.post-content ol{padding-left:24px}
  .post-content li{margin-bottom:8px}
  .post-content img{max-width:100%;height:auto;border-radius:12px;border:1px solid var(--line)}
  .post-content blockquote{border-left:3px solid var(--gold);background:var(--cream);padding:18px 22px;border-radius:0 12px 12px 0;font-family:'Playfair Display',serif;font-size:21px;color:var(--purple-dark);font-style:italic}
  .post-content figcaption{font-size:13px;color:var(--ink-light);text-align:center;margin-top:8px}

  /* generic page */
  .page-main{background:#fff}
  .page-head{padding:54px 0 0}
  .page-content{padding:30px 0 8px;font-size:17px;line-height:1.75;color:var(--ink-mid)}
  .page-content > *{margin-bottom:20px}
  .page-content h2{font-family:'Playfair Display',serif;font-size:28px;color:var(--purple-dark);margin:28px 0 8px}

  /* 404 */
  .nf{padding:90px 0;text-align:center}
  .nf .big{font-family:'Playfair Display',serif;font-size:clamp(64px,13vw,128px);color:var(--purple);font-weight:900;line-height:1}
  .nf h1{font-size:clamp(26px,4vw,38px);margin:6px 0 0;color:var(--ink)}
  .nf p{font-size:18px;color:var(--ink-light);margin:14px 0 26px}

  @media(max-width:880px){.post-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:760px){.post-grid{grid-template-columns:1fr}.post-content{font-size:17px}.blog-hero{padding:48px 0 40px}.post-head{padding:40px 0 0}}
