﻿
/* ─── RESET ───────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#0a0a0a;color:#fff;line-height:1.6;font-size:15px;overflow-x:hidden}
img{display:block;width:100%;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:'Inter',sans-serif}
ul{list-style:none}

::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:#111}::-webkit-scrollbar-thumb{background:#333}

/* ─── DESIGN TOKENS ───────────────────────────── */
:root{
  --bg0:#060606;
  --bg1:#0f0f0f;
  --bg2:#171717;
  --bg3:#202020;
  --white:#ffffff;
  --off:#f3f3f3;
  --red:#c41515;
  --red2:#970f0f;
  --gray:#8a8a8a;
  --gray2:#555;
  --bd:#242424;
  --bdl:#e4e4e4;
  --fd:'Bebas Neue',sans-serif;
  --fb:'Inter',sans-serif;
}

/* ─── BUTTONS ─────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:12px 28px;font-family:var(--fb);font-size:13px;font-weight:700;letter-spacing:.6px;border:none;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap;border-radius:2px}
.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:var(--red2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(196,21,21,.4)}
.btn-white{background:#fff;color:#0a0a0a}.btn-white:hover{background:#e8e8e8}
.btn-dark{background:var(--bg2);color:#fff;border:1px solid var(--bd)}.btn-dark:hover{border-color:#555}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45)}.btn-outline:hover{background:#fff;color:#0a0a0a;border-color:#fff}
.btn-outline-dark{background:transparent;color:#0a0a0a;border:1.5px solid #0a0a0a}.btn-outline-dark:hover{background:#0a0a0a;color:#fff}
.btn-lg{padding:15px 38px;font-size:14px}

/* ─── ANNOUNCE BAR ────────────────────────────── */
.ann{background:var(--red);color:#fff;text-align:center;padding:9px 20px;font-size:12px;font-weight:600;letter-spacing:.5px}
.ann a{color:#fff;text-decoration:underline;opacity:.85}.ann a:hover{opacity:1}
.ann-sep{opacity:.5;margin:0 12px}

/* ─── HEADER ──────────────────────────────────── */
header{position:sticky!important;top:0!important;z-index:900;background:var(--bg0)!important;border-bottom:1px solid var(--bd)}
/* WP admin bar pushes sticky header down so it doesn't hide behind it */
.admin-bar header{top:32px!important}
.admin-bar .ann{top:32px;position:sticky;z-index:901}
@media screen and (max-width:782px){.admin-bar header{top:46px!important}.admin-bar .ann{top:46px}}
.hdr{max-width:1320px;margin:0 auto;padding:0 28px;height:70px;display:flex;align-items:center;justify-content:space-between;gap:24px}

/* Logo */
.logo{display:flex;align-items:center;gap:13px;cursor:pointer;flex-shrink:0;text-decoration:none}
.logo-badge{width:56px;height:56px;flex-shrink:0;border-radius:50%;object-fit:cover}
.logo-txt .sup{display:block;font-family:var(--fd);font-size:10px;letter-spacing:3.5px;color:var(--gray);line-height:1}
.logo-txt .name{display:block;font-family:var(--fd);font-size:22px;letter-spacing:2px;color:#fff;line-height:1.1}
.logo-txt .sub{display:block;font-family:var(--fd);font-size:10px;letter-spacing:2px;color:var(--red);line-height:1;margin-top:2px}

/* Nav */
nav{display:flex;align-items:center;gap:2px}
nav a{font-size:13px;font-weight:500;color:var(--gray);padding:8px 14px;border-radius:2px;cursor:pointer;transition:color .18s,background .18s;letter-spacing:.2px}
nav a:hover,nav a.on{color:#fff;background:var(--bg2)}

/* Header right */
.hdr-r{display:flex;align-items:center;gap:16px;flex-shrink:0}
.hdr-phone{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:700;color:#fff;white-space:nowrap}
.hdr-phone i{color:var(--red);font-size:13px}
.mob-btn{display:none;background:transparent;border:1px solid var(--bd);color:#fff;width:40px;height:40px;border-radius:2px;align-items:center;justify-content:center;font-size:16px}
.hdr-cart{position:relative}
.cart-badge{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}

/* ─── LAYOUT ───────────────────────────────────── */
.wrap{max-width:1320px;margin:0 auto;padding:0 28px}
section{padding:88px 0}
.stag{font-size:11px;font-weight:700;letter-spacing:3px;color:var(--red);text-transform:uppercase;display:block;margin-bottom:10px}
.stitle{font-family:var(--fd);font-size:clamp(38px,4.5vw,60px);letter-spacing:2px;line-height:1.02;margin-bottom:14px}
.sdesc{font-size:15px;color:var(--gray);line-height:1.75;max-width:500px}

/* ─── HERO ─────────────────────────────────────── */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(0,0,0,.88) 0%,rgba(0,0,0,.6) 55%,rgba(0,0,0,.3) 100%)}
.hero-inner{position:relative;z-index:2;max-width:1320px;margin:0 auto;padding:0 28px;width:100%;display:grid;grid-template-columns:1fr 360px;gap:60px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.55);font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;margin-bottom:24px}
.hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:var(--red)}
.hero-title{font-family:var(--fd);font-size:clamp(70px,9vw,120px);line-height:.9;letter-spacing:3px;color:#fff;margin-bottom:6px}
.hero-title .red{color:var(--red)}
.hero-tagline{font-family:var(--fd);font-size:clamp(13px,1.5vw,17px);letter-spacing:7px;color:rgba(255,255,255,.45);margin-bottom:36px}
.hero-tagline b{color:rgba(255,255,255,.8)}
.hero-desc{font-size:16px;color:rgba(255,255,255,.65);line-height:1.75;max-width:460px;margin-bottom:40px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px}
.hero-strips{display:flex;flex-direction:column;gap:10px}
.hero-strip{display:flex;align-items:center;gap:12px;font-size:13px;color:rgba(255,255,255,.6)}
.hero-strip i{color:var(--red);width:16px;text-align:center;font-size:12px}

/* Hero right panel */
.hero-panel{background:rgba(10,10,10,.75);border:1px solid rgba(255,255,255,.1);border-radius:3px;backdrop-filter:blur(12px);overflow:hidden}
.hero-panel-hdr{padding:18px 22px;border-bottom:1px solid rgba(255,255,255,.08);font-family:var(--fd);font-size:15px;letter-spacing:2px;color:rgba(255,255,255,.6)}
.hplink{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid rgba(255,255,255,.07);cursor:pointer;transition:background .18s;gap:12px}
.hplink:last-child{border:none}
.hplink:hover{background:rgba(255,255,255,.05)}
.hplink-left{display:flex;align-items:center;gap:14px}
.hplink-ico{width:40px;height:40px;background:rgba(196,21,21,.2);border:1px solid rgba(196,21,21,.3);border-radius:2px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hplink-ico i{color:var(--red);font-size:16px}
.hplink-name{font-family:var(--fd);font-size:18px;letter-spacing:1px;display:block;line-height:1}
.hplink-sub{font-size:11px;color:var(--gray);margin-top:2px;display:block}
.hplink-arrow{color:var(--gray);font-size:13px;flex-shrink:0}
.hero-panel-stat{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.07);border-top:1px solid rgba(255,255,255,.07)}
.hp-stat{padding:16px 14px;text-align:center;background:rgba(10,10,10,.75)}
.hp-stat .n{font-family:var(--fd);font-size:26px;letter-spacing:1px;color:#fff;display:block}
.hp-stat .l{font-size:10px;letter-spacing:1px;color:var(--gray);text-transform:uppercase}

/* Hero scroll hint */
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,.3);font-size:11px;letter-spacing:2px;text-transform:uppercase}
.hero-scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:scrollPulse 2s infinite}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:.8}}

/* ─── TRUST STRIP ──────────────────────────────── */
.trust{background:var(--bg1);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd)}
.trust-inner{max-width:1320px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bd)}
.t-item{background:var(--bg1);padding:28px 24px;display:flex;align-items:flex-start;gap:16px}
.t-ico{width:46px;height:46px;background:rgba(196,21,21,.12);border:1px solid rgba(196,21,21,.25);border-radius:2px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.t-ico i{color:var(--red);font-size:18px}
.t-item h4{font-family:var(--fd);font-size:17px;letter-spacing:.5px;margin-bottom:3px;color:#fff}
.t-item p{font-size:12px;color:var(--gray);line-height:1.5}

/* ─── CATEGORY TILES ───────────────────────────── */
.cat-tiles{display:grid;grid-template-columns:repeat(3,1fr);height:500px}
.ctile{position:relative;overflow:hidden;cursor:pointer}
.ctile img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.ctile:hover img{transform:scale(1.07)}
.ctile-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.1) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:36px 30px;transition:background .3s}
.ctile:hover .ctile-ov{background:linear-gradient(to top,rgba(196,21,21,.75) 0%,rgba(0,0,0,.5) 60%,rgba(0,0,0,.1) 100%)}
.ctile-tag{font-size:10px;font-weight:700;letter-spacing:3px;color:rgba(255,255,255,.6);text-transform:uppercase;margin-bottom:8px}
.ctile-title{font-family:var(--fd);font-size:38px;letter-spacing:2px;color:#fff;line-height:1;margin-bottom:16px}
.ctile-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#0a0a0a;font-size:12px;font-weight:700;letter-spacing:.5px;padding:9px 18px;border-radius:2px;border:none;cursor:pointer;transform:translateY(10px);opacity:0;transition:all .3s}
.ctile:hover .ctile-btn{transform:translateY(0);opacity:1}

/* ─── SECTION HEADER ROW ───────────────────────── */
.sec-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:16px}

/* ─── PRODUCT CARDS ────────────────────────────── */
.prod-light{background:var(--off)}
.prod-light .stitle{color:#0a0a0a}
.prod-light .sdesc{color:#555}
.prod-light .sec-row .btn-outline-dark{color:#0a0a0a;border-color:#0a0a0a}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pcard{background:#fff;border:1px solid #e0e0e0;border-radius:3px;overflow:hidden;transition:all .25s;cursor:pointer;display:flex;flex-direction:column;position:relative}
.pcard:hover{border-color:#aaa;box-shadow:0 10px 32px rgba(0,0,0,.12);transform:translateY(-5px)}
.pcard-img{position:relative;overflow:hidden;aspect-ratio:16/11;background:#111}
.pcard-img img{width:100%;height:100%;object-fit:contain;transition:transform .5s ease}
.pcard:hover .pcard-img img{transform:scale(1.03)}
.pcard-avail{position:absolute;top:0;left:0;background:#158015;color:#fff;font-size:10px;font-weight:700;letter-spacing:1px;padding:5px 12px;text-transform:uppercase}
.pcard-hover-btn{position:absolute;bottom:0;left:0;right:0;background:#0a0a0a;color:#fff;text-align:center;font-size:12px;font-weight:700;letter-spacing:.8px;padding:13px;transform:translateY(100%);transition:transform .25s;border:none;cursor:pointer;font-family:'Inter',sans-serif;text-transform:uppercase}
.pcard:hover .pcard-hover-btn{transform:translateY(0)}
.pcard-body{padding:20px;flex:1;display:flex;flex-direction:column;background:#fff}
.pcard-cat{font-size:10px;font-weight:700;letter-spacing:2px;color:#999;text-transform:uppercase;margin-bottom:6px}
.pcard-name{font-family:var(--fd);font-size:22px;letter-spacing:1px;color:#0a0a0a;margin-bottom:12px;line-height:1.1}
.pcard-specs{margin-bottom:16px;flex:1}
.pcard-specs li{font-size:12px;color:#777;padding:5px 0;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;gap:8px}
.pcard-specs li:last-child{border:none}
.pcard-specs li span:last-child{color:#0a0a0a;font-weight:600;text-align:right}
.pcard-foot{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid #f0f0f0;margin-top:auto}
.pcard-price{font-family:var(--fd);font-size:28px;letter-spacing:1px;color:#0a0a0a;line-height:1}
.pcard-price small{font-family:'Inter',sans-serif;font-size:12px;color:#999;font-weight:400;letter-spacing:0}

/* ─── DELIVERY ─────────────────────────────────── */
.del-bg{background:var(--bg1)}
.del-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.del-table{border:1px solid var(--bd);border-radius:3px;overflow:hidden}
.del-row{display:grid;grid-template-columns:60px 1fr auto;align-items:stretch;border-bottom:1px solid var(--bd);transition:background .18s}
.del-row:last-child{border:none}
.del-row:hover{background:var(--bg2)}
.del-row-ico{display:flex;align-items:center;justify-content:center;border-right:1px solid var(--bd);font-size:16px;color:var(--gray)}
.del-row-ico i{font-size:18px;color:var(--gray)}
.del-row-info{padding:16px 20px}
.del-row-info .nm{font-size:14px;font-weight:600;color:#fff;margin-bottom:2px}
.del-row-info .rng{font-size:12px;color:var(--gray)}
.del-row-price{padding:0 22px;display:flex;align-items:center;font-family:var(--fd);font-size:22px;letter-spacing:1px;color:var(--red);white-space:nowrap}
.del-row-price.free-col{color:#22aa44}
.del-row-price.call-col{font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--gray)}
.del-note{margin-top:16px;padding:14px 18px;background:rgba(196,21,21,.08);border-left:3px solid var(--red);font-size:13px;color:#aaa;border-radius:0 2px 2px 0;line-height:1.6}
.del-note strong{color:#fff}

/* ─── EVENT CARDS (dark) ───────────────────────── */
.ev-bg{background:var(--bg0)}
.ecard{background:var(--bg2);border:1px solid var(--bd);border-radius:3px;overflow:hidden;transition:all .25s;cursor:pointer}
.ecard:hover{border-color:#3a3a3a;transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.4)}
.ecard-img{aspect-ratio:16/10;overflow:hidden;position:relative}
.ecard-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.ecard:hover .ecard-img img{transform:scale(1.07)}
.ecard-body{padding:24px}
.ecard-cat{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--red);text-transform:uppercase;margin-bottom:6px}
.ecard-name{font-family:var(--fd);font-size:26px;letter-spacing:1px;color:#fff;margin-bottom:8px}
.ecard-desc{font-size:13px;color:var(--gray);line-height:1.65;margin-bottom:18px}
.ecard-foot{display:flex;align-items:center;justify-content:space-between}
.ecard-price{font-size:13px;color:var(--gray);font-style:italic}

/* ─── INQUIRY ──────────────────────────────────── */
.inq-bg{background:var(--red);position:relative;overflow:hidden}
.inq-bg::after{content:'911';position:absolute;right:-20px;top:50%;transform:translateY(-50%);font-family:var(--fd);font-size:280px;color:rgba(0,0,0,.15);line-height:1;pointer-events:none}
.inq-inner{max-width:1320px;margin:0 auto;padding:80px 28px;display:flex;align-items:center;justify-content:space-between;gap:40px;position:relative;z-index:1}
.inq-inner h2{font-family:var(--fd);font-size:clamp(34px,4vw,58px);letter-spacing:2px;color:#fff;line-height:1.05}
.inq-inner p{color:rgba(255,255,255,.8);font-size:16px;margin-top:10px}
.inq-btns{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}

/* ─── HOW IT WORKS ─────────────────────────────── */
.hiw-bg{background:var(--bg1)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bd);border:1px solid var(--bd);border-radius:3px;overflow:hidden;margin-top:56px}
.step{background:var(--bg2);padding:44px 28px;position:relative}
.step-num{font-family:var(--fd);font-size:80px;color:rgba(255,255,255,.04);position:absolute;top:12px;right:16px;line-height:1;user-select:none}
.step-ico{width:52px;height:52px;background:rgba(196,21,21,.12);border:1px solid rgba(196,21,21,.3);border-radius:2px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.step-ico i{color:var(--red);font-size:20px}
.step h3{font-family:var(--fd);font-size:22px;letter-spacing:1px;margin-bottom:10px;color:#fff}
.step p{font-size:13px;color:var(--gray);line-height:1.65}

/* ─── PAGE HERO (inner pages) ──────────────────── */
.phero{padding:108px 0 68px;background:var(--bg1);border-bottom:1px solid var(--bd);text-align:center;position:relative;overflow:hidden}
.phero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(196,21,21,.06) 0%,transparent 65%)}
.phero-in{position:relative;z-index:1}
.phero h1{font-family:var(--fd);font-size:clamp(46px,7vw,86px);letter-spacing:3px;margin-bottom:14px;color:#fff}
.phero p{font-size:15px;color:var(--gray);max-width:480px;margin:0 auto;line-height:1.7}

/* ─── FOOTER ───────────────────────────────────── */
footer{background:var(--bg0);border-top:1px solid var(--bd);padding:72px 0 36px}
.footer-g{max-width:1320px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;margin-bottom:56px}
.f-brand p{font-size:13px;color:var(--gray);line-height:1.75;margin:18px 0;max-width:260px}
.f-ci{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gray);margin-bottom:10px}
.f-ci i{color:var(--red);width:14px;font-size:12px}
.f-ci strong{color:#ccc}
.fcol h4{font-family:var(--fd);font-size:15px;letter-spacing:2px;color:#fff;margin-bottom:18px}
.flinks li{margin-bottom:10px}
.flinks a{font-size:13px;color:var(--gray);cursor:pointer;transition:color .18s}.flinks a:hover{color:#fff}
.fbot{max-width:1320px;margin:0 auto;padding:24px 28px 0;border-top:1px solid var(--bd);display:flex;justify-content:space-between;font-size:12px;color:var(--gray2);flex-wrap:wrap;gap:8px}
.tagbar{background:var(--red);text-align:center;padding:10px;font-family:var(--fd);font-size:13px;letter-spacing:5px;color:#fff}

/* ─── CONTACT ──────────────────────────────────── */
.con-g{display:grid;grid-template-columns:1fr 1.6fr;gap:56px;align-items:start}
.con-card{background:var(--bg2);border:1px solid var(--bd);border-radius:3px;padding:36px;margin-bottom:18px}
.con-item{display:flex;gap:14px;margin-bottom:28px}
.con-item:last-child{margin:0}
.con-ico{width:42px;height:42px;background:rgba(196,21,21,.12);border:1px solid rgba(196,21,21,.25);border-radius:2px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.con-ico i{color:var(--red);font-size:16px}
.con-item h4{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--gray);text-transform:uppercase;margin-bottom:4px}
.con-item p{font-size:14px;font-weight:600;color:#fff}
.con-item small{font-size:12px;color:var(--gray)}
.map-ph{background:var(--bg2);border:1px solid var(--bd);border-radius:3px;height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--gray);font-size:13px;gap:8px}
.map-ph i{font-size:28px;color:var(--bd)}

/* Form (light bg for contact) */
.fcard{background:#fff;border-radius:3px;padding:38px}
.fcard h3{font-family:var(--fd);font-size:30px;letter-spacing:1px;margin-bottom:6px;color:#0a0a0a}
.fcard>p{font-size:14px;color:#777;margin-bottom:28px}
.fg{margin-bottom:18px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
label{display:block;font-size:11px;font-weight:700;letter-spacing:1px;color:#666;text-transform:uppercase;margin-bottom:7px}
input,select,textarea{width:100%;background:#fff;border:1px solid #d8d8d8;border-radius:2px;color:#0a0a0a;font-family:'Inter',sans-serif;font-size:14px;padding:11px 14px;outline:none;transition:border-color .2s;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:#0a0a0a}
select option{background:#fff}
textarea{resize:vertical}

/* About */
.about-g{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-img{border-radius:3px;overflow:hidden;aspect-ratio:4/3;position:relative}
.about-img img{width:100%;height:100%;object-fit:cover}
.val-g{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:44px}
.vcard{background:var(--bg2);border:1px solid var(--bd);border-radius:3px;padding:24px;transition:all .22s}
.vcard:hover{border-color:var(--red)}
.v-ico{width:44px;height:44px;background:rgba(196,21,21,.12);border:1px solid rgba(196,21,21,.25);border-radius:2px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.v-ico i{color:var(--red);font-size:18px}
.vcard h4{font-family:var(--fd);font-size:18px;letter-spacing:.5px;color:#fff;margin-bottom:6px}
.vcard p{font-size:13px;color:var(--gray);line-height:1.6}

/* ─── MODAL ────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.overlay.open{display:flex}
.modal{background:#fff;border-radius:4px;width:100%;max-width:640px;max-height:92vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.4)}
.mhdr{padding:24px 28px;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}
.mhdr h3{font-family:var(--fd);font-size:26px;letter-spacing:1px;color:#0a0a0a}
.mclose{width:34px;height:34px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:2px;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#555}
.mclose:hover{background:var(--red);color:#fff;border-color:var(--red)}
.mbody{padding:28px}
.mpreview{display:flex;align-items:center;gap:14px;background:#f7f7f7;border:1px solid #e8e8e8;border-radius:3px;padding:14px;margin-bottom:24px}
.mpreview-img{width:72px;height:54px;object-fit:cover;border-radius:2px;flex-shrink:0;background:#e0e0e0}
.mpreview h4{font-family:var(--fd);font-size:20px;letter-spacing:.5px;color:#0a0a0a}
.mpreview p{font-size:12px;color:#888}
.mpreview .ptag{margin-left:auto;text-align:right;flex-shrink:0}
.mpreview .amt{font-family:var(--fd);font-size:26px;color:var(--red)}
.mpreview small{font-size:11px;color:#888}
.dchoices{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}
.dch{border:1px solid #e0e0e0;border-radius:2px;padding:11px 8px;cursor:pointer;transition:all .2s;text-align:center;background:#fff}
.dch:hover{border-color:#0a0a0a}.dch.sel{border-color:var(--red);background:rgba(196,21,21,.04)}
.dch .di{margin-bottom:4px;font-size:16px;color:#444}
.dch .di i{font-size:16px}
.dch .dn{font-size:11px;font-weight:700;color:#0a0a0a}
.dch .dp{font-size:10px;color:#999}
.psum{background:#f7f7f7;border:1px solid #e8e8e8;border-radius:3px;padding:18px;margin:20px 0}
.prow{display:flex;justify-content:space-between;font-size:14px;padding:5px 0;color:#888}
.prow .pv{color:#0a0a0a;font-weight:600}
.prow.tot{border-top:1px solid #e8e8e8;margin-top:8px;padding-top:12px}
.prow.tot .pl{font-family:var(--fd);font-size:18px;color:#0a0a0a}
.prow.tot .pv{font-family:var(--fd);font-size:22px;color:var(--red)}
.dep-note{background:rgba(196,21,21,.05);border:1px solid rgba(196,21,21,.18);border-radius:3px;padding:13px 15px;font-size:13px;color:#555;margin-bottom:18px;line-height:1.6}
.dep-note strong{color:#0a0a0a}

/* ─── ANIMATIONS ───────────────────────────────── */
@keyframes fi{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade{animation:fi .35s ease}

/* ─── RESPONSIVE ───────────────────────────────── */
@media(max-width:1280px){
  .hdr{padding:0 20px}
  nav a{padding:8px 10px;font-size:12px}
}
@media(max-width:1100px){
  .hdr-phone{display:none}
  .hero-inner{grid-template-columns:1fr}.hero-panel{display:none}
  .cat-tiles{height:380px}
  .grid4{grid-template-columns:repeat(2,1fr)}
  .del-grid{grid-template-columns:1fr;gap:32px}
  .about-g{grid-template-columns:1fr;gap:32px}
  .con-g{grid-template-columns:1fr}
  .footer-g{grid-template-columns:1fr 1fr;gap:32px}
  .inq-inner{flex-direction:column;text-align:center}
  .inq-btns{justify-content:center}
}
@media(max-width:900px){
  /* Header — switch to hamburger */
  nav{display:none}
  .mob-btn{display:flex}
  .hdr-r{gap:8px}
  .hdr-r .btn-red{font-size:12px;padding:8px 14px}
  .cart-txt{display:none}
  /* Ann bar — hide address + its separator */
  .ann-addr{display:none}
  .ann-addr+.ann-sep{display:none}
}
@media(max-width:768px){
  /* Hero */
  .hero{height:100svh;min-height:600px}
  .hero-title{font-size:clamp(52px,14vw,90px)}
  .hero-desc{font-size:13px}
  .hero-btns{flex-direction:column;align-items:flex-start;gap:10px}
  .hero-btns .btn{width:100%;justify-content:center}
  .hero-strips{gap:8px}
  .hero-strip{font-size:12px}
  /* Sections */
  section,.trust{padding:52px 0}
  .wrap{padding:0 16px}
  .sec-row{flex-direction:column;gap:14px}
  /* Grids */
  .cat-tiles{grid-template-columns:1fr;height:auto}
  .ctile{height:200px}
  .trust-inner{grid-template-columns:1fr 1fr;gap:16px}
  .grid4,.grid3{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:24px}
  /* Footer */
  .footer-g{grid-template-columns:1fr;gap:28px}
  .fbot{flex-direction:column;gap:6px;text-align:center}
  .fcol{display:none}
  /* Forms */
  .frow{grid-template-columns:1fr}
  .val-g{grid-template-columns:1fr 1fr}
  /* Page hero */
  .phero{padding:40px 0 28px}
  .phero-in h1{font-size:clamp(26px,8vw,44px)}
}
@media(max-width:600px){
  /* Booking box */
  .rbb{padding:16px}
  .rbb-dates{flex-direction:column;gap:10px}
  .rbb-sep{display:none}
  .rbb-field{width:100%}
  /* Flatpickr popup full-width on mobile */
  .flatpickr-calendar{width:100vw!important;max-width:100vw!important;left:0!important;right:0!important;border-radius:0!important;border-left:none!important;border-right:none!important}
  .flatpickr-calendar.multiMonth .flatpickr-rContainer:first-child{display:none}
  /* Single product */
  .sp-grid{gap:20px;padding-top:16px}
  .sp-main-img{aspect-ratio:16/9}
  .sp-title{font-size:clamp(20px,6vw,32px)}
  .sp-price{font-size:28px}
  .sp-thumbs{display:none}
  /* Product cards */
  .grid4,.grid3{grid-template-columns:1fr}
  .pcard-foot{flex-direction:column;gap:8px;align-items:flex-start}
  .pcard-foot .btn{width:100%;text-align:center}
  /* Delivery table */
  .del-row{flex-wrap:wrap;gap:6px}
  .del-row-price{margin-left:auto}
  /* CTA */
  .inq-bg::after{font-size:120px}
}
@media(max-width:480px){
  .trust-inner{grid-template-columns:1fr}
  .ann{font-size:11px;padding:7px 14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ann-sep{display:none}
  .ann-addr{display:none}
  .steps{grid-template-columns:1fr}
  .val-g{grid-template-columns:1fr}
  .grid4,.grid3{grid-template-columns:1fr}
  .hero-btns .btn{font-size:13px;padding:12px 18px}
  .stitle{font-size:clamp(22px,7vw,34px)}
  .sp-related .grid4{grid-template-columns:1fr 1fr}
}
@media(max-width:380px){
  .logo-badge{width:36px;height:36px}
  .logo-txt .name{font-size:18px}
  .logo-txt .sup,.logo-txt .sub{font-size:9px}
  .hdr{padding:0 12px;gap:10px}
  .hero-title{font-size:clamp(42px,13vw,70px)}
  .sp-related .grid4{grid-template-columns:1fr}
}

/* ─── BOOKING BOX ─────────────────────────────── */
.rbb{background:var(--bg2);border:1px solid var(--bd);border-radius:4px;padding:22px;margin-bottom:20px}
.rbb-head{font-family:var(--fd);font-size:14px;letter-spacing:1.5px;color:#fff;margin-bottom:16px;display:flex;align-items:center;gap:8px;text-transform:uppercase}
.rbb-head i{color:var(--red)}
.rbb-dates{display:flex;align-items:flex-end;gap:10px;margin-bottom:14px}
.rbb-field{flex:1}
.rbb-time{margin-bottom:0}
.rbb-sep{padding-bottom:11px;color:var(--gray2);flex-shrink:0}
.rbb-field label{display:block;font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--gray);text-transform:uppercase;margin-bottom:6px}
.rbb-input{width:100%;background:var(--bg3)!important;border:1px solid var(--bd);border-radius:2px;padding:10px 12px;font-size:13px;color:#fff!important;-webkit-text-fill-color:#fff!important;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;-webkit-appearance:none;color-scheme:dark}
.rbb-input:focus{border-color:var(--red)}
.rbb-input option{background:var(--bg2);color:#fff}
.rbb-summary{margin-top:16px;background:var(--bg3);border:1px solid var(--bd);border-radius:2px;overflow:hidden}
.rbb-sum-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;border-bottom:1px solid var(--bd);color:var(--gray)}
.rbb-sum-row:last-child{border:none}
.rbb-sum-total{font-weight:700;color:#fff;font-size:15px;border-bottom:1px solid var(--bd)}
.rbb-deposit{background:rgba(196,21,21,.08);color:var(--red);font-size:12px;font-weight:600}
.rbb-deposit-note{font-size:11px;color:var(--gray2);padding:6px 14px 12px;line-height:1.6}

/* ─── FLATPICKR DARK THEME ─────────────────────── */
.flatpickr-calendar{font-family:'Inter',sans-serif!important;background:var(--bg2)!important;border:1px solid var(--bd)!important;border-radius:4px!important;box-shadow:0 12px 40px rgba(0,0,0,.6)!important}
.flatpickr-months{background:var(--bg3)!important;border-radius:4px 4px 0 0!important;padding:4px 0}
.flatpickr-month{color:#fff!important;fill:#fff!important}
.flatpickr-current-month{color:#fff!important;font-size:13px!important;font-weight:600!important}
.flatpickr-current-month input.cur-year{color:#fff!important;background:transparent!important;border:none!important;outline:none!important;box-shadow:none!important}
.flatpickr-monthDropdown-months{background:var(--bg2)!important;color:#fff!important}
.flatpickr-prev-month svg,.flatpickr-next-month svg{fill:#fff!important}
.flatpickr-prev-month:hover svg,.flatpickr-next-month:hover svg{fill:var(--red)!important}
.flatpickr-weekdays{background:var(--bg2)!important;border-bottom:1px solid var(--bd)!important}
span.flatpickr-weekday{background:transparent!important;color:var(--gray)!important;font-size:10px!important;font-weight:700!important;letter-spacing:.5px}
.flatpickr-days{border-color:var(--bd)!important}
.flatpickr-day{color:#ccc!important;border-radius:3px!important;border-color:transparent!important}
.flatpickr-day:hover,.flatpickr-day:focus{background:var(--bg3)!important;color:#fff!important;border-color:var(--bd)!important}
.flatpickr-day.today{border-color:var(--gray2)!important;color:#fff!important}
.flatpickr-day.today:hover{background:var(--bg3)!important}
.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange{background:var(--red)!important;border-color:var(--red)!important;color:#fff!important}
.flatpickr-day.inRange{background:rgba(196,21,21,.18)!important;border-color:transparent!important;color:#fff!important;box-shadow:-5px 0 0 rgba(196,21,21,.18),5px 0 0 rgba(196,21,21,.18)!important}
.flatpickr-day.startRange.inRange,.flatpickr-day.endRange.inRange{background:var(--red)!important}
.flatpickr-day.flatpickr-disabled{color:var(--bg3)!important;opacity:.35!important}
.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:var(--gray2)!important;opacity:.3!important}
/* Booked days */
.flatpickr-day.day-booked{background:rgba(196,21,21,.12)!important;color:#c44!important;border:1px solid rgba(196,21,21,.3)!important;cursor:not-allowed!important;text-decoration:line-through!important;opacity:.7!important}
/* Legend inside calendar */
.fp-legend{display:flex;gap:12px;padding:8px 12px;border-top:1px solid var(--bd);background:var(--bg3);border-radius:0 0 4px 4px;justify-content:center}
.fp-legend span{font-size:10px;color:var(--gray);display:flex;align-items:center;gap:4px;letter-spacing:.3px}
.fp-dot{display:inline-block;width:9px;height:9px;border-radius:50%;flex-shrink:0}
.fp-avail{background:var(--bg3);border:1px solid var(--gray2)}
.fp-booked{background:rgba(196,21,21,.3);border:1px solid rgba(196,21,21,.5)}
.fp-sel{background:var(--red)}
/* mobile flatpickr handled in main responsive block above */

/* ─── WOOCOMMERCE OVERRIDES ────────────────────── */
.woocommerce-notices-wrapper,.woocommerce-message,.woocommerce-error,.woocommerce-info{margin-bottom:20px}
.woo-wrap .woocommerce{color:#fff}
.woo-wrap h1,.woo-wrap h2,.woo-wrap h3{font-family:var(--fd);letter-spacing:1px;color:#fff}
.woo-wrap .product_title{font-family:var(--fd);font-size:clamp(32px,5vw,54px);letter-spacing:2px;color:#fff;margin-bottom:12px}
.woo-wrap .woocommerce-product-details__short-description{color:var(--gray);font-size:14px;line-height:1.75;margin-bottom:20px}
.woo-wrap .price{font-family:var(--fd);font-size:36px;color:var(--red);letter-spacing:1px}
.woo-wrap .price del{color:var(--gray2);font-size:22px}
.woo-wrap .price ins{text-decoration:none}
.woo-wrap .cart{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:20px 0}
/* Hide quantity field — rentals are always qty 1 */
.woo-wrap form.cart .quantity,.woo-wrap form.cart input[type=number]{display:none!important}
.woo-wrap input[type=number]{width:80px;background:var(--bg2);border:1px solid var(--bd);color:#fff;padding:10px 12px;border-radius:2px;font-size:15px}
/* Override WordPress wp-element-button global styles (injected inline in <head>, very high specificity) */
.woo-wrap .single_add_to_cart_button,
.woo-wrap .single_add_to_cart_button.wp-element-button,
.woo-wrap .single_add_to_cart_button.button,
.woo-wrap .single_add_to_cart_button.alt,
.woo-wrap form.cart button[type=submit],
.woo-wrap button.single_add_to_cart_button{
  background:var(--red)!important;
  background-color:var(--red)!important;
  color:#fff!important;
  border:none!important;
  border-color:transparent!important;
  box-shadow:none!important;
  outline:none!important;
  padding:14px 36px!important;
  font-family:var(--fd)!important;
  font-size:18px!important;
  letter-spacing:1px!important;
  cursor:pointer!important;
  border-radius:2px!important;
  transition:background .2s!important;
  text-decoration:none!important;
  display:inline-block!important;
}
.woo-wrap .single_add_to_cart_button:hover,
.woo-wrap form.cart button[type=submit]:hover{background:var(--red2)!important;background-color:var(--red2)!important}
.woo-wrap .woocommerce-product-gallery{border-radius:3px;overflow:hidden}
.woo-wrap .woocommerce-tabs ul.tabs{border-bottom:1px solid var(--bd);margin-bottom:24px;display:flex;gap:4px;padding:0}
.woo-wrap .woocommerce-tabs ul.tabs li{background:var(--bg2);border:1px solid var(--bd);border-bottom:none;padding:10px 20px;cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.5px}
.woo-wrap .woocommerce-tabs ul.tabs li.active{background:var(--bg3);border-color:var(--red);color:var(--red)}
.woo-wrap .woocommerce-tabs ul.tabs li a{color:inherit}
.woo-wrap .woocommerce-Tabs-panel{color:var(--gray);font-size:14px;line-height:1.75}
/* ── CART TABLE ───────────────────────────────── */
/* Force full-width — Divi's higher-specificity rules override plain `table` selector */
.woo-wrap table,.woo-wrap .shop_table{width:100%!important;border-collapse:collapse!important}
/* Desktop only: restore proper HTML table rendering (mobile block below overrides at ≤768px) */
@media(min-width:769px){
  .woo-wrap .shop_table{display:table!important}
  .woo-wrap .shop_table thead{display:table-header-group!important}
  .woo-wrap .shop_table tbody{display:table-row-group!important}
  .woo-wrap .shop_table tr{display:table-row!important}
  .woo-wrap .shop_table th,.woo-wrap .shop_table td{display:table-cell!important;vertical-align:middle}
  .woo-wrap .shop_table th.product-price,.woo-wrap .shop_table td.product-price,
  .woo-wrap .shop_table th.product-subtotal,.woo-wrap .shop_table td.product-subtotal{text-align:right}
}
.woo-wrap table thead{background:var(--bg3);border-bottom:2px solid var(--red)}
.woo-wrap table th{padding:14px 16px;font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--gray);text-transform:uppercase;text-align:left}
.woo-wrap table td{padding:18px 14px;border-bottom:1px solid var(--bd);font-size:13px;color:#fff;vertical-align:middle}
/* Suppress empty WooCommerce notices wrapper — causes blank space above cart */
.woo-wrap .woocommerce-notices-wrapper{min-height:0!important;margin:0!important;padding:0!important}
.woo-wrap .woocommerce-notices-wrapper:empty{display:none!important}
/* Remove button */
.woo-wrap td.product-remove{width:36px;padding:0 8px;text-align:center}
.woo-wrap td.product-remove a.remove{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:rgba(196,21,21,.15);border:1px solid rgba(196,21,21,.3);color:var(--red)!important;font-size:16px;line-height:1;text-decoration:none;transition:all .2s}
.woo-wrap td.product-remove a.remove:hover{background:var(--red);color:#fff!important}
/* Thumbnail */
.woo-wrap td.product-thumbnail{width:80px;padding:12px 8px}
.woo-wrap td.product-thumbnail img,.woo-wrap .cart_item td img{width:72px!important;height:54px!important;object-fit:cover;border-radius:3px;display:block}
/* Product name + booking meta */
.woo-wrap td.product-name a{color:#fff;text-decoration:none;font-weight:600;font-size:13px;display:block;margin-bottom:8px}
.woo-wrap td.product-name a:hover{color:var(--red)}
.woo-wrap td.product-name .variation,.woo-wrap td.product-name dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:2px 8px;font-size:11px}
.woo-wrap td.product-name dt{color:var(--gray);font-weight:600;letter-spacing:.3px;white-space:nowrap}
.woo-wrap td.product-name dd{color:#ccc;margin:0}
/* Price / subtotal */
.woo-wrap td.product-price,.woo-wrap td.product-subtotal{font-family:var(--fd);font-size:17px;letter-spacing:.5px;white-space:nowrap;color:#fff}
.woo-wrap td.product-subtotal{color:var(--red)}
/* Quantity — always hidden for rentals (qty always 1) */
.woo-wrap td.product-quantity,.woo-wrap th.product-quantity{display:none!important}
/* Cart actions row */
.woo-wrap .woocommerce-cart-form .actions{padding:16px 0;display:flex;gap:12px;align-items:center;justify-content:flex-end;border-top:1px solid var(--bd)}
.woo-wrap .woocommerce-cart-form .actions .coupon{display:flex;gap:8px;flex:1}
.woo-wrap .woocommerce-cart-form .actions .coupon input{background:var(--bg2);border:1px solid var(--bd);color:#fff;padding:10px 14px;border-radius:2px;font-size:13px;flex:1}
.woo-wrap .woocommerce-cart-form .actions .coupon .button{background:var(--bg3);color:#fff;border:1px solid var(--bd);padding:10px 16px;font-size:12px;font-weight:700;letter-spacing:.5px;cursor:pointer;border-radius:2px}
.woo-wrap button[name=update_cart],.woo-wrap .woocommerce-cart-form .button{background:var(--red);color:#fff;border:none;padding:12px 24px;font-family:var(--fd);font-size:14px;letter-spacing:1px;cursor:pointer;border-radius:2px;transition:background .2s}
.woo-wrap button[name=update_cart]:hover,.woo-wrap .woocommerce-cart-form .button:hover{background:var(--red2)}
/* Cart collaterals */
.woo-wrap .cart-collaterals{margin-top:40px}

/* ── CART TOTALS ──────────────────────────────── */
.woo-wrap .cart_totals{background:var(--bg2);border:1px solid var(--bd);border-radius:4px;max-width:480px;width:100%;margin-left:auto}

/* Header bar */
.woo-wrap .cart_totals h2{font-family:var(--fd);font-size:13px;letter-spacing:3px;color:var(--gray);padding:14px 20px;border-bottom:1px solid var(--bd);margin:0;background:var(--bg3);border-radius:4px 4px 0 0;text-transform:uppercase}

/* Table base */
.woo-wrap .cart_totals table{border-collapse:collapse;width:100%;background:transparent}
.woo-wrap .cart_totals table tr{border-bottom:1px solid var(--bd)}
.woo-wrap .cart_totals table tr:last-child{border-bottom:none}
.woo-wrap .cart_totals table th{color:var(--gray);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:18px 20px;vertical-align:middle;white-space:nowrap}
.woo-wrap .cart_totals table td{color:#fff;padding:18px 20px;vertical-align:middle;text-align:right}

/* Subtotal row */
.woo-wrap .cart_totals .cart-subtotal th{color:var(--gray)}
.woo-wrap .cart_totals .cart-subtotal td{font-family:var(--fd);font-size:26px;letter-spacing:.5px;color:#fff!important}
.woo-wrap .cart_totals .cart-subtotal td .woocommerce-Price-amount,
.woo-wrap .cart_totals .cart-subtotal td bdi{color:#fff!important}

/* Shipping row */
.woo-wrap .cart_totals .shipping th{vertical-align:top;padding-top:20px}
.woo-wrap .cart_totals .shipping td{text-align:left;padding:12px 14px 14px}

/* Shipping option cards */
.woo-wrap #shipping_method{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px}
.woo-wrap #shipping_method li{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;
  background:var(--bg1);
  border:1px solid var(--bd);
  border-left:3px solid transparent;
  border-radius:2px;
  cursor:pointer;
  transition:border-color .18s,background .18s;
}
.woo-wrap #shipping_method li:hover{border-color:#3a3a3a;border-left-color:#3a3a3a}
.woo-wrap #shipping_method li:has(input:checked){border-color:rgba(196,21,21,.3);border-left-color:var(--red);background:rgba(196,21,21,.05)}
.woo-wrap #shipping_method li input[type=radio]{margin-top:3px;accent-color:var(--red);flex-shrink:0;cursor:pointer;width:13px;height:13px}
.woo-wrap #shipping_method li label{color:#777;font-size:11px;font-weight:600;letter-spacing:.2px;line-height:1.6;cursor:pointer;flex:1;min-width:0;word-break:break-word;overflow-wrap:anywhere}
.woo-wrap #shipping_method li input[type=radio]:checked + label{color:#fff}

/* Shipping destination note */
.woo-wrap .woocommerce-shipping-destination{color:var(--gray2);font-size:10px;letter-spacing:.3px;margin:8px 0 0;display:block}
.woo-wrap .woocommerce-shipping-destination a{color:var(--red);text-decoration:none}

/* Fee row (damage deposit) */
.woo-wrap .cart_totals .fee th{white-space:normal;font-size:9px;line-height:1.6;color:var(--gray)}
.woo-wrap .cart_totals .fee td{white-space:normal;color:#666;font-size:14px;font-style:italic;text-align:right}

/* Order total */
.woo-wrap .cart_totals .order-total{background:var(--bg3)}
.woo-wrap .cart_totals .order-total th{color:rgba(255,255,255,.5);font-size:9px;letter-spacing:2px;vertical-align:middle}
.woo-wrap .cart_totals .order-total td{font-family:var(--fd);font-size:30px;letter-spacing:1px;color:var(--red)!important;vertical-align:middle;text-align:right}
.woo-wrap .cart_totals .order-total td .woocommerce-Price-amount,
.woo-wrap .cart_totals .order-total td bdi{color:var(--red)!important}

/* Checkout button — flush to card bottom */
.woo-wrap .checkout-button,.woo-wrap #place_order{
  display:block;background:var(--red);color:#fff;border:none;
  padding:17px 20px;font-family:var(--fd);font-size:18px;letter-spacing:2px;
  cursor:pointer;border-radius:0 0 4px 4px;width:100%;
  text-align:center;text-decoration:none;transition:background .2s;
  margin-top:0;
}
.woo-wrap .checkout-button:hover,.woo-wrap #place_order:hover{background:var(--red2)}
/* Mobile cart */
@media(max-width:768px){
  /* Hide table headers */
  .woo-wrap .shop_table thead{display:none}
  .woo-wrap .shop_table,.woo-wrap .shop_table tbody{display:block;width:100%}
  /* Each cart item = CSS grid card */
  .woo-wrap .shop_table tr.cart_item{
    display:grid!important;
    grid-template-columns:30px 72px 1fr;
    grid-template-rows:auto auto;
    grid-template-areas:"del img name" "del price total";
    background:var(--bg2);
    border:1px solid var(--bd);
    border-radius:3px;
    margin-bottom:14px;
    overflow:hidden;
  }
  .woo-wrap .shop_table td{border:none!important;vertical-align:top}
  .woo-wrap .shop_table td.product-remove{grid-area:del;display:flex!important;align-items:center;justify-content:center;padding:14px 0;border-right:1px solid var(--bd)!important}
  .woo-wrap .shop_table td.product-thumbnail{grid-area:img;display:block!important;padding:12px 8px}
  .woo-wrap .shop_table td.product-thumbnail img,.woo-wrap .shop_table .cart_item td img{width:56px!important;height:42px!important}
  .woo-wrap .shop_table td.product-name{grid-area:name;display:block!important;padding:12px 12px 12px 4px}
  .woo-wrap .shop_table td.product-name a{font-size:12px}
  .woo-wrap .shop_table td.product-price{grid-area:price;display:block!important;padding:10px 8px 12px;border-top:1px solid var(--bd)!important}
  .woo-wrap .shop_table td.product-price::before{content:'PRICE';display:block;color:var(--gray);font-size:9px;font-weight:700;letter-spacing:.8px;font-family:'Inter',sans-serif;margin-bottom:3px}
  .woo-wrap .shop_table td.product-subtotal{grid-area:total;display:block!important;padding:10px 12px 12px 4px;border-top:1px solid var(--bd)!important}
  .woo-wrap .shop_table td.product-subtotal::before{content:'TOTAL';display:block;color:var(--gray);font-size:9px;font-weight:700;letter-spacing:.8px;font-family:'Inter',sans-serif;margin-bottom:3px}
  .woo-wrap .shop_table td.product-quantity{display:none!important}
  /* tfoot actions row */
  .woo-wrap .shop_table tfoot,.woo-wrap .shop_table tfoot tr,.woo-wrap .shop_table tfoot td{display:block;width:100%}
  .woo-wrap .shop_table tfoot td{border:none;padding:0}
  /* Cart totals + actions */
  .woo-wrap .cart_totals{max-width:100%}
  .woo-wrap .woocommerce-cart-form .actions{flex-direction:column;align-items:stretch}
  .woo-wrap .woocommerce-cart-form .actions .coupon{width:100%}
  .woo-wrap button[name=update_cart]{width:100%;text-align:center}
}
.woo-wrap #payment{background:var(--bg2);border:1px solid var(--bd);border-radius:3px;padding:20px}
.woo-wrap .woocommerce-form__label{color:#ccc;font-size:13px}
.woo-wrap .woocommerce-input-wrapper input,.woo-wrap .woocommerce-input-wrapper select{background:var(--bg2);border:1px solid var(--bd);color:#fff;padding:10px 14px;border-radius:2px;font-size:14px;width:100%}
.woo-wrap .woocommerce-billing-fields h3,.woo-wrap .woocommerce-shipping-fields h3,.woo-wrap h3#order_review_heading{font-family:var(--fd);font-size:22px;letter-spacing:1px;margin-bottom:16px;color:#fff}

/* ── CHECKOUT & ACCOUNT INPUTS — dark theme ───── */
.woo-wrap input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=number]),
.woo-wrap select,
.woo-wrap textarea{
  background:var(--bg2)!important;
  background-color:var(--bg2)!important;
  border:1px solid var(--bd)!important;
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  border-radius:2px!important;
  padding:12px 14px!important;
  font-size:14px!important;
  font-family:'Inter',sans-serif!important;
  width:100%!important;
  transition:border-color .2s!important;
}
.woo-wrap input:focus:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=number]),
.woo-wrap select:focus,
.woo-wrap textarea:focus{
  border-color:var(--red)!important;
  outline:none!important;
  box-shadow:none!important;
}
/* Fix browser autofill background (Chrome/Edge override) */
.woo-wrap input:-webkit-autofill,
.woo-wrap input:-webkit-autofill:hover,
.woo-wrap input:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0 1000px #171717 inset!important;
  -webkit-text-fill-color:#fff!important;
  border-color:var(--bd)!important;
  caret-color:#fff!important;
}
.woo-wrap select{
  appearance:none!important;
  -webkit-appearance:none!important;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8a8a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E")!important;
  background-repeat:no-repeat!important;
  background-position:right 14px center!important;
  background-size:12px!important;
  padding-right:38px!important;
  cursor:pointer!important;
}
.woo-wrap select option{background:#171717!important;color:#fff!important}
/* Labels */
.woo-wrap .woocommerce-billing-fields label,
.woo-wrap .woocommerce-shipping-fields label,
.woo-wrap .form-row label{
  color:var(--gray)!important;
  font-size:11px!important;
  font-weight:700!important;
  letter-spacing:1px!important;
  text-transform:uppercase!important;
  margin-bottom:6px!important;
  display:block!important;
}
.woo-wrap .woocommerce-MyAccount-navigation ul{list-style:none}
.woo-wrap .woocommerce-MyAccount-navigation li a{display:block;padding:10px 16px;border-bottom:1px solid var(--bd);color:var(--gray);font-size:13px;transition:color .2s}
.woo-wrap .woocommerce-MyAccount-navigation li.is-active a,.woo-wrap .woocommerce-MyAccount-navigation li a:hover{color:#fff}
.woo-wrap .woocommerce-account p,.woo-wrap .woocommerce-order-details p{color:var(--gray);font-size:14px}
.woo-wrap .order_details li strong{color:#fff}
/* Related products */
.woo-wrap .related h2,.woo-wrap .upsells h2{font-family:var(--fd);font-size:28px;letter-spacing:1px;margin-bottom:24px;color:#fff}
/* Hide WC's duplicate "Shop" page title — we have our own phero heading */
.woo-wrap h1.page-title{display:none!important}
/* Shop product grid — !important to override Divi's floats/flex */
.woo-wrap ul.products{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:18px!important;list-style:none!important;float:none!important;padding:0!important;margin:0!important}
.woo-wrap ul.products li.product{background:var(--bg2)!important;border:1px solid var(--bd)!important;border-radius:3px!important;padding:0!important;overflow:hidden!important;transition:all .25s!important;cursor:pointer!important;float:none!important;width:auto!important;margin:0!important}
.woo-wrap ul.products li.product:hover{border-color:#3a3a3a!important;transform:translateY(-3px)!important}
.woo-wrap ul.products li.product a{display:block;text-decoration:none}
.woo-wrap ul.products li.product .et_shop_image,.woo-wrap ul.products li.product img{aspect-ratio:16/10!important;object-fit:cover!important;width:100%!important;height:auto!important;display:block!important}
.woo-wrap ul.products li.product .woocommerce-loop-product__title,.woo-wrap ul.products li.product h2{font-family:var(--fd)!important;font-size:16px!important;letter-spacing:.5px!important;padding:12px 14px 4px!important;color:#fff!important;margin:0!important}
.woo-wrap ul.products li.product .price{display:block!important;padding:4px 14px 14px!important;font-size:20px!important;color:var(--red)!important;font-family:var(--fd)!important;letter-spacing:.5px!important}
.woo-wrap ul.products li.product .button{display:block!important;background:var(--red)!important;color:#fff!important;text-align:center!important;padding:10px!important;font-size:13px!important;font-weight:600!important;letter-spacing:.5px!important;transition:background .2s!important;border:none!important;cursor:pointer!important;text-decoration:none!important}
.woo-wrap ul.products li.product .button:hover{background:var(--red2)!important}
/* Pagination & ordering */
.woo-wrap .woocommerce-result-count{color:var(--gray);font-size:13px;margin-bottom:14px}
.woo-wrap .woocommerce-ordering select{background:var(--bg2);border:1px solid var(--bd);color:#fff;padding:8px 12px;font-size:13px;border-radius:2px;margin-bottom:16px}
.woo-wrap nav.woocommerce-pagination ul{display:flex;gap:8px;list-style:none;padding:32px 0 0;justify-content:center;flex-wrap:wrap}
.woo-wrap nav.woocommerce-pagination ul li a,.woo-wrap nav.woocommerce-pagination ul li span{background:var(--bg2);border:1px solid var(--bd);color:#fff;padding:8px 14px;font-size:13px;text-decoration:none;border-radius:2px}
.woo-wrap nav.woocommerce-pagination ul li span.current{background:var(--red);border-color:var(--red)}
@media(max-width:768px){.woo-wrap ul.products{grid-template-columns:1fr 1fr!important}}
@media(max-width:480px){.woo-wrap ul.products{grid-template-columns:1fr!important}}

/* ─── SINGLE PRODUCT PAGE ─────────────────────── */
.sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start;padding:40px 0 0}
/* Gallery */
.sp-main-img{border-radius:4px;overflow:hidden;aspect-ratio:4/3;background:#111}
.sp-main-img img{width:100%;height:100%;object-fit:contain;display:block;transition:opacity .2s}
.sp-thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.sp-thumb{width:72px;height:52px;object-fit:cover;border-radius:3px;cursor:pointer;opacity:.55;border:2px solid transparent;transition:all .2s;flex-shrink:0}
.sp-thumb:hover{opacity:.85}
.sp-thumb.active{opacity:1;border-color:var(--red)}
/* Summary */
.sp-cat{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--red);text-transform:uppercase;margin-bottom:10px}
.sp-title{font-family:var(--fd);font-size:clamp(22px,3vw,40px);letter-spacing:1.5px;color:#fff;line-height:1.1;margin-bottom:14px}
.sp-price{font-family:var(--fd);font-size:38px;color:var(--red);letter-spacing:1px;margin-bottom:16px;line-height:1}
.sp-price small{font-family:'Inter',sans-serif;font-size:14px;color:var(--gray);font-weight:400;letter-spacing:0}
.sp-desc{font-size:13px;color:var(--gray);line-height:1.8;margin-bottom:20px;border-bottom:1px solid var(--bd);padding-bottom:18px}
/* Tabs */
.sp-tabs{margin-top:48px;border-top:1px solid var(--bd);padding-top:32px}
.sp-tab-nav{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid var(--bd)}
.sp-tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:10px 20px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gray);cursor:pointer;margin-bottom:-1px;transition:all .2s}
.sp-tab-btn.active{color:#fff;border-bottom-color:var(--red)}
.sp-tab-panel{color:#b0b0b0;font-size:14px;line-height:1.85}
.sp-tab-panel p{margin-bottom:14px;color:#b0b0b0}
.sp-tab-panel h1,.sp-tab-panel h2,.sp-tab-panel h3,.sp-tab-panel h4{font-family:var(--fd);letter-spacing:1px;color:#fff;margin-bottom:14px;margin-top:4px}
.sp-tab-panel h2{font-size:22px}.sp-tab-panel h3{font-size:18px}.sp-tab-panel h4{font-size:15px}
.sp-tab-panel strong{color:#fff;font-weight:600}
.sp-tab-panel ul,.sp-tab-panel ol{padding-left:18px;margin-bottom:14px}
.sp-tab-panel ul{list-style:disc}.sp-tab-panel ol{list-style:decimal}
.sp-tab-panel li{margin-bottom:6px;color:#b0b0b0}
/* Related */
.sp-related{margin-top:52px;border-top:1px solid var(--bd);padding-top:32px}
.sp-rel-title{font-family:var(--fd);font-size:24px;letter-spacing:1.5px;color:#fff;margin-bottom:24px}
/* Hide WC default quantity (qty always 1 for rentals) */
.woocommerce div.product .quantity,.woo-wrap .quantity{display:none!important}
/* Shipping methods at checkout */
/* Shipping method styles now in cart_totals block above */
@media(max-width:900px){
  .sp-grid{grid-template-columns:1fr;gap:24px;padding-top:20px}
  .sp-main-img{aspect-ratio:16/9}
  .sp-title{font-size:clamp(20px,4vw,36px)}
}
@media(max-width:768px){.woo-wrap ul.products{grid-template-columns:1fr 1fr}}

/* ─── ATTACHMENT ADD-ONS ───────────────────────── */
.rbb-addons{margin-top:0;border-top:1px solid var(--bd)}
.addon-item{margin-bottom:6px}
.addon-label{
  display:flex;align-items:flex-start;gap:12px;
  background:var(--bg3);border:1px solid var(--bd);border-left:3px solid transparent;
  border-radius:2px;padding:12px 14px;cursor:pointer;
  transition:border-color .18s,background .18s;
}
.addon-label:hover{border-color:#3a3a3a;border-left-color:#555}
.addon-label:has(input:checked){border-color:rgba(196,21,21,.3);border-left-color:var(--red);background:rgba(196,21,21,.05)}
.addon-label input[type=checkbox]{margin-top:3px;accent-color:var(--red);flex-shrink:0;width:14px;height:14px;cursor:pointer}
.addon-info{flex:1;min-width:0}
.addon-name{display:block;font-size:13px;font-weight:600;color:#ccc;letter-spacing:.2px;line-height:1.3}
.addon-label:has(input:checked) .addon-name{color:#fff}
.addon-desc{display:block;font-size:11px;color:var(--gray);margin-top:3px;line-height:1.5}
.addon-price-tag{font-family:var(--fd);font-size:14px;letter-spacing:.5px;color:var(--red);white-space:nowrap;flex-shrink:0;align-self:center}
.addon-sub{margin:6px 0 6px 26px;padding:10px 12px;background:var(--bg2);border:1px solid var(--bd);border-radius:2px}
.addon-sub label{display:block;font-size:10px;font-weight:700;letter-spacing:1.2px;color:var(--gray);text-transform:uppercase;margin-bottom:6px}
/* Bucket info bar (top of addons) */
.addon-bucket-info{
  display:flex;align-items:flex-start;gap:8px;
  background:rgba(74,175,80,.06);border:1px solid rgba(74,175,80,.18);
  border-radius:2px;padding:10px 12px;font-size:11px;color:#aaa;
  margin-bottom:12px;line-height:1.6;
}
.addon-bucket-info i{color:#4caf50;margin-top:2px;flex-shrink:0}
.addon-bucket-info strong{color:#fff}

/* Bucket price tag — shows FREE + value */
.addon-bucket-price{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0;align-self:center}
.abp-free{font-family:var(--fd);font-size:15px;letter-spacing:.5px;color:#4caf50;line-height:1}
.abp-val{font-size:9px;color:var(--gray2);letter-spacing:.3px;text-decoration:line-through}

/* Both-buckets selected confirmation (green) */
.addon-bucket-warn{
  display:none;align-items:center;gap:8px;
  background:rgba(74,175,80,.06);border:1px solid rgba(74,175,80,.2);
  border-radius:2px;padding:9px 12px;font-size:11px;color:#4caf50;
  margin-top:6px;line-height:1.5;
}
.addon-bucket-warn i{flex-shrink:0}

/* ─── CATEGORY FILTER BAR ─────────────────────────────────── */
.cf-bar{background:var(--bg2);border-bottom:1px solid var(--bd);position:sticky;top:70px;z-index:89}
.admin-bar .cf-bar{top:102px}
@media screen and (max-width:782px){.admin-bar .cf-bar{top:116px}}
.cf-inner{display:flex;align-items:center;gap:2px;padding:10px 28px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}
.cf-inner::-webkit-scrollbar{display:none}
.cf-pipe{width:1px;height:18px;background:#2a2a2a;flex-shrink:0;margin:0 8px}

.cf-tab{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 12px;border-radius:100px;
  font-family:var(--fb);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:#5a5a5a;border:1px solid transparent;white-space:nowrap;
  text-decoration:none!important;transition:color .15s,background .15s,border-color .15s;
  flex-shrink:0;line-height:1;
}
.cf-tab i{font-size:10px;opacity:.7;transition:opacity .15s}
.cf-tab:hover{color:#bbb;background:var(--bg3);border-color:#333}
.cf-tab:hover i{opacity:1}
.cf-tab.on{color:#fff!important;background:var(--red);border-color:var(--red)}
.cf-tab.on i{opacity:1}

.cf-lbl{}
.cf-cnt{
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.1);color:#aaa;
  font-size:9px;font-weight:800;
  padding:0 5px;border-radius:100px;min-width:17px;height:15px;
  line-height:1;
}
.cf-tab.on .cf-cnt{background:rgba(255,255,255,.2);color:#fff}
.cf-tab:hover .cf-cnt{background:rgba(255,255,255,.1);color:#ccc}

.cf-content{background:var(--bg0);padding:40px 0 80px}
@media(max-width:768px){.cf-bar{top:0;position:relative}.cf-inner{padding:8px 16px}.cf-tab{font-size:10px;padding:5px 10px}}

/* ─── MEGA MENU ─────────────────────────────────────────────── */
/* Nav item wrapper (replaces plain <a> for items with sub-menus) */
.nav-item{position:relative;display:inline-flex;align-items:center}

/* Top-level link inside nav-item */
#mainNav .nav-link{
  font-size:13px;font-weight:500;color:var(--gray);
  padding:8px 14px;border-radius:2px;cursor:pointer;
  transition:color .18s,background .18s;letter-spacing:.2px;
  display:flex;align-items:center;gap:5px;
  text-decoration:none;white-space:nowrap;
}
#mainNav .nav-link:hover,#mainNav .nav-link.on{color:#fff;background:var(--bg2)}

/* Chevron arrow */
.nav-arr{font-size:9px;color:var(--gray2);transition:transform .22s;flex-shrink:0}
.nav-item:hover .nav-arr{transform:rotate(180deg);color:#fff}

/* ── Mega menu panel ── */
.mega-wrap{
  position:absolute;top:calc(100% + 1px);left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--bg0);
  border:1px solid var(--bd);border-top:2px solid var(--red);
  border-radius:0 0 6px 6px;
  box-shadow:0 28px 64px rgba(0,0,0,.8);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s,visibility .2s,transform .2s;
  z-index:9999;width:820px;
}
.nav-item:hover .mega-wrap{
  opacity:1;visibility:visible;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.mega-inner{display:grid;grid-template-columns:1fr 1fr 1fr 210px}

/* Mega columns */
.mega-col{padding:22px 20px;border-right:1px solid var(--bd)}
.mega-col-hd{
  font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--red);margin-bottom:12px;
  display:flex;align-items:center;gap:6px;font-family:var(--fd);
  padding-bottom:10px;border-bottom:1px solid var(--bd);
}
.mega-col-hd i{font-size:11px}
.mega-link{
  display:flex;align-items:center;gap:7px;
  font-size:12px;font-weight:400;color:#777;
  padding:7px 0;
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:color .15s,padding-left .15s;
  text-decoration:none;line-height:1.3;
}
.mega-link:last-child{border-bottom:none}
.mega-link:hover{color:#fff;background:transparent;padding-left:5px}
.mega-link i.fa-angle-right{font-size:10px;color:var(--red);flex-shrink:0;transition:transform .15s}
.mega-link:hover i.fa-angle-right{transform:translateX(2px)}

/* Promo panel (rightmost column) */
.mega-promo{
  background:rgba(196,21,21,.07);border-left:1px solid rgba(196,21,21,.2);
  padding:22px 18px;display:flex;flex-direction:column;
}
.mp-tag{
  font-size:9px;font-weight:700;letter-spacing:2.5px;color:var(--red);
  text-transform:uppercase;margin-bottom:10px;font-family:var(--fd);
}
.mp-title{font-family:var(--fd);font-size:22px;letter-spacing:1px;color:#fff;margin-bottom:8px;line-height:1.1}
.mp-desc{font-size:11px;color:#666;line-height:1.7;margin-bottom:14px;flex:1}
.mp-btn{width:100%;text-align:center;font-size:12px!important;padding:10px 16px!important;justify-content:center;margin-bottom:0}
.mp-phone{
  display:flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;color:#555;
  margin-top:10px;transition:color .15s;text-decoration:none;
}
.mp-phone:hover{color:#fff}.mp-phone i{color:var(--red);font-size:10px}
.mp-hours{display:flex;align-items:center;gap:6px;font-size:11px;color:#444;margin-top:6px}
.mp-hours i{color:var(--gray2);font-size:10px}

/* ── Simple dropdown ── */
.nav-drop{
  position:absolute;top:calc(100% + 1px);left:0;
  background:var(--bg0);
  border:1px solid var(--bd);border-top:2px solid var(--red);
  border-radius:0 0 4px 4px;min-width:230px;
  box-shadow:0 20px 48px rgba(0,0,0,.8);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s,visibility .2s,transform .2s;
  transform:translateY(8px);z-index:9999;
}
.nav-item:hover .nav-drop{opacity:1;visibility:visible;pointer-events:all;transform:translateY(0)}
.drop-link{
  display:flex;align-items:center;gap:9px;
  padding:11px 16px;font-size:12px;color:#777;
  border-bottom:1px solid var(--bd);
  transition:all .15s;text-decoration:none;background:transparent;
  border-radius:0!important;
}
.drop-link:last-child{border-bottom:none}
.drop-link:hover{color:#fff;background:var(--bg2)!important;padding-left:22px}
.drop-link-all{color:#aaa;font-weight:600}
.drop-link-all:hover{color:#fff}
.drop-link i{font-size:11px;color:var(--red);flex-shrink:0}
.drop-sep{height:1px;background:var(--bd)}

/* Override base nav a styles for sub-menu links */
nav .mega-link,nav .drop-link{font-weight:400!important;letter-spacing:0!important;border-radius:0!important}
nav .mega-link:hover{background:transparent!important}
nav .drop-link:hover{background:var(--bg2)!important}

/* ── Mobile mega menu ── */
@media(max-width:900px){
  /* nav-item must be full-width block, not inline-flex */
  .nav-item{display:block!important;width:100%!important;position:static!important}

  /* Kill ALL dropdown visibility on mobile — override hover rules with !important */
  .mega-wrap,
  .nav-item:hover .mega-wrap,
  .nav-drop,
  .nav-item:hover .nav-drop{
    display:none!important;
    position:static!important;
    transform:none!important;
    width:100%!important;
    box-shadow:none!important;
    border:none!important;
    border-radius:0!important;
    opacity:1!important;
    visibility:visible!important;
  }
  /* Show only when JS adds .mob-open */
  .nav-item.mob-open .mega-wrap,
  .nav-item.mob-open .nav-drop{
    display:block!important;
    background:rgba(255,255,255,.03);
    border-top:1px solid var(--bd)!important;
  }

  .mega-inner{grid-template-columns:1fr!important}
  .mega-col{border-right:none!important;border-bottom:1px solid var(--bd);padding:14px 18px}
  .mega-promo{display:none!important}

  /* Reset hover arrow on mobile; only rotate when mob-open */
  .nav-item:hover .nav-arr{transform:none!important;color:var(--gray2)!important}
  .nav-item.mob-open .nav-arr{transform:rotate(180deg)!important;color:#fff!important}

  /* Nav link styling in mobile overlay */
  #mainNav .nav-link{
    border-bottom:1px solid var(--bd)!important;
    border-radius:0!important;
    justify-content:space-between!important;
    padding:15px 22px!important;
    background:transparent!important;
    width:100%!important;
    font-size:14px!important;
  }
  #mainNav .nav-link.on{background:rgba(196,21,21,.08)!important}
  /* Plain links (About Us, Contact) in mobile overlay */
  #mainNav > a{
    padding:15px 22px!important;
    border-bottom:1px solid var(--bd)!important;
    border-radius:0!important;
    display:block!important;
    font-size:14px!important;
    color:var(--gray)!important;
  }
  #mainNav > a:hover,#mainNav > a.on{color:#fff!important;background:var(--bg2)!important}

  /* Sub-menu link hover on mobile */
  nav .mega-link:hover{background:rgba(255,255,255,.05)!important;padding-left:12px}
  nav .drop-link:hover{background:rgba(255,255,255,.05)!important;padding-left:22px}
}

/* ── STORAGE PAGE ────────────────────────────────────────────── */
.stor-intro{font-size:14px;color:var(--gray);line-height:1.75;margin:0 0 28px}
.stor-what h3,.stor-features h3{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin:0 0 14px;font-family:var(--fd)}
.stor-list{list-style:none;margin:0 0 32px;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}
.stor-list li{display:flex;align-items:center;gap:8px;font-size:12px;color:#ccc;padding:8px 12px;background:var(--bg3);border-radius:3px;border-left:2px solid var(--red)}
.stor-list li i{color:var(--red);font-size:11px;flex-shrink:0}
.stor-feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:0 0 48px}
.stor-feat-card{background:var(--bg3);border:1px solid var(--bd);border-radius:4px;padding:18px 16px;display:flex;align-items:flex-start;gap:12px}
.stor-feat-icon{width:38px;height:38px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:14px}
.stor-feat-card h4{margin:0 0 4px;font-size:12px;color:#fff;letter-spacing:.5px;text-transform:uppercase;font-family:var(--fd)}
.stor-feat-card p{margin:0;font-size:11px;color:var(--gray2);line-height:1.55}

/* Earn section */
.earn-section{background:var(--bg2);border:1px solid var(--bd);border-radius:6px;padding:48px 40px;margin:8px 0 0;position:relative;overflow:hidden}
.earn-section::before{content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;background:var(--red);opacity:.04;border-radius:50%}
.earn-head{margin:0 0 6px;font-size:clamp(22px,3.5vw,38px);font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:-0.5px;line-height:1.1}
.earn-head span{color:var(--red)}
.earn-sub{font-size:13px;color:var(--gray);margin:0 0 36px;max-width:580px;line-height:1.65}
.earn-flow{display:flex;align-items:center;gap:0;margin:0 0 40px;flex-wrap:wrap;gap:4px}
.earn-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:18px 14px;background:var(--bg3);border:1px solid var(--bd);border-radius:4px;flex:1;min-width:110px}
.earn-step i{font-size:22px;color:var(--red);margin-bottom:8px}
.earn-step strong{font-size:11px;color:#fff;text-transform:uppercase;letter-spacing:.8px;display:block;margin-bottom:4px;font-family:var(--fd)}
.earn-step small{font-size:10px;color:var(--gray2);line-height:1.4}
.earn-arrow{color:var(--red);font-size:16px;padding:0 4px;flex-shrink:0;align-self:center}
.earn-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:0 0 36px}
.earn-benefit{display:flex;align-items:flex-start;gap:10px;padding:16px;background:var(--bg3);border-radius:4px;border:1px solid var(--bd)}
.earn-benefit i{color:#4caf50;font-size:15px;margin-top:1px;flex-shrink:0}
.earn-benefit strong{font-size:11px;color:#fff;display:block;margin-bottom:3px;text-transform:uppercase;letter-spacing:.5px;font-family:var(--fd)}
.earn-benefit span{font-size:11px;color:var(--gray2);line-height:1.5}
.earn-cta-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.earn-cta-note{font-size:11px;color:var(--gray2);line-height:1.6}
.earn-cta-note strong{color:#fff}
@media(max-width:640px){.earn-section{padding:32px 22px}.earn-flow{flex-direction:column;align-items:stretch}.earn-arrow{transform:rotate(90deg);text-align:center;padding:2px 0}.earn-step{flex-direction:row;text-align:left;gap:12px;padding:12px}.earn-step i{margin-bottom:0;font-size:18px}}

/* Rental pricing tiers */
.rent-tier-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 28px}
.rent-tier{background:var(--bg3);border:1px solid var(--bd);border-radius:4px;padding:20px 16px;text-align:center;position:relative;overflow:hidden}
.rent-tier.best{border-color:var(--red);background:rgba(220,50,47,.05)}
.rent-tier-badge{position:absolute;top:0;left:0;right:0;background:var(--red);color:#fff;font-size:9px;font-weight:800;letter-spacing:.8px;padding:3px 0;text-transform:uppercase;font-family:var(--fd);text-align:center}
.rent-tier-label{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--gray2);font-family:var(--fd);margin:0 0 8px;display:block}
.rent-tier.best .rent-tier-label{margin-top:16px}
.rent-tier-val{font-size:28px;font-weight:900;color:#fff;font-family:var(--fd);line-height:1;display:block}
.rent-tier-per{font-size:10px;color:var(--gray2);display:block;margin-top:3px}
@media(max-width:640px){.rent-tier-grid{grid-template-columns:1fr 1fr}}

/* Storage pricing */
.stor-pricing-wrap{margin:0 0 40px}
.stor-pricing-wrap h3{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin:0 0 16px;font-family:var(--fd)}
.stor-tier-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:0 0 14px}
.stor-tier{background:var(--bg3);border:1px solid var(--bd);border-radius:4px;padding:22px 18px;position:relative;overflow:hidden;transition:border-color .2s}
.stor-tier:hover{border-color:#444}
.stor-tier.featured{border-color:var(--red);background:rgba(220,50,47,.05)}
.stor-tier-badge{position:absolute;top:0;right:0;background:var(--red);color:#fff;font-size:9px;font-weight:800;letter-spacing:.8px;padding:4px 10px;text-transform:uppercase;font-family:var(--fd)}
.stor-tier-label{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--gray2);margin:0 0 4px;font-family:var(--fd)}
.stor-tier-name{font-size:15px;font-weight:800;color:#fff;margin:0 0 10px;font-family:var(--fd);text-transform:uppercase;letter-spacing:.3px}
.stor-tier-price{margin:0 0 12px}
.stor-tier-price .stp-val{font-size:30px;font-weight:900;color:#fff;font-family:var(--fd);line-height:1}
.stor-tier-price .stp-per{font-size:11px;color:var(--gray2);margin-left:3px}
.stor-tier-desc{font-size:11px;color:var(--gray2);line-height:1.55;margin:0;border-top:1px solid var(--bd);padding-top:10px}

.stor-rental-prog{background:var(--bg3);border:1px solid rgba(74,175,80,.3);border-radius:4px;padding:20px 22px;margin:0 0 28px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.srp-icon{width:44px;height:44px;background:rgba(74,175,80,.12);border:1px solid rgba(74,175,80,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.srp-icon i{color:#4caf50;font-size:18px}
.srp-body{flex:1;min-width:200px}
.srp-title{font-size:12px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.6px;font-family:var(--fd);margin:0 0 4px}
.srp-desc{font-size:11px;color:var(--gray2);line-height:1.55;margin:0}
.srp-price{text-align:right;flex-shrink:0}
.srp-price .stp-val{font-size:22px;font-weight:900;color:#4caf50;font-family:var(--fd);line-height:1;display:block}
.srp-price .stp-per{font-size:10px;color:var(--gray2)}

.stor-addons-wrap h3{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin:0 0 14px;font-family:var(--fd)}
.stor-addons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin:0 0 40px}
.stor-addon-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;background:var(--bg3);border:1px solid var(--bd);border-radius:3px}
.stor-addon-item span{font-size:11px;color:#ccc}
.stor-addon-item strong{font-size:11px;color:var(--red);font-family:var(--fd);white-space:nowrap}
@media(max-width:600px){.stor-tier-grid{grid-template-columns:1fr 1fr}.stor-rental-prog{flex-direction:column;gap:14px}.srp-price{text-align:left}}

/* === CHECKOUT UI FIX === */
.woocommerce-checkout .col2-set{display:grid!important;grid-template-columns:1fr 1fr!important;gap:32px!important;float:none!important;width:100%!important;margin-bottom:32px!important}
.woocommerce-checkout .col2-set .col-1,.woocommerce-checkout .col2-set .col-2{float:none!important;width:100%!important}
.woocommerce-checkout input[type=text],.woocommerce-checkout input[type=email],.woocommerce-checkout input[type=tel],.woocommerce-checkout input[type=password],.woocommerce-checkout select,.woocommerce-checkout textarea{background:#1a1a1a!important;background-color:#1a1a1a!important;border:1px solid #2e2e2e!important;color:#fff!important;-webkit-text-fill-color:#fff!important;caret-color:#fff!important;border-radius:3px!important;padding:13px 15px!important;font-size:14px!important;width:100%!important;box-sizing:border-box!important;transition:border-color .2s!important;color-scheme:dark!important}
.woocommerce-checkout input:focus,.woocommerce-checkout select:focus,.woocommerce-checkout textarea:focus{border-color:var(--red)!important;box-shadow:0 0 0 2px rgba(196,21,21,.15)!important;outline:none!important}
.woocommerce-checkout input:-webkit-autofill,.woocommerce-checkout input:-webkit-autofill:hover,.woocommerce-checkout input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #1a1a1a inset!important;-webkit-text-fill-color:#fff!important;caret-color:#fff!important}
.woocommerce-checkout label,.woocommerce-checkout .form-row label{color:#888!important;font-size:11px!important;font-weight:700!important;letter-spacing:1.2px!important;text-transform:uppercase!important;margin-bottom:7px!important;display:block!important}
.woocommerce-checkout .required{color:var(--red)!important}
.woocommerce-checkout h3{font-family:var(--fd)!important;font-size:18px!important;letter-spacing:1px!important;color:#fff!important;margin-bottom:20px!important;padding-bottom:10px!important;border-bottom:1px solid var(--bd)!important;text-transform:uppercase!important}
.woocommerce-checkout h3#order_review_heading{margin-top:32px!important}
.woocommerce-checkout-review-order-table{width:100%!important;border-collapse:collapse!important}
.woocommerce-checkout-review-order-table th,.woocommerce-checkout-review-order-table td{padding:12px 0!important;border-bottom:1px solid var(--bd)!important;color:#fff!important;font-size:13px!important}
.woocommerce-checkout-review-order-table thead th{font-size:10px!important;letter-spacing:1.5px!important;text-transform:uppercase!important;color:#555!important;font-weight:700!important}
.woocommerce-checkout-review-order-table .order-total td,.woocommerce-checkout-review-order-table .order-total th{color:var(--red)!important;font-size:20px!important;font-family:var(--fd)!important;border-bottom:none!important}
.woocommerce-checkout #payment{background:#111!important;border:1px solid var(--bd)!important;border-radius:4px!important;padding:24px!important;margin-top:8px!important}
.woocommerce-checkout #payment ul.payment_methods{list-style:none!important;padding:0 0 16px!important;margin:0 0 16px!important;border-bottom:1px solid var(--bd)!important}
.woocommerce-checkout #payment ul.payment_methods li{padding:14px!important;margin-bottom:8px!important;border:1px solid var(--bd)!important;border-radius:3px!important;background:#1a1a1a!important;cursor:pointer!important;transition:border-color .2s!important}
.woocommerce-checkout #payment ul.payment_methods li label{color:#fff!important;font-size:14px!important;font-weight:600!important;letter-spacing:.3px!important;text-transform:none!important;cursor:pointer!important;display:inline-flex!important;align-items:center!important;gap:10px!important}
.woocommerce-checkout #payment input[type=radio]{width:16px!important;height:16px!important;accent-color:var(--red)!important;flex-shrink:0!important}
.woocommerce-checkout #payment .payment_box{background:#0f0f0f!important;border:1px solid var(--bd)!important;border-radius:3px!important;padding:16px!important;margin-top:10px!important;color:#888!important;font-size:13px!important}
.woocommerce-checkout #place_order{width:100%!important;padding:18px!important;font-size:16px!important;letter-spacing:2px!important;font-family:var(--fd)!important;background:var(--red)!important;color:#fff!important;border:none!important;border-radius:3px!important;cursor:pointer!important;transition:background .2s!important;text-transform:uppercase!important;margin-top:16px!important}
.woocommerce-checkout #place_order:hover{background:var(--red2)!important}
.woocommerce-checkout textarea#order_comments{min-height:100px!important}
@media(max-width:768px){.woocommerce-checkout .col2-set{grid-template-columns:1fr!important}}

/* === ORDER RECEIVED POPUP === */
.c911-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.93);z-index:99999;display:flex;align-items:center;justify-content:center;animation:c9FadeIn .4s both}
@keyframes c9FadeIn{from{opacity:0}to{opacity:1}}
.c911-box{background:#111;border:1px solid #222;border-top:3px solid #22a722;border-radius:6px;padding:48px 40px;max-width:540px;width:92%;text-align:center;animation:c9Up .45s .1s both}
@keyframes c9Up{from{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}
.c911-icon{width:72px;height:72px;background:rgba(34,167,34,.1);border:2px solid #22a722;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:34px;color:#22a722}
.c911-box h2{font-family:var(--fd);font-size:30px;letter-spacing:2px;color:#fff;margin-bottom:10px;text-transform:uppercase}
.c911-box p{color:#777;font-size:14px;line-height:1.7;margin-bottom:4px}
.c911-box .c9-onum{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:3px;padding:12px 20px;margin:20px 0;font-family:var(--fd);font-size:20px;color:var(--red);letter-spacing:1px}
.c9-btns{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap}
.c9-close{background:var(--red);color:#fff;border:none;padding:14px 32px;border-radius:3px;font-family:var(--fd);font-size:13px;letter-spacing:1.5px;cursor:pointer;text-transform:uppercase;transition:background .2s}
.c9-close:hover{background:var(--red2)}
.c9-call{background:#1a1a1a;color:#ccc;border:1px solid #333;padding:14px 20px;border-radius:3px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:border-color .2s}
.c9-call:hover{border-color:#fff;color:#fff}
@media(max-width:480px){.c911-box{padding:32px 20px}.c9-btns{flex-direction:column}}
