/* ================================================================
   ROOFSPAN BLOCKS — Complete Design System v1.0
   All styles scoped to .rsb- prefix so they never conflict
   with your theme. Safe to use alongside any WordPress theme.
================================================================ */
:root{
  --rsb-or:#e8520a; --rsb-or2:#c04408; --rsb-or3:#ff6b2b;
  --rsb-glow:rgba(232,82,10,.25); --rsb-dim:rgba(232,82,10,.10);
  --rsb-ink:#060809; --rsb-dk1:#0b1018; --rsb-dk2:#101720;
  --rsb-dk3:#16212e; --rsb-dk4:#1e2d3d; --rsb-steel:#2a3d52;
  --rsb-wh:#fff; --rsb-g1:#f2f4f7; --rsb-g2:#e1e5ea;
  --rsb-g4:#94a3b8; --rsb-g6:#475569;
  --rsb-fd:'Barlow Condensed',sans-serif;
  --rsb-fb:'Barlow',sans-serif;
  --rsb-r:8px; --rsb-r2:14px;
  --rsb-t:.28s cubic-bezier(.4,0,.2,1);
}

/* ── Shared utilities ── */
.rsb-wrap{max-width:1240px;margin:0 auto;padding:0 40px}
.rsb-ey{font-family:var(--rsb-fd);font-size:.75rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--rsb-or);display:block;margin-bottom:14px}
.rsb-h2{font-family:var(--rsb-fd);font-weight:900;line-height:1.04;margin:0}
.rsb-h2-lt{color:#fff} .rsb-h2-dk{color:#0b1018}
.rsb-p{font-family:var(--rsb-fb);font-size:.97rem;line-height:1.82;margin:0}
.rsb-p-lt{color:rgba(255,255,255,.55)} .rsb-p-dk{color:#475569}
.rsb-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--rsb-fd);font-weight:700;font-size:.95rem;letter-spacing:.08em;text-transform:uppercase;padding:14px 34px;border-radius:var(--rsb-r);border:2px solid transparent;cursor:pointer;text-decoration:none;transition:all var(--rsb-t)}
.rsb-btn:hover{transform:translateY(-2px)}
.rsb-btn-or{background:var(--rsb-or);color:#fff;border-color:var(--rsb-or)}
.rsb-btn-or:hover{background:var(--rsb-or2);border-color:var(--rsb-or2);box-shadow:0 0 50px var(--rsb-glow);color:#fff}
.rsb-btn-gh{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.rsb-btn-gh:hover{border-color:#fff;background:rgba(255,255,255,.06);color:#fff}
.rsb-btn-do{background:transparent;color:var(--rsb-or);border-color:var(--rsb-or)}
.rsb-btn-do:hover{background:var(--rsb-or);color:#fff}
/* Scroll reveal */
.rsb-rv,.rsb-rl,.rsb-rr{opacity:0;transition:opacity .7s ease,transform .7s ease}
.rsb-rv{transform:translateY(32px)} .rsb-rl{transform:translateX(-32px)} .rsb-rr{transform:translateX(32px)}
.rsb-rv.on,.rsb-rl.on,.rsb-rr.on{opacity:1;transform:none}
@media(max-width:640px){.rsb-wrap{padding:0 20px}}

/* ================================================================
   1 — HERO
================================================================ */
.rsb-hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--rsb-ink)}
.rsb-hero-vid{position:absolute;inset:0;z-index:0;overflow:hidden}
.rsb-hero-vid video{width:100%;height:100%;object-fit:cover;opacity:.28}
.rsb-hero-vid::after{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(6,8,9,.45) 0%,rgba(6,8,9,.75) 55%,rgba(6,8,9,.97) 100%)}
.rsb-hero-grid{position:absolute;inset:0;z-index:1;pointer-events:none;background-image:linear-gradient(rgba(232,82,10,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(232,82,10,.06) 1px,transparent 1px);background-size:90px 90px;animation:rsb-grid 28s linear infinite;mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.6) 30%,rgba(0,0,0,.6) 70%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.6) 30%,rgba(0,0,0,.6) 70%,transparent 100%)}
@keyframes rsb-grid{to{background-position:90px 90px}}
.rsb-hero-orb{position:absolute;border-radius:50%;pointer-events:none;z-index:1}
.rsb-orb1{width:900px;height:900px;top:-25%;right:-15%;background:radial-gradient(circle,rgba(232,82,10,.16) 0%,transparent 58%);animation:rsb-float1 18s ease-in-out infinite}
.rsb-orb2{width:500px;height:500px;bottom:5%;left:-10%;background:radial-gradient(circle,rgba(14,20,30,.9) 0%,transparent 65%);animation:rsb-float2 22s ease-in-out infinite}
@keyframes rsb-float1{0%,100%{transform:translate(0,0)}50%{transform:translate(-25px,-18px)}}
@keyframes rsb-float2{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-15px)}}
.rsb-hero-grain{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px}
.rsb-hero-slash{position:absolute;right:0;top:0;width:50%;height:100%;z-index:1;background:linear-gradient(135deg,transparent 0%,rgba(232,82,10,.035) 100%);clip-path:polygon(25% 0%,100% 0%,100% 100%,0% 100%);pointer-events:none}
.rsb-hero-body{position:relative;z-index:3;padding-top:100px;padding-bottom:0;flex:1;display:flex;align-items:flex-end}
.rsb-hero-content{max-width:740px;padding-bottom:48px}
.rsb-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(232,82,10,.10);border:1px solid rgba(232,82,10,.35);border-radius:100px;padding:6px 18px 6px 10px;margin-bottom:30px}
.rsb-badge-dot{width:9px;height:9px;border-radius:50%;background:var(--rsb-or);animation:rsb-pulse 2.4s ease-in-out infinite}
@keyframes rsb-pulse{0%,100%{box-shadow:0 0 0 3px rgba(232,82,10,.3)}50%{box-shadow:0 0 0 9px rgba(232,82,10,0)}}
.rsb-badge-txt{font-family:var(--rsb-fd);font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--rsb-or)}
.rsb-hero-h1{font-family:var(--rsb-fd);font-weight:900;color:#fff;font-size:clamp(3.5rem,9vw,8rem);line-height:.9;letter-spacing:-.01em;margin-bottom:28px}
.rsb-hero-h1 .rsb-line{display:block;overflow:hidden}
.rsb-hero-h1 .rsb-line span{display:inline-block;animation:rsb-slideUp .9s cubic-bezier(.16,1,.3,1) both}
.rsb-hero-h1 .rsb-line:nth-child(2) span{animation-delay:.12s}
.rsb-hero-h1 .rsb-line:nth-child(3) span{animation-delay:.24s}
.rsb-hero-h1 .rsb-accent{color:var(--rsb-or)}
@keyframes rsb-slideUp{from{transform:translateY(110%);opacity:0}to{transform:translateY(0);opacity:1}}
.rsb-hero-sub{font-family:var(--rsb-fb);font-size:1.1rem;color:rgba(255,255,255,.6);max-width:520px;line-height:1.78;margin-bottom:44px;animation:rsb-fadeIn .8s ease .5s both}
@keyframes rsb-fadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.rsb-hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px;animation:rsb-fadeIn .8s ease .65s both}
.rsb-hero-trust{display:flex;align-items:center;gap:14px;animation:rsb-fadeIn .8s ease .8s both}
.rsb-trust-avas{display:flex}
.rsb-tav{width:32px;height:32px;border-radius:50%;background:#1e2d3d;border:2px solid #0b1018;font-family:var(--rsb-fd);font-weight:800;font-size:.65rem;color:#fff;display:flex;align-items:center;justify-content:center;margin-right:-8px}
.rsb-hero-trust-txt{font-family:var(--rsb-fd);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-left:18px}
/* Stats bar */
.rsb-stats-bar{position:relative;z-index:3;background:rgba(6,8,9,.78);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.06)}
.rsb-stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.rsb-stat{padding:26px 36px;border-right:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden}
.rsb-stat:last-child{border-right:none}
.rsb-stat::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--rsb-or);transform:scaleX(0);transition:transform .4s ease}
.rsb-stat:hover::before{transform:scaleX(1)}
.rsb-stat-n{font-family:var(--rsb-fd);font-size:clamp(2rem,3.5vw,3rem);font-weight:900;color:var(--rsb-or);line-height:1;display:block}
.rsb-stat-l{font-family:var(--rsb-fd);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:6px;display:block}
@media(max-width:900px){.rsb-stats-grid{grid-template-columns:repeat(2,1fr)}.rsb-stat:nth-child(2){border-right:none}}
@media(max-width:480px){.rsb-stats-grid{grid-template-columns:1fr}.rsb-stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.05)}.rsb-hero-btns{flex-direction:column}}

/* ================================================================
   2 — EMERGENCY BAND
================================================================ */
.rsb-emg{background:linear-gradient(90deg,#700000,#c0392b 40%,#c0392b 60%,#700000);background-size:200% 100%;animation:rsb-emg 4s ease-in-out infinite;position:relative;overflow:hidden}
@keyframes rsb-emg{0%,100%{background-position:0%}50%{background-position:100%}}
.rsb-emg::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,rgba(255,255,255,.025) 0,rgba(255,255,255,.025) 8px,transparent 8px,transparent 18px)}
.rsb-emg-inner{position:relative;z-index:1;display:flex;align-items:stretch;min-height:68px}
.rsb-emg-content{display:flex;align-items:center;gap:16px;padding:14px 40px;flex:1}
.rsb-emg-ico{font-size:1.9rem;animation:rsb-zap .75s ease-in-out infinite alternate}
@keyframes rsb-zap{to{transform:scale(1.25) rotate(6deg)}}
.rsb-emg-txt strong{font-family:var(--rsb-fd);font-size:1.3rem;font-weight:900;color:#fff;display:block}
.rsb-emg-txt span{font-size:.84rem;color:rgba(255,255,255,.72)}
.rsb-emg-cta{background:rgba(255,255,255,.12);color:#fff;font-family:var(--rsb-fd);font-size:.84rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:0 44px;display:flex;align-items:center;gap:10px;border:none;border-left:1px solid rgba(255,255,255,.15);text-decoration:none;flex-shrink:0;transition:background var(--rsb-t)}
.rsb-emg-cta:hover{background:rgba(255,255,255,.22);color:#fff}
@media(max-width:768px){.rsb-emg-inner{flex-direction:column;padding:20px}.rsb-emg-content{padding:0}.rsb-emg-cta{padding:14px 24px;border-left:none;border-radius:var(--rsb-r)}}

/* ================================================================
   3 — BEFORE / AFTER SLIDER
================================================================ */
.rsb-ba-section{background:var(--rsb-dk1);padding:112px 0}
.rsb-ba-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:center}
.rsb-ba-info h2{font-family:var(--rsb-fd);font-weight:900;font-size:clamp(2rem,3.5vw,2.8rem);color:#fff;margin:0 0 18px}
.rsb-ba-sub{color:rgba(255,255,255,.52);font-family:var(--rsb-fb);font-size:.97rem;line-height:1.82}
.rsb-ba-points{display:flex;flex-direction:column;gap:22px;margin-top:32px}
.rsb-bap{display:flex;gap:16px;align-items:flex-start}
.rsb-bap-ico{width:46px;height:46px;border-radius:var(--rsb-r);background:rgba(232,82,10,.10);border:1px solid rgba(232,82,10,.22);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.rsb-bap strong{display:block;color:#fff;font-weight:600;margin-bottom:4px;font-family:var(--rsb-fb)}
.rsb-bap span{font-size:.86rem;color:rgba(255,255,255,.42);line-height:1.68;font-family:var(--rsb-fb)}
.rsb-ba-slider{position:relative;border-radius:var(--rsb-r2);overflow:hidden;aspect-ratio:16/10;cursor:ew-resize;user-select:none;box-shadow:0 32px 100px rgba(0,0,0,.6)}
.rsb-ba-before,.rsb-ba-after{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.rsb-ba-before{background:linear-gradient(135deg,#1e2d3d,#2d3f52)}
.rsb-ba-after{background:linear-gradient(135deg,#0b1018,#141e2c);clip-path:inset(0 50% 0 0)}
.rsb-ba-ph-title{font-family:var(--rsb-fd);font-size:1.2rem;font-weight:800;margin-bottom:6px}
.rsb-ba-before .rsb-ba-ph-title{color:rgba(255,255,255,.4)}
.rsb-ba-after  .rsb-ba-ph-title{color:var(--rsb-or)}
.rsb-ba-ph-sub{font-size:.75rem;color:rgba(255,255,255,.2);font-family:var(--rsb-fd);letter-spacing:.1em;text-transform:uppercase}
.rsb-ba-ph-icon{font-size:3rem;opacity:.3;margin-bottom:8px}
.rsb-ba-bar{position:absolute;top:0;bottom:0;left:50%;z-index:10;width:3px;background:var(--rsb-or);transform:translateX(-50%);box-shadow:0 0 20px rgba(232,82,10,.7);pointer-events:none}
.rsb-ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:var(--rsb-or);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;font-weight:900;box-shadow:0 0 0 6px rgba(232,82,10,.25),0 8px 30px rgba(0,0,0,.5)}
.rsb-ba-cap{position:absolute;bottom:20px;font-family:var(--rsb-fd);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.6);padding:5px 14px;border-radius:100px;backdrop-filter:blur(8px);pointer-events:none}
.rsb-ba-cap-l{left:20px} .rsb-ba-cap-r{right:20px}
.rsb-ba-hint{text-align:center;margin-top:14px;font-family:var(--rsb-fd);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.2)}
@media(max-width:900px){.rsb-ba-layout{grid-template-columns:1fr;gap:48px}}

/* ================================================================
   4 — COST ESTIMATOR
================================================================ */
.rsb-est-section{background:var(--rsb-dk2);position:relative;overflow:hidden;padding:112px 0}
.rsb-est-section::before{content:'';position:absolute;top:-25%;right:-8%;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(232,82,10,.09) 0%,transparent 60%);pointer-events:none}
.rsb-est-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.rsb-est-panel{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.07);border-radius:var(--rsb-r2);padding:48px}
.rsb-est-title{font-family:var(--rsb-fd);font-size:1.55rem;font-weight:800;color:#fff;margin:0 0 36px}
.rsb-est-title span{color:var(--rsb-or)}
.rsb-ef{margin-bottom:26px}
.rsb-ef label{display:block;font-family:var(--rsb-fd);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.36);margin-bottom:10px}
.rsb-ef input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:5px;border-radius:3px;background:rgba(255,255,255,.09);outline:none;cursor:pointer}
.rsb-ef input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--rsb-or);border:3px solid var(--rsb-dk2);box-shadow:0 0 0 3px rgba(232,82,10,.35);cursor:pointer;transition:transform var(--rsb-t)}
.rsb-ef input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.25)}
.rsb-range-meta{display:flex;justify-content:space-between;margin-top:7px}
.rsb-range-meta span{font-size:.74rem;color:rgba(255,255,255,.24);font-family:var(--rsb-fd)}
.rsb-range-val{font-family:var(--rsb-fd);font-size:1.35rem;font-weight:800;color:var(--rsb-or);margin-top:5px}
.rsb-chips{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.rsb-chip{padding:11px 14px;text-align:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--rsb-r);font-family:var(--rsb-fd);font-size:.84rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.48);cursor:pointer;transition:all var(--rsb-t)}
.rsb-chip:hover{background:rgba(232,82,10,.07);border-color:rgba(232,82,10,.3);color:#fff}
.rsb-chip.on{background:rgba(232,82,10,.12);border-color:var(--rsb-or);color:#fff}
.rsb-est-result{display:flex;flex-direction:column;gap:22px}
.rsb-er-main{text-align:center;padding:40px 28px;background:rgba(232,82,10,.07);border:1px solid rgba(232,82,10,.22);border-radius:var(--rsb-r2);position:relative;overflow:hidden}
.rsb-er-main::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--rsb-or),var(--rsb-or3))}
.rsb-er-label{font-family:var(--rsb-fd);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:12px}
.rsb-er-range{font-family:var(--rsb-fd);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;color:var(--rsb-or);line-height:1}
.rsb-er-note{font-size:.76rem;color:rgba(255,255,255,.28);margin-top:10px;font-family:var(--rsb-fb)}
.rsb-er-rows{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:var(--rsb-r);overflow:hidden}
.rsb-er-row{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.05)}
.rsb-er-row:last-child{border-bottom:none}
.rsb-er-row-l{font-size:.86rem;color:rgba(255,255,255,.42);font-family:var(--rsb-fb)}
.rsb-er-row-v{font-family:var(--rsb-fd);font-weight:700;font-size:.95rem;color:#fff}
.rsb-er-row-v.green{color:#4ade80!important}
.rsb-er-disc{font-size:.74rem;color:rgba(255,255,255,.2);line-height:1.65;font-family:var(--rsb-fb)}
.rsb-er-go{width:100%;padding:16px;background:var(--rsb-or);color:#fff;font-family:var(--rsb-fd);font-size:.95rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:var(--rsb-r);cursor:pointer;transition:background var(--rsb-t),transform var(--rsb-t),box-shadow var(--rsb-t)}
.rsb-er-go:hover{background:var(--rsb-or2);transform:translateY(-2px);box-shadow:0 0 50px var(--rsb-glow)}
@media(max-width:900px){.rsb-est-layout{grid-template-columns:1fr;gap:48px}.rsb-est-panel{padding:32px}}

/* ================================================================
   5 — TESTIMONIALS CAROUSEL
================================================================ */
.rsb-testi-section{background:var(--rsb-g1);padding:112px 0}
.rsb-carousel-outer{overflow:hidden}
.rsb-carousel-track{display:flex;gap:24px;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.rsb-tc{flex:0 0 calc(33.333% - 16px);background:#fff;border:1px solid var(--rsb-g2);border-radius:var(--rsb-r2);padding:36px 32px;position:relative;transition:box-shadow var(--rsb-t),transform var(--rsb-t),border-color var(--rsb-t)}
.rsb-tc::before{content:'';position:absolute;inset:0 0 auto;height:3px;background:var(--rsb-or);border-radius:var(--rsb-r2) var(--rsb-r2) 0 0;transform:scaleX(0);transition:transform .4s ease}
.rsb-tc:hover{box-shadow:0 16px 56px rgba(0,0,0,.1);transform:translateY(-7px);border-color:rgba(232,82,10,.22)}
.rsb-tc:hover::before{transform:scaleX(1)}
.rsb-tc-stars{color:var(--rsb-or);font-size:1.05rem;letter-spacing:2px;margin-bottom:18px}
.rsb-tc-text{font-size:.94rem;color:var(--rsb-g6);line-height:1.8;margin-bottom:24px;font-style:italic;font-family:var(--rsb-fb)}
.rsb-tc-who{display:flex;align-items:center;gap:14px}
.rsb-tc-av{width:44px;height:44px;border-radius:50%;background:var(--rsb-or);font-family:var(--rsb-fd);font-weight:900;font-size:.9rem;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rsb-tc-name{font-weight:600;font-size:.9rem;color:var(--rsb-dk1);font-family:var(--rsb-fb)}
.rsb-tc-role{font-size:.76rem;color:rgba(100,116,139,.7);margin-top:2px;font-family:var(--rsb-fb)}
.rsb-tc-src{display:flex;align-items:center;gap:7px;margin-top:18px;padding-top:16px;border-top:1px solid var(--rsb-g2);font-size:.74rem;color:var(--rsb-g4);font-family:var(--rsb-fb)}
.rsb-g-badge{width:18px;height:18px;border-radius:50%;background:#4285f4;color:#fff;font-weight:900;font-size:.67rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rsb-carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:36px}
.rsb-cdot{width:8px;height:8px;border-radius:50%;background:var(--rsb-g2);cursor:pointer;transition:background var(--rsb-t),transform var(--rsb-t);border:none;padding:0}
.rsb-cdot.on{background:var(--rsb-or);transform:scale(1.4)}
@media(max-width:900px){.rsb-tc{flex:0 0 100%}}

/* ================================================================
   6 — MAP + SERVICE AREA
================================================================ */
.rsb-map-section{background:var(--rsb-dk1);padding:112px 0}
.rsb-map-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.rsb-map-info h2{font-family:var(--rsb-fd);font-weight:900;font-size:clamp(2rem,3.5vw,2.8rem);color:#fff;margin:0 0 18px}
.rsb-map-sub{font-family:var(--rsb-fb);font-size:.97rem;color:rgba(255,255,255,.52);line-height:1.82}
.rsb-area-list{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.rsb-area-row{display:flex;align-items:center;gap:12px}
.rsb-area-dot{width:8px;height:8px;border-radius:50%;background:var(--rsb-or);flex-shrink:0}
.rsb-area-name{font-size:.9rem;color:rgba(255,255,255,.65);font-family:var(--rsb-fb)}
.rsb-area-dist{font-family:var(--rsb-fd);font-size:.72rem;color:rgba(255,255,255,.24);letter-spacing:.08em;margin-left:auto}
.rsb-map-embed{border-radius:var(--rsb-r2);overflow:hidden;height:450px;position:relative;border:1px solid rgba(255,255,255,.06);box-shadow:0 24px 80px rgba(0,0,0,.5)}
.rsb-map-embed iframe{width:100%;height:100%;border:none;filter:grayscale(.4) contrast(1.1) brightness(.85)}
.rsb-map-badge{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(6,8,9,.88);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--rsb-r);padding:16px 20px;display:flex;align-items:center;gap:14px}
.rsb-map-badge-ico{font-size:1.6rem}
.rsb-map-badge strong{display:block;font-family:var(--rsb-fd);font-size:.95rem;font-weight:800;color:#fff}
.rsb-map-badge span{font-size:.8rem;color:rgba(255,255,255,.45);font-family:var(--rsb-fb)}
@media(max-width:900px){.rsb-map-layout{grid-template-columns:1fr;gap:48px}}

/* ================================================================
   7 — FAQ
================================================================ */
.rsb-faq-section{background:var(--rsb-g1);padding:112px 0}
.rsb-faq-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.rsb-faq-intro h2{font-family:var(--rsb-fd);font-weight:900;font-size:clamp(1.8rem,3vw,2.6rem);color:#0b1018;margin:0 0 12px}
.rsb-faq-intro p{font-family:var(--rsb-fb);font-size:.92rem;color:var(--rsb-g6);margin-bottom:40px;line-height:1.75}
.rsb-faq-list{display:flex;flex-direction:column;gap:10px}
.rsb-fqi{background:#fff;border:1px solid var(--rsb-g2);border-radius:var(--rsb-r);overflow:hidden;transition:border-color var(--rsb-t)}
.rsb-fqi:hover{border-color:rgba(232,82,10,.3)}
.rsb-fqq{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 22px;background:none;border:none;text-align:left;cursor:pointer;font-family:var(--rsb-fb);font-size:.94rem;font-weight:600;color:#0b1018;line-height:1.4}
.rsb-fqplus{width:28px;height:28px;border-radius:50%;background:var(--rsb-g1);color:var(--rsb-or);font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--rsb-t),transform var(--rsb-t)}
.rsb-fqi.open .rsb-fqplus{background:var(--rsb-or);color:#fff;transform:rotate(45deg)}
.rsb-fqa{max-height:0;overflow:hidden;transition:max-height .38s ease,padding .32s ease;padding:0 22px}
.rsb-fqi.open .rsb-fqa{max-height:300px;padding:0 22px 20px}
.rsb-fqa p{font-size:.89rem;color:var(--rsb-g6);line-height:1.78;font-family:var(--rsb-fb);margin:0}
.rsb-faq-aside{background:var(--rsb-dk2);border-radius:var(--rsb-r2);padding:48px}
.rsb-faq-aside h3{font-family:var(--rsb-fd);font-size:1.8rem;font-weight:800;color:#fff;margin:0 0 14px}
.rsb-faq-aside p{color:rgba(255,255,255,.5);font-size:.92rem;line-height:1.75;font-family:var(--rsb-fb);margin-bottom:32px}
.rsb-resp-list{display:flex;flex-direction:column;gap:11px;margin-top:32px;padding-top:28px;border-top:1px solid rgba(255,255,255,.07)}
.rsb-resp-row{display:flex;align-items:center;gap:10px;font-size:.88rem;color:rgba(255,255,255,.55);font-family:var(--rsb-fb)}
.rsb-resp-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
@media(max-width:900px){.rsb-faq-layout{grid-template-columns:1fr;gap:52px}}

/* ================================================================
   8 — CONTACT
================================================================ */
.rsb-contact-section{background:var(--rsb-dk1);padding:112px 0}
.rsb-contact-layout{display:grid;grid-template-columns:1fr 1.25fr;gap:80px;align-items:start}
.rsb-contact-info h2{font-family:var(--rsb-fd);font-weight:900;font-size:clamp(2rem,3.5vw,2.8rem);color:#fff;margin:0 0 16px}
.rsb-contact-sub{font-family:var(--rsb-fb);font-size:.97rem;color:rgba(255,255,255,.52);line-height:1.82}
.rsb-ci-list{display:flex;flex-direction:column;gap:18px;margin:32px 0}
.rsb-ci-row{display:flex;gap:14px;align-items:flex-start}
.rsb-ci-ico{width:44px;height:44px;border-radius:50%;background:rgba(232,82,10,.10);border:1px solid rgba(232,82,10,.22);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
.rsb-ci-row strong{display:block;font-family:var(--rsb-fd);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.36);margin-bottom:4px}
.rsb-ci-row a,.rsb-ci-row span{font-size:.93rem;color:rgba(255,255,255,.6);transition:color var(--rsb-t);text-decoration:none;font-family:var(--rsb-fb)}
.rsb-ci-row a:hover{color:var(--rsb-or)}
.rsb-soc-row{display:flex;gap:8px;flex-wrap:wrap}
.rsb-soc{font-family:var(--rsb-fd);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.38);border:1px solid rgba(255,255,255,.1);padding:7px 16px;border-radius:100px;transition:all var(--rsb-t);text-decoration:none}
.rsb-soc:hover{color:#fff;border-color:var(--rsb-or);background:rgba(232,82,10,.1)}
.rsb-cf-box{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:var(--rsb-r2);padding:48px 42px}
.rsb-cf-box h3{font-family:var(--rsb-fd);font-size:1.6rem;font-weight:800;color:#fff;margin:0 0 28px}
.rsb-ff{margin-bottom:18px}
.rsb-ff label{display:block;font-family:var(--rsb-fd);font-size:.7rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.34);margin-bottom:7px}
.rsb-ff input,.rsb-ff select,.rsb-ff textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--rsb-r);color:#fff;font-family:var(--rsb-fb);font-size:.93rem;padding:12px 15px;outline:none;-webkit-appearance:none;appearance:none;transition:border-color var(--rsb-t),background var(--rsb-t);box-sizing:border-box}
.rsb-ff input::placeholder,.rsb-ff textarea::placeholder{color:rgba(255,255,255,.18)}
.rsb-ff input:focus,.rsb-ff select:focus,.rsb-ff textarea:focus{border-color:var(--rsb-or);background:rgba(255,255,255,.05)}
.rsb-ff select option{background:#101720;color:#fff}
.rsb-ff textarea{resize:vertical;min-height:100px}
.rsb-ff-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.rsb-cf-send{width:100%;padding:16px;background:var(--rsb-or);color:#fff;font-family:var(--rsb-fd);font-size:.95rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:var(--rsb-r);cursor:pointer;margin-top:6px;transition:background var(--rsb-t),transform var(--rsb-t),box-shadow var(--rsb-t)}
.rsb-cf-send:hover{background:var(--rsb-or2);transform:translateY(-2px);box-shadow:0 0 50px var(--rsb-glow)}
.rsb-cf-success{text-align:center;padding:60px 20px}
.rsb-cf-success .rsb-success-icon{font-size:3rem;margin-bottom:18px}
.rsb-cf-success h3{font-family:var(--rsb-fd);font-size:1.8rem;font-weight:800;color:#fff;margin:0 0 12px}
.rsb-cf-success p{color:rgba(255,255,255,.5);font-size:.95rem;line-height:1.7;font-family:var(--rsb-fb)}
.rsb-cf-success a{color:var(--rsb-or)}
@media(max-width:900px){.rsb-contact-layout{grid-template-columns:1fr;gap:52px}.rsb-cf-box{padding:32px 24px}}
@media(max-width:600px){.rsb-ff-2{grid-template-columns:1fr}}

/* ================================================================
   SMS CALLBACK WIDGET — Fixed floating button
================================================================ */
#rsb-sms-widget{position:fixed;bottom:28px;right:28px;z-index:9999}
.rsb-sms-fab{width:58px;height:58px;border-radius:50%;background:var(--rsb-or);border:none;color:#fff;cursor:pointer;box-shadow:0 8px 32px rgba(232,82,10,.45),0 2px 8px rgba(0,0,0,.3);transition:transform var(--rsb-t),box-shadow var(--rsb-t);display:flex;align-items:center;justify-content:center;animation:rsb-fabPop .5s cubic-bezier(.34,1.56,.64,1) 2s both;position:relative}
@keyframes rsb-fabPop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.rsb-sms-fab:hover{transform:scale(1.1);box-shadow:0 12px 48px rgba(232,82,10,.55)}
.rsb-sms-ring{position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(232,82,10,.4);animation:rsb-ring 2.5s ease-out infinite;pointer-events:none}
@keyframes rsb-ring{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.7);opacity:0}}
.rsb-sms-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:#ef4444;border:2px solid #060809;font-size:.6rem;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--rsb-fd);animation:rsb-badge 1s ease-in-out infinite alternate}
@keyframes rsb-badge{from{transform:scale(1)}to{transform:scale(1.2)}}
.rsb-sms-panel{position:absolute;bottom:72px;right:0;width:320px;background:#101720;border:1px solid rgba(255,255,255,.08);border-radius:var(--rsb-r2);box-shadow:0 24px 80px rgba(0,0,0,.6);overflow:hidden;transform-origin:bottom right;transform:scale(.85) translateY(10px);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .28s ease}
.rsb-sms-panel.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}
.rsb-sms-hdr{background:var(--rsb-or);padding:18px 20px;display:flex;align-items:center;justify-content:space-between}
.rsb-sms-hdr strong{font-family:var(--rsb-fd);font-size:1.1rem;font-weight:800;color:#fff;display:block}
.rsb-sms-hdr span{font-size:.78rem;color:rgba(255,255,255,.75);font-family:var(--rsb-fb)}
.rsb-sms-close{background:rgba(255,255,255,.2);border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background var(--rsb-t)}
.rsb-sms-close:hover{background:rgba(255,255,255,.35)}
.rsb-sms-body{padding:22px 20px}
.rsb-sms-body p{font-size:.86rem;color:rgba(255,255,255,.55);line-height:1.65;margin-bottom:18px;font-family:var(--rsb-fb)}
.rsb-sms-input{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--rsb-r);color:#fff;font-family:var(--rsb-fb);font-size:.9rem;padding:12px 15px;outline:none;margin-bottom:10px;transition:border-color var(--rsb-t);box-sizing:border-box}
.rsb-sms-input:focus{border-color:var(--rsb-or)}
.rsb-sms-input::placeholder{color:rgba(255,255,255,.2)}
.rsb-sms-submit{width:100%;padding:13px;background:var(--rsb-or);color:#fff;font-family:var(--rsb-fd);font-size:.9rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:var(--rsb-r);cursor:pointer;transition:background var(--rsb-t)}
.rsb-sms-submit:hover{background:var(--rsb-or2)}
.rsb-sms-or{text-align:center;font-size:.75rem;color:rgba(255,255,255,.3);margin:12px 0;font-family:var(--rsb-fd);letter-spacing:.1em;text-transform:uppercase}
.rsb-sms-call{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--rsb-fd);font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--rsb-or);padding:10px;border:1px solid rgba(232,82,10,.3);border-radius:var(--rsb-r);transition:all var(--rsb-t);text-decoration:none}
.rsb-sms-call:hover{background:rgba(232,82,10,.1);color:var(--rsb-or)}
.rsb-sms-ok{text-align:center;padding:24px 20px}
.rsb-sms-ok .rsb-sms-ok-icon{font-size:2.4rem;margin-bottom:12px}
.rsb-sms-ok strong{color:#4ade80;font-family:var(--rsb-fd);font-size:1.2rem;display:block;margin-bottom:8px}
.rsb-sms-ok p{color:rgba(255,255,255,.5);font-size:.88rem;font-family:var(--rsb-fb)}
@media(max-width:480px){#rsb-sms-widget{bottom:16px;right:16px}.rsb-sms-panel{width:calc(100vw - 32px)}}
