@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&display=swap');

:root{--bg:#fff;--text:#1f2937;--muted:#6b7280;--primary:#b80d0d;--line:#e5e7eb;--shadow:0 10px 30px rgba(0,0,0,.08);--radius:14px;--max:1200px;--font:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans","Helvetica Neue",sans-serif}
*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font);background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}.main{min-height:60vh}
.topbar{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line);z-index:50}
.topbar-inner{max-width:var(--max);margin:0 auto;position:relative;display:flex;align-items:center;justify-content:space-between;padding:10px 20px;gap:16px}
.menu{display:flex;align-items:center;justify-content:center;gap:24px;flex:1}
.menu a{font-size:14px;font-family:'Roboto', sans-serif;font-weight:600;color:#838b9b;padding:8px 10px;border-radius:10px}
.menu a.active{color:var(--primary);border-bottom:2px solid var(--primary);border-radius:0;padding-bottom:4px}
.logo{display:flex;align-items:center;justify-content:center;min-width:130px}
.logo img{height:35px;display:block}.logo span{font-weight:800;letter-spacing:.15em;color:var(--primary)}
.searchbox{position:absolute;right:16px;display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:6px 10px;color:var(--muted)}
.searchbox input{border:0;outline:0;background:transparent;font-size:13px;width:140px}
.search-ico{opacity:.6}
.hero{position:relative}
.hero-media{height:520px;max-height:70vh;background:#f3f4f6}
.hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.hero-placeholder{height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}
.hero-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;width:90%;max-width:700px;display:flex;flex-direction:column;align-items:center;gap:32px;}
.hero-badge{width:44px;height:44px;border-radius:14px;background:linear-gradient(180deg,#d11212,var(--primary));box-shadow:var(--shadow);position:relative}
.hero-badge:after{content:"";position:absolute;inset:12px;border:2px solid rgba(255,255,255,.9);border-radius:10px}
.hero-copy{margin-top:120px;max-width:320px;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.35)}
.hero-copy h1{margin:0 0 16px;font-size:22px;line-height:1.25;font-weight:800}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:10px 16px;font-weight:700;font-size:13px;border:1px solid transparent;cursor:pointer}
.btn-sm{padding:8px 12px;font-size:12px}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{filter:brightness(1.05)}
.btn-secondary{background:#fff;border-color:var(--primary);color:var(--primary)}.btn-secondary:hover{background:#fff5f5}
.btn-ghost{background:transparent;border-color:var(--line);color:#111827}
.btn-danger{background:#fff;border-color:#ef4444;color:#ef4444}.btn-danger:hover{background:#fff5f5}
.featured{max-width:var(--max);margin:0 auto;padding:20px 16px 60px}
.featured-row{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;align-items:end;margin-top:-75px}
.product-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 10px 25px rgba(0,0,0,.04);padding:14px;text-align:center}
.product-img{display:flex;align-items:center;justify-content:center;height:120px}
.product-img img{max-height:120px;max-width:100%;object-fit:contain}
.img-placeholder{width:90px;height:90px;border-radius:18px;background:#f3f4f6}
.product-title{font-size:12px;margin:10px 0 6px;color:var(--primary);font-weight:800}
.product-price{font-size:11px;color:#111827;margin-bottom:10px;font-weight:700}
/* ── old product page replaced → see .pdp-* below ── */
.product-page,.product-wrap,.product-media,.product-media-placeholder,.product-info,.product-short,.product-desc,.product-cta{/* legacy stubs – not used */}

/* ====================================================================
   PRODUCT DETAIL PAGE (PDP) — Enterprise
   ==================================================================== */

/* Breadcrumb */
.pdp-bc{background:#f8f9fb;border-bottom:1px solid var(--line);padding:10px 0}
.pdp-bc-inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);flex-wrap:wrap}
.pdp-bc-inner a{color:var(--muted);transition:color .15s}.pdp-bc-inner a:hover{color:var(--primary)}
.pdp-bc-inner span{color:#9ca3af}
.pdp-bc-cur{color:#374151;font-weight:600}

/* Hero wrapper */
.pdp-hero{background:#fff;padding:40px 0 48px}
.pdp-hero-inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}

/* Gallery */
.pdp-gallery-col{position:sticky;top:80px}
.pdp-main-viewer{border:1px solid var(--line);border-radius:5px;overflow:hidden;background:#f8fafc;position:relative}
.pdp-main-img{width:100%;aspect-ratio:4/3;object-fit:contain;display:block;background:#fff;transition:opacity .12s ease;padding:8px}
.pdp-no-img{aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#d1d5db;font-size:13px}

/* Thumbnail strip */
.pdp-thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.pdp-thumb{width:76px;height:76px;border:2px solid var(--line);border-radius:5px;overflow:hidden;padding:0;background:#f8fafc;cursor:pointer;transition:border-color .15s,box-shadow .15s;flex-shrink:0}
.pdp-thumb img{width:100%;height:100%;object-fit:contain;padding:3px}
.pdp-thumb.is-active{border-color:var(--primary);box-shadow:0 0 0 3px rgba(184,13,13,.12)}
.pdp-thumb:hover:not(.is-active){border-color:#9ca3af}

/* Info column */
.pdp-info-col{display:flex;flex-direction:column;gap:0}
.pdp-cats{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.pdp-cat{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:#fff0f0;color:var(--primary);padding:3px 10px;border-radius:4px}
.pdp-title{font-size:30px;font-weight:800;color:#111827;margin:0 0 6px;line-height:1.2}
.pdp-sku{font-size:12px;color:var(--muted);margin:0 0 12px}
.pdp-rule{border:0;border-top:1px solid var(--line);margin:14px 0}

/* Price */
.pdp-prices{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.pdp-price-reg{font-size:26px;font-weight:800;color:#111827}
.pdp-price-sale{font-size:26px;font-weight:800;color:var(--primary)}
.pdp-price-was{font-size:16px;color:#9ca3af;text-decoration:line-through}
.pdp-sale-tag{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px}

/* Short text */
.pdp-short{font-size:14px;color:#374151;line-height:1.7;margin-bottom:14px}

/* Stock badge */
.pdp-stock-badge{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;padding:5px 12px;border-radius:5px;margin-bottom:20px}
.pdp-stock--in{background:#ecfdf5;color:#065f46}
.pdp-stock--out{background:#fef2f2;color:#991b1b}

/* CTA buttons */
.pdp-cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.pdp-btn-wa{display:inline-flex;align-items:center;gap:8px;background:#25d366;color:#fff;font-size:14px;font-weight:700;padding:13px 22px;border-radius:8px;text-decoration:none;transition:filter .2s,transform .15s;letter-spacing:.01em}
.pdp-btn-wa:hover{filter:brightness(1.08);transform:translateY(-1px)}
.pdp-btn-quote{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--primary);color:var(--primary);font-size:14px;font-weight:700;padding:12px 22px;border-radius:8px;text-decoration:none;transition:background .15s,transform .15s}
.pdp-btn-quote:hover{background:#fff5f5;transform:translateY(-1px)}

/* Trust row */
.pdp-trust-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-top:4px;border-top:1px solid var(--line)}
.pdp-trust-item{display:flex;align-items:center;gap:7px;font-size:12px;color:#6b7280;padding:8px 0}
.pdp-trust-item svg{flex-shrink:0;color:var(--primary)}

/* ── Description section ───────────────────────────────────── */
.pdp-desc-wrap{background:#fafafa;border-top:1px solid var(--line);padding:48px 24px 64px}
.pdp-desc-inner{max-width:var(--max);margin:0 auto}
.pdp-desc-heading{display:flex;align-items:center;gap:20px;margin:0 0 28px;font-size:20px;font-weight:500;color:#111827;white-space:nowrap}
.pdp-desc-rule{flex:1;height:2px;background:linear-gradient(to right,var(--primary),transparent)}
.pdp-desc-body{font-size:15px;color:#374151;line-height:1.85}
.pdp-desc-body h2{font-size:18px;font-weight:400;color:#111827;margin:28px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.pdp-desc-body h3{font-size:16px;font-weight:700;margin:20px 0 10px}
.pdp-desc-body p{margin:0 0 14px}
.pdp-desc-body ul,.pdp-desc-body ol{padding-left:22px;margin:12px 0}
.pdp-desc-body li{margin-bottom:6px}
.pdp-desc-body strong{color:#111827}

/* ── TABLE STYLING — enterprise clean ─────────────────────── */
.pdp-desc-body table{width:100%;border-collapse:collapse;margin:20px 0;font-size:14px;border:1px solid #e5e7eb;border-radius:5px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.pdp-desc-body table thead tr,.pdp-desc-body table tr:first-child{background:#8a0000}
.pdp-desc-body table thead th,.pdp-desc-body table tr:first-child td,.pdp-desc-body table tr:first-child th{color:#fff;font-weight:700;font-size:13px;letter-spacing:.04em;padding:12px 14px;text-align:left;border:none}
.pdp-desc-body table tbody tr{transition:background .12s}
.pdp-desc-body table tbody tr:nth-child(even){background:#f9fafb}


.pdp-desc-body table td{padding:11px 14px;border-bottom:1px solid #e5e7eb;vertical-align:top;color:#374151}
.pdp-desc-body table td:first-child{font-weight:700;color:#111827;white-space:nowrap}
/* Remove WC inline width attrs that break layout */
.pdp-desc-body table td[width],.pdp-desc-body table th[width]{width:auto !important}
.pdp-desc-body table[width]{width:100% !important}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:960px){
  .pdp-hero-inner{grid-template-columns:1fr;gap:32px}
  .pdp-gallery-col{position:static}
  .pdp-title{font-size:24px}
}
@media(max-width:600px){
  .pdp-hero{padding:24px 0 32px}
  .pdp-hero-inner{padding:0 14px}
  .pdp-cta-row{flex-direction:column}
  .pdp-btn-wa,.pdp-btn-quote{justify-content:center}
  .pdp-trust-row{grid-template-columns:1fr}
  .pdp-thumbs{gap:6px}
  .pdp-thumb{width:60px;height:60px}
  .pdp-desc-wrap{padding:28px 14px 40px}
  .pdp-desc-body table{font-size:12px}
  .pdp-desc-body table td,.pdp-desc-body table th{padding:8px 10px}
}.discover{text-align:center;color:var(--primary);font-weight:900;margin:22px 0 12px;font-size:22px}
.center{text-align:center}

.page{max-width:var(--max);margin:0 auto;padding:26px 16px}
.page-inner{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.page-content{color:#374151;line-height:1.6}
.product-page{max-width:var(--max);margin:0 auto;padding:0}
.product-wrap{display:block}
.product-media img,.product-media-placeholder,.product-info h1,.product-short,.product-desc,.product-cta{/* superseded by .pdp-* */}
.admin-body{background:#f6f7fb}
.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.admin-sidebar{background:linear-gradient(180deg,#eef5fa 0%,#e6eff7 100%);color:#0c2f56;padding:18px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow:hidden;border-right:1px solid rgba(12,47,86,.08);box-shadow:inset -1px 0 0 rgba(255,255,255,.55)}
.admin-brand{display:flex;align-items:center;justify-content:center;margin-bottom:16px;padding:8px 6px 14px;border-bottom:1px solid rgba(12,47,86,.08)}
.admin-brand-logo{display:block;max-width:100%;width:200px;height:auto;object-fit:contain}
.admin-brand span{opacity:.7;font-weight:800}
.admin-nav{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.admin-nav a{padding:12px 14px;border-radius:14px;color:#12385f;font-size:13px;font-weight:700;border:1px solid transparent;background:rgba(255,255,255,.28);backdrop-filter:blur(4px)}
.admin-nav a.active,.admin-nav a:hover{background:#ffffff;color:#0a2a4a;border-color:rgba(32,93,150,.16);box-shadow:0 10px 22px rgba(25,74,122,.08)}
.admin-logout{margin-top:auto;padding-top:24px}
.admin-content{padding:18px;min-width:0}
.admin-topbar{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 16px;box-shadow:var(--shadow)}
.admin-title{font-weight:900}
.admin-inner{padding:18px 0}

.admin-logout .btn{width:100%;justify-content:center;background:#0f4c81;color:#fff;border-color:#0f4c81;box-shadow:0 12px 26px rgba(15,76,129,.18)}
.admin-logout .btn:hover{background:#0b3d68;border-color:#0b3d68;color:#fff}
.admin-topbar-left{display:flex;align-items:center;gap:12px}
.admin-sidebar-toggle{display:none !important;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;border:1px solid rgba(12,47,86,.08);background:#fff;color:#0c2f56;font-size:18px;cursor:pointer;box-shadow:0 8px 20px rgba(15,76,129,.08)}
.admin-sidebar-toggle:hover{background:#f8fbff}
body.admin-sidebar-collapsed .admin-shell{grid-template-columns:96px 1fr}
body.admin-sidebar-collapsed .admin-brand{padding-bottom:10px}
body.admin-sidebar-collapsed .admin-brand-logo{width:56px}
body.admin-sidebar-collapsed .admin-nav a{font-size:0;padding:12px 10px;min-height:44px}
body.admin-sidebar-collapsed .admin-nav a span{display:none}
body.admin-sidebar-collapsed .admin-nav a{position:relative}
body.admin-sidebar-collapsed .admin-nav a::before{content:"•";font-size:20px;line-height:1;color:#0f4c81;margin:auto;display:block;text-align:center}
body.admin-sidebar-collapsed .admin-nav a.active::before{color:#0a2a4a}
body.admin-sidebar-collapsed .admin-logout .btn{font-size:0;position:relative;padding:12px 10px}
body.admin-sidebar-collapsed .admin-logout .btn::before{content:"⎋";font-size:18px;line-height:1;color:#fff}
@media (max-width:720px){.admin-brand-logo{width:170px}body.admin-sidebar-collapsed .admin-shell{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:18px;margin-bottom:16px}
.row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.form{display:flex;flex-direction:column;gap:10px}
.form input[type=text],.form input[type=password],.form input[type=number],.form textarea{border:1px solid var(--line);border-radius:14px;padding:10px 12px;font-size:14px;outline:none}
.form textarea{min-height:160px;resize:vertical}
.form label{font-size:13px;font-weight:800;color:#111827}
.preview{border:1px dashed var(--line);border-radius:5px;padding:10px;background:#fafafa}
.preview img{max-width:100%;border-radius:12px;display:block}
.preview-logo img{height:40px;width:auto}
.sep{border:0;border-top:1px solid var(--line);margin:10px 0}
.grid-actions{display:flex;flex-wrap:wrap;gap:10px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.checks{display:flex;flex-direction:column;gap:8px;padding-top:8px}
.table-wrap{overflow:auto}
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
.table th{font-size:12px;color:#374151;text-transform:uppercase;letter-spacing:.06em}
.actions{display:flex;gap:8px;align-items:center}
.alert{padding:10px 12px;border-radius:14px;font-size:13px;border:1px solid}
.alert-error{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
.alert-ok{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}
.auth-card{max-width:420px;margin:60px auto;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:22px}
.ul{margin:0;padding-left:18px;color:#374151}
@media (max-width:1100px){.featured-row{grid-template-columns:repeat(3,1fr);margin-top:0}.hero-copy{margin-top:70px}}
@media (max-width:720px){.product-wrap{grid-template-columns:1fr}.admin-shell{grid-template-columns:1fr}.admin-sidebar{position:relative;height:auto}}



/* ===== Hero Slider ===== */
.hero-slider{position:relative;height:750px;max-height:70vh;min-height:420px;overflow:hidden;background:#111}
.hero-slider .hero-slides{position:relative;width:100%;height:100%}
.hero-slider .hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s ease;will-change:opacity;background-size:cover;background-position:center;background-repeat:no-repeat}
.hero-slider .hero-slide.is-active{opacity:1;z-index:2}
.hero-slider .hero-slide:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.15) 0%, rgba(0,0,0,.52) 40%, rgba(0,0,0,.52) 60%, rgba(0,0,0,.15) 100%)}
.hero-slider .hero-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;width:90%;max-width:700px;display:flex;flex-direction:column;align-items:center;gap:32px;}
.hero-slider .hero-title{margin:0;color:#fff;font-size:25px;line-height:1.4;font-weight:400;text-shadow:0 2px 12px rgba(0,0,0,.45);letter-spacing:.01em}
.hero-slider .hero-btn{width:fit-content}
.hero-dots{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);display:flex;gap:8px;z-index:4}
.hero-dot{width:10px;height:10px;border-radius:999px;border:0;background:rgba(255,255,255,.35);cursor:pointer}
.hero-dot.is-active{background:rgba(255,255,255,.95)}
.hero-empty{background:#1f2937}
@media (max-width: 768px){
  .hero-slider{height:520px}
  .hero-slider .hero-title{font-size:20px}
}

/* ===== Topbar logo ===== */
.topbar-logo{display:flex;align-items:center;flex-shrink:0}
.topbar-logo .logo-img{height:35px;display:block}
.mobile-topbar-logo{display:none}
.mobile-topbar-logo img{display:block;height:36px;width:auto;max-width:150px;object-fit:contain}

/* ===== Burger button ===== */
.nav-burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:4px;flex-shrink:0}
.nav-burger span{display:block;width:24px;height:2px;background:#1f2937;border-radius:2px;transition:transform .25s, opacity .25s}
.nav-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.is-open span:nth-child(2){opacity:0}
.nav-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Mobile nav ===== */
@media(max-width:768px){
  .nav-burger{display:flex}
  .mobile-topbar-logo{display:flex;align-items:center;justify-content:center;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);height:36px;line-height:0;z-index:2}
  .menu .topbar-logo{display:none !important}
  .topbar-inner{min-height:56px;justify-content:flex-start}
  .menu{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:0;
    background:#fff;border-bottom:1px solid var(--line);
    box-shadow:0 8px 24px rgba(0,0,0,.08);
    padding:8px 0;z-index:100
  }
  .menu.is-open{display:flex}
  .menu a{width:100%;padding:13px 20px;font-size:15px;border-radius:0}
  .menu a.active{border-bottom:0;border-left:3px solid var(--primary);border-radius:0;padding-left:17px}
  .topbar-inner{position:relative}
  .featured-row{grid-template-columns:repeat(2,1fr);margin-top:0}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .hero-slider .hero-overlay{gap:24px}
}
@media(max-width:420px){
  .featured-row{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr}
  .hero-slider .hero-title{font-size:18px}
}

/* ===== Contact Page ===== */
.contact-page{padding:40px 16px 80px}
.contact-wrap{max-width:1100px;margin:0 auto}
.contact-heading{font-size:28px;font-weight:800;color:var(--primary);margin:0 0 28px}
.contact-form{display:flex;flex-direction:column;gap:18px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cf-field{display:flex;flex-direction:column;gap:6px}
.cf-field--full{grid-column:1/-1}
.cf-field--half{max-width:520px}
.cf-label{font-size:13px;font-weight:600;color:#111827}
.cf-input{border:1px solid #b0b7c3;border-radius:4px;padding:10px 12px;font-size:14px;outline:none;transition:border-color .2s;width:100%}
.cf-input:focus{border-color:var(--primary)}
.cf-textarea{border:1px solid #b0b7c3;border-radius:4px;padding:10px 12px;font-size:14px;outline:none;resize:vertical;min-height:150px;width:100%;transition:border-color .2s}
.cf-textarea:focus{border-color:var(--primary)}
.cf-checkgroup{display:flex;flex-direction:column;gap:8px;padding-top:4px}
.cf-check-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;color:#111827}
.cf-check-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);flex-shrink:0;cursor:pointer}
.cf-select-wrap{position:relative}
.cf-select{width:100%;border:1px solid #b0b7c3;border-radius:4px;padding:10px 36px 10px 12px;font-size:14px;outline:none;appearance:none;background:#fff;cursor:pointer;transition:border-color .2s}
.cf-select:focus{border-color:var(--primary)}
.cf-select-ico{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:#6b7280;font-size:12px}
.cf-submit{width:100%;padding:15px;background:var(--primary);color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:700;cursor:pointer;letter-spacing:.03em;transition:filter .2s}
.cf-submit:hover{filter:brightness(1.08)}
@media(max-width:640px){
  .cf-row{grid-template-columns:1fr}
  .cf-field--half{max-width:100%}
  .contact-heading{font-size:22px}
}

/* ===================================================================
   FOOTER
   =================================================================== */

/* ── Newsletter bar ─────────────────────────────────────────────── */
.footer-newsletter{background:#e8e8e8;padding:40px 20px}
.footer-newsletter-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:32px}
.footer-newsletter-title{margin:0;font-size:26px;font-weight:700;color:var(--primary)}
.footer-newsletter-form{display:flex;align-items:center;gap:0;min-width:420px}
.footer-nsl-input{flex:1;border:1px solid #ccc;border-right:0;border-radius:4px 0 0 4px;padding:12px 16px;font-size:14px;outline:none;background:#fff;height:48px}
.footer-nsl-input:focus{border-color:#aaa}
.footer-nsl-btn{background:#1f2937;color:#fff;border:none;padding:0 22px;height:48px;font-size:13px;font-weight:700;letter-spacing:.08em;cursor:pointer;border-radius:0 4px 4px 0;white-space:nowrap;transition:background .2s}
.footer-nsl-btn:hover{background:#111}
.footer-nsl-msg{font-size:14px;color:#065f46;font-weight:600;padding:8px 0}
.footer-newsletter-map iframe{border-radius:10px;display:block}

/* ── Main footer ────────────────────────────────────────────────── */
.footer-main{background:#f0f0f0;padding:48px 20px 0}
.footer-main-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:40px;border-bottom:1px solid #d8d8d8}

.footer-col{}
.footer-col--brand{}
.footer-logo-link{display:inline-block;margin-bottom:18px}
.footer-logo{height:60px;width:auto;display:block}
.footer-social{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.footer-contacts{display:flex;flex-direction:column;gap:4px}
.footer-col-title{font-size:13px;font-weight:700;color:#111827;margin:0 0 14px;text-transform:uppercase;letter-spacing:.06em}
.footer-nav{display:flex;flex-direction:column;gap:8px}
.footer-link{font-size:14px;color:#4b5563;text-decoration:none;transition:color .18s}
.footer-link:hover{color:var(--primary)}
.footer-link--sm{font-size:13px}
.footer-hours{margin:0 0 14px;font-size:14px;color:#4b5563;line-height:1.7}
.footer-phones{display:flex;flex-direction:column;gap:4px}

/* ── Bottom bar ─────────────────────────────────────────────────── */
.footer-bottom{background:#e0e0e0;padding:14px 20px;width:100vw;margin-left:calc(50% - 50vw)}
.footer-bottom-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#6b7280;flex-wrap:wrap;gap:8px}

/* ── WhatsApp FAB ───────────────────────────────────────────────── */
.whatsapp-fab{position:fixed;bottom:24px;left:20px;width:52px;height:52px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.25);z-index:200;transition:transform .2s,box-shadow .2s;text-decoration:none}
.whatsapp-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(0,0,0,.3)}

/* ── Scroll-to-top ──────────────────────────────────────────────── */
.scroll-top{position:fixed;bottom:24px;right:20px;width:44px;height:44px;border-radius:50%;background:#374151;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.scroll-top.is-visible{opacity:1;pointer-events:auto}
.scroll-top:hover{background:#1f2937;transform:translateY(-2px)}

/* ── Footer responsive ──────────────────────────────────────────── */
@media(max-width:960px){
  .footer-newsletter-inner{grid-template-columns:1fr;gap:20px}
  .footer-newsletter-form{min-width:0;width:100%}
  .footer-newsletter-map{display:none}
  .footer-main-inner{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:580px){
  .footer-main-inner{grid-template-columns:1fr}
  .footer-newsletter-title{font-size:20px}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start}
}

/* ===================================================================
   FAQ PAGE
   =================================================================== */
.faq-page{padding:40px 16px 80px;background:#fff}
.faq-wrap{max-width:1000px;margin:0 auto}

/* ── Accordion ──────────────────────────────────────────────────── */
.faq-accordion{margin-bottom:60px}
.faq-item{border-bottom:1px solid #e5e7eb}
.faq-trigger{width:100%;display:flex;align-items:center;gap:14px;background:none;border:none;cursor:pointer;padding:22px 0;text-align:left}
.faq-icon{flex-shrink:0;width:22px;height:22px;position:relative;color:var(--primary)}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:currentColor;border-radius:2px;transition:transform .25s,opacity .25s}
.faq-icon::before{width:2px;height:16px;top:3px;left:10px}
.faq-icon::after{width:16px;height:2px;top:10px;left:3px}
.faq-item.is-open .faq-icon::before{transform:rotate(90deg);opacity:0}
.faq-question{font-size:18px;font-weight:400;color:var(--primary);line-height:1.3}
.faq-body{display:none;padding:0 0 20px 36px}
.faq-item.is-open .faq-body{display:block}
.faq-answer{font-size:15px;color:#374151;line-height:1.7;border-left:3px solid #f3f4f6;padding-left:16px}

/* ── Mini contact form section ──────────────────────────────────── */
.faq-contact-section{border-top:2px solid #f3f4f6;padding-top:48px}
.faq-contact-inner{display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:start}
.faq-contact-left{font-size:15px;color:#4b5563;line-height:1.7}
.faq-contact-left p{margin:0 0 14px}
.faq-here-link{color:var(--primary);font-weight:600;text-decoration:underline}
.faq-here-link:hover{text-decoration:none}
.faq-mini-form{display:flex;flex-direction:column;gap:14px}
.faq-mini-field{display:flex;flex-direction:column;gap:5px}
.faq-mini-label{font-size:14px;font-weight:600;color:#111827}
.faq-mini-input{border:1px solid #d1d5db;border-radius:4px;padding:10px 12px;font-size:14px;outline:none;transition:border-color .2s}
.faq-mini-input:focus{border-color:var(--primary)}
.faq-mini-textarea{border:1px solid #d1d5db;border-radius:4px;padding:10px 12px;font-size:14px;outline:none;resize:vertical;min-height:150px;transition:border-color .2s}
.faq-mini-textarea:focus{border-color:var(--primary)}
.faq-mini-submit-row{display:flex;justify-content:flex-end}
.faq-mini-submit{background:#fff;border:1px solid var(--primary);color:var(--primary);padding:10px 28px;font-size:14px;font-weight:600;border-radius:4px;cursor:pointer;transition:background .2s,color .2s}
.faq-mini-submit:hover{background:var(--primary);color:#fff}
.faq-shield{display:flex;justify-content:center;margin-top:24px}
.faq-shield svg{width:80px;height:auto;opacity:.9}

@media(max-width:720px){
  .faq-contact-inner{grid-template-columns:1fr}
  .faq-question{font-size:16px}
  .faq-contact-left{font-size:14px}
}

/* ===================================================================
   ABOUT PAGE — Enterprise refinement
   =================================================================== */

/* ── Page shell ─────────────────────────────────────────────────── */
.about-page{background:#fafafa;padding:0 0 80px}
.about-wrap{max-width:1100px;margin:0 auto;padding:0 24px}

/* ── Hero banner ────────────────────────────────────────────────── */
.about-hero{background:linear-gradient(135deg,#1a1a1a 0%,#2d0a0a 60%,#b80d0d 100%);padding:72px 24px;text-align:center;margin-bottom:0}
.about-hero-inner{max-width:760px;margin:0 auto}
.about-hero-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:14px}
.about-hero-title{font-size:42px;font-weight:800;color:#fff;margin:0 0 18px;line-height:1.15}
.about-hero-line{width:56px;height:3px;background:var(--primary);margin:0 auto 20px;border-radius:2px}
.about-hero-sub{font-size:16px;color:rgba(255,255,255,.75);line-height:1.7;margin:0;text-align:justify;hyphens:auto}

/* ── Section card wrapper ───────────────────────────────────────── */
.about-section{background:#fff;border:1px solid #e9ecef;border-radius:5px;padding:56px 52px;margin-top:28px;box-shadow:0 2px 16px rgba(0,0,0,.05)}

/* ── Section header (label + title + accent line) ───────────────── */
.about-section-label{font-size:10px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--primary);margin:0 0 8px;display:block}
.about-section-title{font-size:26px;font-weight:500;color:#111827;margin:0 0 6px;line-height:1.25}
.about-section-rule{width:40px;height:3px;background:var(--primary);border-radius:2px;margin:0 0 28px}

/* ── Body text — justified everywhere ──────────────────────────── */
.about-body{font-size:15px;color:#374151;line-height:1.85;margin:0;text-align:justify;hyphens:auto}
.about-body+.about-body{margin-top:18px}

/* ── Two-column layout (text + image) ──────────────────────────── */
.about-cols{display:grid;gap:52px;align-items:center}
.about-cols--img-right{grid-template-columns:1fr 380px}
.about-cols--img-left {grid-template-columns:380px 1fr}

/* ── Image treatment ────────────────────────────────────────────── */
.about-img-wrap{position:relative}
.about-img-wrap::after{content:"";position:absolute;inset:0;border-radius:12px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.07)}
.about-img{width:100%;border-radius:12px;display:block;object-fit:cover;aspect-ratio:4/3}

/* ── Mission section (centered, no columns) ─────────────────────── */
.about-mission-wrap{max-width:780px;margin:0 auto;text-align:center}
.about-mission-wrap .about-section-label,
.about-mission-wrap .about-section-rule{margin-left:auto;margin-right:auto}
.about-mission-wrap .about-section-title{text-align:center}
.about-mission-wrap .about-body{text-align:center}
.about-mission-divider{width:1px;height:28px;background:#e5e7eb;margin:20px auto}

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:900px){
  .about-section{padding:36px 28px}
  .about-cols--img-right,
  .about-cols--img-left{grid-template-columns:1fr;gap:28px}
  /* On mobile, image always goes below text */
  .about-cols--img-left .about-img-wrap{order:1}
  .about-hero-title{font-size:30px}
  .about-hero-sub{text-align:left}
  .about-body{text-align:left;hyphens:none}
}
@media(max-width:560px){
  .about-hero{padding:48px 20px}
  .about-section{padding:28px 18px;border-radius:12px;margin-top:16px}
  .about-wrap{padding:0 14px}
  .about-hero-title{font-size:24px}
  .about-section-title{font-size:21px}
  .about-img{aspect-ratio:3/2}
}

/* ===================================================================
   FAQ PAGE
   =================================================================== */
.faq-page{padding:40px 16px 80px;background:#fff}
.faq-wrap{max-width:1000px;margin:0 auto}

/* ── Accordion ──────────────────────────────────────────────────── */
.faq-accordion{margin-bottom:60px}
.faq-item{border-bottom:1px solid #e5e7eb}
.faq-trigger{width:100%;display:flex;align-items:center;gap:14px;background:none;border:none;cursor:pointer;padding:22px 0;text-align:left}
.faq-icon{flex-shrink:0;width:22px;height:22px;position:relative;color:var(--primary)}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:currentColor;border-radius:2px;transition:transform .25s,opacity .25s}
.faq-icon::before{width:2px;height:16px;top:3px;left:10px}
.faq-icon::after{width:16px;height:2px;top:10px;left:3px}
.faq-item.is-open .faq-icon::before{transform:rotate(90deg);opacity:0}
.faq-question{font-size:18px;font-weight:400;color:var(--primary);line-height:1.3}
.faq-body{display:none;padding:0 0 20px 36px}
.faq-item.is-open .faq-body{display:block}
.faq-answer{font-size:15px;color:#374151;line-height:1.7;border-left:3px solid #f3f4f6;padding-left:16px}

/* ── Mini contact form section ──────────────────────────────────── */
.faq-contact-section{border-top:2px solid #f3f4f6;padding-top:48px}
.faq-contact-inner{display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:start}
.faq-contact-left{font-size:15px;color:#4b5563;line-height:1.7}
.faq-contact-left p{margin:0 0 14px}
.faq-here-link{color:var(--primary);font-weight:600;text-decoration:underline}
.faq-here-link:hover{text-decoration:none}
.faq-mini-form{display:flex;flex-direction:column;gap:14px}
.faq-mini-field{display:flex;flex-direction:column;gap:5px}
.faq-mini-label{font-size:14px;font-weight:600;color:#111827}
.faq-mini-input{border:1px solid #d1d5db;border-radius:4px;padding:10px 12px;font-size:14px;outline:none;transition:border-color .2s}
.faq-mini-input:focus{border-color:var(--primary)}
.faq-mini-textarea{border:1px solid #d1d5db;border-radius:4px;padding:10px 12px;font-size:14px;outline:none;resize:vertical;min-height:150px;transition:border-color .2s}
.faq-mini-textarea:focus{border-color:var(--primary)}
.faq-mini-submit-row{display:flex;justify-content:flex-end}
.faq-mini-submit{background:#fff;border:1px solid var(--primary);color:var(--primary);padding:10px 28px;font-size:14px;font-weight:600;border-radius:4px;cursor:pointer;transition:background .2s,color .2s}
.faq-mini-submit:hover{background:var(--primary);color:#fff}
.faq-shield{display:flex;justify-content:center;margin-top:24px}
.faq-shield svg{width:80px;height:auto;opacity:.9}

@media(max-width:720px){
  .faq-contact-inner{grid-template-columns:1fr}
  .faq-question{font-size:16px}
  .faq-contact-left{font-size:14px}
}

/* ===================================================================
   ABOUT PAGE
   =================================================================== */
.about-page{background:#fff;padding:60px 20px 80px}
.about-wrap{max-width:1200px;margin:0 auto}

/* Intro — centered title + centered paragraph */
.about-intro{text-align:center;max-width:860px;margin:0 auto 40px}
.about-title{font-size:32px;font-weight:800;color:var(--primary);margin:0 0 24px;text-align:center}
.about-intro-text{font-size:15px;color:#374151;line-height:1.8;margin:0;text-align:center}

.about-divider{border:none;border-top:1px solid #e5e7eb;margin:0 0 48px}

/* History — text left ~55%, image right ~40%, vertically centred */
.about-history{display:grid;grid-template-columns:1fr 320px;gap:60px;align-items:center;padding-bottom:48px}
.about-subtitle{font-size:28px;font-weight:700;color:var(--primary);margin:0 0 20px;text-align:center}
.about-history-text{font-size:15px;color:#374151;line-height:1.8;margin:0;text-align:center}
.about-history-img-wrap{display:flex;justify-content:flex-end}
.about-history-img{width:100%;max-width:320px;border-radius:6px;display:block;object-fit:cover}

@media(max-width:860px){
  .about-history{grid-template-columns:1fr;gap:32px}
  .about-history-img-wrap{justify-content:center}
  .about-history-img{max-width:480px}
  .about-title{font-size:26px}
  .about-subtitle{font-size:22px}
}

/* ── Achievements: image left, text right ───────────────────────── */
.about-achieve{display:grid;grid-template-columns:320px 1fr;gap:60px;align-items:center;padding-bottom:48px}
.about-achieve-img-wrap{display:flex;justify-content:flex-start}
.about-achieve-img{width:100%;max-width:320px;border-radius:6px;display:block;object-fit:cover}
.about-achieve-text{font-size:15px;color:#374151;line-height:1.8;margin:0;text-align:center}

/* ── Mission Statement: fully centered ──────────────────────────── */
.about-mission{max-width:860px;margin:0 auto;text-align:center;padding-bottom:0}
.about-mission-text{font-size:15px;color:#374151;line-height:1.8;margin:0 0 20px;text-align:center}
.about-mission-text:last-child{margin-bottom:0}

@media(max-width:860px){
  .about-achieve{grid-template-columns:1fr;gap:32px}
  .about-achieve-img-wrap{justify-content:center}
  .about-achieve-img{max-width:480px}
}

/* ===================================================================
   SERVICES PAGE — Enterprise layout
   =================================================================== */

/* ── Hero banner ────────────────────────────────────────────────── */
.svc-hero{background:linear-gradient(135deg,#000 0%,#ff4b4b 60%,#2a1515 100%);padding:52px 0 44px;text-align:center}
.svc-hero-inner{max-width:680px;margin:0 auto}
.svc-hero-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin:0 0 14px}
.svc-hero-title{font-size:44px;font-weight:800;color:#fff;margin:0 0 16px;line-height:1.1}
.svc-hero-line{width:56px;height:3px;background:var(--primary);margin:0 auto 20px;border-radius:2px}
.svc-hero-sub{font-size:16px;color:rgba(255,255,255,.75);line-height:1.7;margin:0}

/* ── Page shell ─────────────────────────────────────────────────── */
.svc-page{background:#fafafa;padding:0 0 80px}
.svc-wrap{max-width:1100px;margin:0 auto;padding:0 24px}

/* ── Service card ───────────────────────────────────────────────── */
.svc-card{background:#fff;border:1px solid #e9ecef;border-radius:5px;padding:52px 52px;margin-top:28px;box-shadow:0 2px 16px rgba(0,0,0,.05);overflow:hidden}
.svc-card-inner{display:grid;gap:56px;align-items:center}
.svc-card-inner--img-left {grid-template-columns:400px 1fr}
.svc-card-inner--img-right{grid-template-columns:1fr 400px}
/* On img-right, content comes first in DOM so stays left visually */
.svc-card-inner--img-right .svc-content-col{order:1}
.svc-card-inner--img-right .svc-img-col    {order:2}

/* ── Image ──────────────────────────────────────────────────────── */
.svc-img-wrap{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.12)}
.svc-img-wrap::after{content:'';position:absolute;inset:0;border-radius:12px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.07);pointer-events:none}
.svc-img{width:100%;display:block;object-fit:cover;aspect-ratio:4/3}

/* ── Content ────────────────────────────────────────────────────── */
.svc-label{font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--primary);display:block;margin-bottom:8px}
.svc-title{font-size:26px;font-weight:500;color:#111827;margin:0 0 10px;line-height:1.25}
.svc-rule{width:40px;height:3px;background:var(--primary);border-radius:2px;margin-bottom:20px}
.svc-body{font-size:15px;color:#374151;line-height:1.85;margin:0 0 24px;text-align:justify;hyphens:auto}

/* ── Sub-grid (for install/relocation two-column text) ──────────── */
.svc-sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.svc-sub-item{}
.svc-sub-heading{font-size:14px;font-weight:700;color:var(--primary);margin:0 0 8px}
.svc-sub-text{font-size:14px;color:#4b5563;line-height:1.7;margin:0;text-align:justify;hyphens:auto}

/* ── CTA button ─────────────────────────────────────────────────── */
.svc-btn{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;font-size:14px;font-weight:700;padding:12px 24px;border-radius:8px;text-decoration:none;transition:filter .2s,transform .15s;letter-spacing:.02em}
.svc-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.svc-btn svg{flex-shrink:0;transition:transform .2s}
.svc-btn:hover svg{transform:translateX(3px)}

/* ── Divider between cards ──────────────────────────────────────── */
.svc-divider{display:none}

/* ── Bottom CTA strip ───────────────────────────────────────────── */
.svc-cta{background:linear-gradient(135deg,#111827,#1f2937);border-radius:5px;margin-top:28px;padding:40px 52px}
.svc-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.svc-cta-title{font-size:20px;font-weight:800;color:#fff;margin:0 0 6px}
.svc-cta-sub{font-size:14px;color:rgba(255,255,255,.65);margin:0;line-height:1.6}
.svc-cta-btn{flex-shrink:0;display:inline-block;background:var(--primary);color:#fff;font-size:14px;font-weight:700;padding:14px 28px;border-radius:8px;text-decoration:none;transition:filter .2s,transform .15s;white-space:nowrap}
.svc-cta-btn:hover{filter:brightness(1.12);transform:translateY(-1px)}

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:960px){
  .svc-card{padding:36px 28px}
  .svc-card-inner--img-left,
  .svc-card-inner--img-right{grid-template-columns:1fr;gap:28px}
  /* Image always below content on mobile */
  .svc-card-inner--img-left  .svc-img-col{order:2}
  .svc-card-inner--img-left  .svc-content-col{order:1}
  .svc-card-inner--img-right .svc-content-col{order:1}
  .svc-card-inner--img-right .svc-img-col{order:2}
  .svc-sub-grid{grid-template-columns:1fr}
  .svc-body,.svc-sub-text{text-align:left;hyphens:none}
  .svc-hero-title{font-size:30px}
  .svc-cta{padding:28px 24px}
}
@media(max-width:560px){
  .svc-hero{padding:48px 20px}
  .svc-hero-title{font-size:24px}
  .svc-hero-sub{font-size:14px}
  .svc-wrap{padding:0 14px}
  .svc-card{padding:24px 16px;border-radius:12px;margin-top:16px}
  .svc-title{font-size:21px}
  .svc-img{aspect-ratio:16/9}
  .svc-cta-inner{flex-direction:column;align-items:flex-start}
  .svc-cta-btn{width:100%;text-align:center}
}


/* ===================================================================
   HOME PRODUCTS - enterprise card grid
   =================================================================== */
.home-products{padding:56px 16px 88px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)}
.home-products__shell{max-width:var(--max);margin:0 auto}
.home-products__head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:28px}
.home-products__eyebrow{display:inline-block;margin-bottom:10px;font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--primary)}
.home-products__title{margin:0;font-size:42px;line-height:1.05;color:#0f172a;font-weight:900}
.home-products__intro{margin:14px 0 0;max-width:760px;font-size:15px;line-height:1.8;color:#64748b}
.home-products__cta{min-width:160px}
.home-products__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.home-product-card{display:flex;flex-direction:column;min-height:100%;background:#fff;border:1px solid #e6ebf2;border-radius:24px;overflow:hidden;box-shadow:0 18px 45px rgba(15,23,42,.06);transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease}
.home-product-card:hover{transform:translateY(-6px);box-shadow:0 24px 54px rgba(15,23,42,.12);border-color:#d9e2ec}
.home-product-card__media{position:relative;display:flex;align-items:center;justify-content:center;padding:28px;height:280px;background:radial-gradient(circle at top,#ffffff 0%,#f8fafc 58%,#eef2f7 100%);border-bottom:1px solid #edf2f7}
.home-product-card__media img{max-width:100%;max-height:220px;object-fit:contain;display:block;filter:drop-shadow(0 16px 24px rgba(15,23,42,.12))}
.home-product-card__badge{position:absolute;top:18px;left:18px;display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:rgba(184,13,13,.08);color:var(--primary);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.home-product-card__body{display:flex;flex-direction:column;gap:14px;padding:24px 24px 22px;flex:1}
.home-product-card__title{margin:0;font-size:21px;line-height:1.25;font-weight:900;color:#0f172a}
.home-product-card__title a{color:inherit}
.home-product-card__title a:hover{color:var(--primary)}
.home-product-card__text{margin:0;color:#64748b;font-size:14px;line-height:1.75;min-height:74px}
.home-product-card__footer{margin-top:auto;display:flex;align-items:end;justify-content:space-between;gap:16px;padding-top:2px}
.home-product-card__price-wrap{display:flex;flex-direction:column;gap:4px}
.home-product-card__price-label{font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#94a3b8}
.home-product-card__price{font-size:22px;font-weight:900;color:#111827;line-height:1.1}
.home-product-card__btn{padding:11px 18px}
.home-products__empty{background:#fff;border:1px solid #e5e7eb;border-radius:24px;padding:36px;text-align:center;box-shadow:0 18px 45px rgba(15,23,42,.05)}
.home-products__empty h3{margin:0 0 10px;font-size:24px;color:#0f172a}
.home-products__empty p{margin:0 0 18px;color:#64748b;line-height:1.7}

@media(max-width:1100px){
  .home-products__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .home-products__title{font-size:36px}
}
@media(max-width:820px){
  .home-products{padding:44px 14px 72px}
  .home-products__head{flex-direction:column;align-items:flex-start;margin-bottom:22px}
  .home-products__title{font-size:30px}
  .home-products__intro{font-size:14px;max-width:none}
}
@media(max-width:640px){
  .home-products__grid{grid-template-columns:1fr}
  .home-product-card__media{height:240px;padding:22px}
  .home-product-card__media img{max-height:190px}
  .home-product-card__body{padding:20px}
  .home-product-card__title{font-size:19px}
  .home-product-card__text{min-height:auto}
  .home-product-card__footer{flex-direction:column;align-items:flex-start}
  .home-product-card__btn{width:100%}
}

/* ===== Homepage featured products - refined minimal showcase ===== */
.showcase-products{padding:56px 18px 74px;background:#fff !important;}
.showcase-products__shell{max-width:1200px;margin:0 auto}
.showcase-products__head{margin-bottom:26px;text-align:center}
.showcase-products__eyebrow{display:inline-block;margin-bottom:8px;color:#8b9099;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase}
.showcase-products__title{margin:0;color:#12233d;font-size:40px;line-height:1.1;font-weight:900}
.showcase-products__grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:34px 22px;align-items:start}
.showcase-product{text-align:center}
.showcase-product__media{display:flex;align-items:flex-end;justify-content:center;height:220px;padding:8px 10px 14px}
.showcase-product__media img{max-width:100%;max-height:200px;object-fit:contain;display:block;transition:transform .22s ease, filter .22s ease;}
.showcase-product:hover .showcase-product__media img{transform:translateY(-4px);}
.showcase-product__body{display:flex;flex-direction:column;align-items:center;gap:10px}
.showcase-product__title{margin:0;min-height:16px;font-size:17px;line-height:1.25;font-weight:700}
.showcase-product__title a{color:#c21111}
.showcase-product__title a:hover{color:#a10e0e}
.showcase-product__price{font-size:14px;line-height:1.2;font-weight:500;color:#000}
.showcase-product__btn{display:inline-flex;align-items:center;justify-content:center;min-width:110px;height:42px;padding:0 20px;border-radius:4px;background:#c91010;border:1px solid #c91010;color:#fff;font-size:15px;font-weight:800;transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease;box-shadow:0 10px 20px rgba(201,16,16,.14)}
.showcase-product__btn:hover{background:#a90d0d;border-color:#a90d0d;transform:translateY(-1px);box-shadow:0 14px 26px rgba(169,13,13,.22)}

@media (max-width:1180px){
  .showcase-products__grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (max-width:960px){
  .showcase-products{padding:48px 16px 64px}
  .showcase-products__title{font-size:34px}
  .showcase-products__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:30px 18px}
}
@media (max-width:680px){
  .showcase-products__title{font-size:28px}
  .showcase-products__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px 14px}
  .showcase-product__media{height:180px}
  .showcase-product__media img{max-height:165px}
  .showcase-product__title{font-size:15px;min-height:40px}
  .showcase-product__btn{min-width:102px;height:40px;font-size:14px}
}
@media (max-width:420px){
  .showcase-products{padding:42px 14px 56px}
  .showcase-products__grid{grid-template-columns:1fr}
  .showcase-product__media{height:210px}
  .showcase-product__media img{max-height:190px}
}


/* Homepage products section refinements */
.showcase-products{background:#fff;padding:64px 0 78px;}
.showcase-products__head{margin-bottom:34px;text-align:center;}
.showcase-products__title{margin:0;color:#0f2a44;font-size:35px;font-weight:500;line-height:1.2;letter-spacing:0;}
.showcase-products__eyebrow{display:none !important;}


/* === Shop page === */
.shop-hero{background:linear-gradient(135deg,#000 0%,#ff4b4b 60%,#2a1515 100%);padding:52px 0 44px;position:relative;overflow:hidden}.shop-hero::before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.shop-hero-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;position:relative;z-index:1}.shop-hero-eyebrow{display:block;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:8px}.shop-hero-title{font-size:clamp(28px,4vw,46px);font-weight:900;color:#fff;margin:0 0 10px;letter-spacing:-.02em;line-height:1.05}.shop-hero-sub{color:rgba(255,255,255,.55);font-size:14px;margin:0;max-width:340px;line-height:1.6}.shop-hero-text{flex:1}.shop-search-form{flex:0 0 360px;max-width:100%}.shop-search-box{display:flex;align-items:center;gap:10px;background:rgba0 0 0 / 40%);border:1px solid rgba(255 255 255 / 40%);border-radius:12px;padding:6px 6px 6px 14px;backdrop-filter:blur(8px)}.shop-search-box svg{color:rgba(255,255,255,.4);flex-shrink:0}.shop-search-input{flex:1;background:none!important;border:none!important;outline:none;color:#f5f5f5;font-size:14px;font-family:inherit}.shop-search-input::placeholder{color:rgba(255,255,255,.35)}.shop-search-btn{background:#b80d0d;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;font-family:inherit;transition:filter .15s}.shop-search-btn:hover{filter:brightness(1.1)}.shop-wrap{max-width:1200px;margin:0 auto;padding:32px 24px 48px;display:grid;grid-template-columns:260px 1fr;gap:32px;align-items:start}.shop-sidebar{position:sticky;top:72px}.sidebar-toggle{display:none;width:100%;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px 14px;font-size:14px;font-weight:600;color:#374151;cursor:pointer;align-items:center;gap:8px;text-align:left;font-family:inherit}.sidebar-toggle svg:last-child{margin-left:auto;transition:transform .2s}.sidebar-toggle.is-open svg:last-child{transform:rotate(180deg)}.sidebar-nav{background:#fff;border:1px solid #e5e7eb;border-radius:5px;padding:8px 0;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.04)}.sidebar-section-label{font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#9ca3af;padding:10px 16px 6px}.sidebar-cat-link{display:flex;align-items:center;gap:6px;padding:9px 16px;text-decoration:none;color:#374151;font-size:13.5px;transition:background .12s,color .12s;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit}.sidebar-cat-link:hover{background:#fafafa;color:#b80d0d}.sidebar-cat-link.is-active{color:#b80d0d;background:#fff0f0;font-weight:700}.sidebar-cat-name{flex:1}.sidebar-cat-count{font-size:11px;font-weight:400;color:#9ca3af;border-radius:20px;padding:1px 7px;min-width:22px;text-align:center}.sidebar-cat-link.is-active .sidebar-cat-count,.sidebar-child-link.is-active .sidebar-cat-count{background:#ffe0e0;color:#b80d0d}.sidebar-chevron{color:#d1d5db;flex-shrink:0;margin-left:2px;transition:transform .2s}.sidebar-chevron.is-open{transform:rotate(180deg)}.sidebar-children{display:none;padding-left:0;border-top:1px solid #f3f4f6}.sidebar-children.is-open{display:block}.sidebar-child-link{display:flex;align-items:center;gap:8px;padding:8px 16px 8px 28px;text-decoration:none;color:#6b7280;font-size:13px;transition:color .12s,background .12s;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit}.sidebar-child-link:hover{color:#b80d0d;background:#fafafa}.sidebar-child-link.is-active{color:#b80d0d;font-weight:600;background:#fff8f8}.sidebar-child-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.5}.sidebar-cta{margin-top:16px;background: #f5f5f5;border-radius:5px;padding:20px;color:#fff;text-align:center}.sidebar-cta-icon{width:48px;height:48px;background:rgba(184,13,13,.25);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;color:#b80d0d}.sidebar-cta-text{font-size:13px;color:rgba(0 0 0 / 70%);margin:0 0 14px;line-height:1.5}.sidebar-cta-btn{display:block;background:#b80d0d;color:#fff;text-decoration:none;font-size:12px;font-weight:700;padding:9px 14px;border-radius:8px;transition:filter .15s}.sidebar-cta-btn:hover{filter:brightness(1.1)}.shop-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.shop-toolbar-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1}.shop-toolbar-right{display:flex;align-items:center;gap:8px}.shop-result-count{font-size:13px;color:#6b7280}.shop-filter-tag{display:inline-flex;align-items:center;gap:5px;background:#fff0f0;border:1px solid #fecaca;color:#b80d0d;font-size:12px;font-weight:600;padding:3px 8px;border-radius:6px}.shop-filter-remove{color:#b80d0d;text-decoration:none;line-height:1;font-size:11px}.shop-sort-label{font-size:13px;color:#6b7280;white-space:nowrap}.shop-sort-select{border:1px solid #e5e7eb;border-radius:8px;padding:7px 10px;font-size:13px;font-family:inherit;background:#fff;color:#374151;cursor:pointer;outline:none}.shop-sort-select:focus{border-color:#b80d0d}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.shop-card{background:#fff;border:1px solid #e5e7eb;border-radius:5px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column}.shop-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.1);border-color:#d1d5db}.shop-card-img-wrap{position:relative;height:200px;display:flex;align-items:center;justify-content:center;background:#fff;overflow:hidden}.shop-card-img{max-height:180px;max-width:90%;object-fit:contain;transition:transform .3s}.shop-card:hover .shop-card-img{transform:scale(1.05)}.shop-card-badge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.shop-card-badge--sale{background:#b80d0d;color:#fff}.shop-card-badge--oos{background:#6b7280;color:#fff}.shop-card-overlay{position:absolute;inset:0;background:rgba(255 84 84 / 40%);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s}.shop-card:hover .shop-card-overlay{opacity:1}.shop-card-cta{color:#fff;font-size:14px;font-weight:700;background:rgba(184,13,13,.9);padding:10px 20px;border-radius:8px;transform:translateY(8px);transition:transform .25s}.shop-card:hover .shop-card-cta{transform:translateY(0)}.shop-card-body{padding:16px;display:flex;flex-direction:column;flex:1}.shop-card-title{font-size:14px;font-weight:700;color:#111827;margin:0 0 6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.shop-card-desc{font-size:12px;color:#6b7280;margin:0 0 10px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.shop-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto}.shop-card-price{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.shop-card-price-regular{font-size:15px;font-weight:800;color:#111827}.shop-card-price-sale{font-size:15px;font-weight:800;color:#b80d0d}.shop-card-price-was{font-size:12px;color:#9ca3af;text-decoration:line-through}.shop-card-price-call{font-size:13px;color:#6b7280;font-weight:600}.shop-card-arrow{width:32px;height:32px;border-radius:50%;background:#f3f4f6;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#9ca3af;transition:background .2s,color .2s}.shop-card:hover .shop-card-arrow{background:#b80d0d;color:#fff}.shop-pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:32px}.shop-page-btn{min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;font-family:inherit}.shop-page-btn:hover{border-color:#b80d0d;color:#b80d0d}.shop-page-btn.is-active{background:#b80d0d;color:#fff;border-color:#b80d0d}.shop-page-ellipsis{font-size:14px;color:#9ca3af;padding:0 4px}.shop-empty{text-align:center;padding:60px 20px}.shop-empty h3{font-size:18px;color:#374151;margin:16px 0 8px}.shop-empty p{font-size:14px;color:#6b7280;margin:0 0 20px}.shop-trust{background:#f8f9fb;border-top:1px solid #e5e7eb;padding:40px 24px}.shop-trust-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.shop-trust-item{display:flex;align-items:center;gap:14px}.shop-trust-item strong{display:block;font-size:14px;color:#111827;font-weight:700}.shop-trust-item span{display:block;font-size:12px;color:#6b7280;margin-top:2px}@media(max-width:960px){.shop-wrap{grid-template-columns:1fr;gap:0}.sidebar-toggle{display:flex}.sidebar-nav{display:none;margin-top:8px}.sidebar-nav.is-open{display:block}.sidebar-cta{display:none}.shop-trust-inner{grid-template-columns:repeat(2,1fr)}}@media(max-width:580px){.shop-hero-inner{flex-direction:column}.shop-search-form{flex:0 0 auto;width:100%}.shop-trust-inner{grid-template-columns:1fr}}


/* ====================================================================
   UNIFIED INTERIOR HERO + PAGE POLISH (FAQ / CONTACT / ABOUT)
   ==================================================================== */
.faq-hero,.contact-hero,.about-hero{
  background:linear-gradient(135deg,#000 0%,#ff4b4b 60%,#2a1515 100%);
  padding:52px 0 44px;
  text-align:center;
}
.faq-hero-inner,.contact-hero-inner,.about-hero-inner{max-width:680px;margin:0 auto;padding:0 20px}
.faq-hero-label,.contact-hero-label,.about-hero-label{
  display:inline-block;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin:0 0 14px
}
.faq-hero-title,.contact-hero-title,.about-hero-title{font-size:44px;font-weight:800;color:#fff;margin:0 0 16px;line-height:1.1}
.faq-hero-line,.contact-hero-line,.about-hero-line{width:56px;height:3px;background:var(--primary);margin:0 auto 20px;border-radius:2px}
.faq-hero-sub,.contact-hero-sub,.about-hero-sub{font-size:16px;color:rgba(255,255,255,.75);line-height:1.7;margin:0;text-align:center;hyphens:none}

.contact-page,.faq-page{background:#f8fafc;padding:40px 16px 80px}
.contact-wrap,.faq-wrap{max-width:1200px;margin:0 auto}
.contact-shell,.faq-shell{background:#fff;border:1px solid #eceff3;border-radius:28px;box-shadow:0 22px 60px rgba(15,23,42,.06);padding:32px}
.contact-heading,.faq-heading{font-size:32px;line-height:1.15;font-weight:500;color:#111827;margin:0 0 10px}
.contact-intro,.faq-intro{font-size:15px;line-height:1.75;color:#6b7280;margin:0 0 28px;max-width:760px}

.contact-form{display:flex;flex-direction:column;gap:18px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cf-field{display:flex;flex-direction:column;gap:8px}
.cf-field--full{grid-column:1/-1}
.cf-field--half{max-width:520px}
.cf-label{font-size:13px;font-weight:600;color:#111827;letter-spacing:0}
.cf-input,.cf-textarea,.cf-select,.faq-mini-input,.faq-mini-textarea{
  width:100%;height:38px;border:1px solid #b8c0cc;border-radius:3px;padding:8px 12px;font-size:14px;outline:none;background:#fff;color:#111827;
  transition:border-color .18s, box-shadow .18s, background .18s;box-shadow:none;
}
.cf-textarea{min-height:150px;height:150px;resize:vertical;padding-top:10px}
.cf-input:focus,.cf-textarea:focus,.cf-select:focus,.faq-mini-input:focus,.faq-mini-textarea:focus{
  border-color:#9aa6b2; box-shadow:none; background:#fff;
}
.cf-select{padding-right:42px;appearance:none}
.cf-select-wrap{position:relative;max-width:520px}
.cf-select-ico{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:#6b7280;font-size:11px}
.cf-checkgroup{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding-top:2px}
.cf-checkgroup--plain{display:flex;flex-direction:column;gap:10px}
.cf-check-label{display:flex;align-items:flex-start;gap:10px;font-size:14px;cursor:pointer;color:#111827}
.cf-check-label--plain{padding:0;border:0;background:transparent;border-radius:0;transition:none}
.cf-check-label--plain:hover{background:transparent;border-color:transparent}
.cf-check-label input[type=checkbox]{width:17px;height:17px;accent-color:var(--primary);flex-shrink:0;cursor:pointer;margin-top:1px}
.cf-submit,.faq-mini-submit{
  display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 28px;background:#cf0000;color:#fff;border:none;border-radius:3px;
  font-size:18px;font-weight:700;cursor:pointer;letter-spacing:0;transition:filter .18s;background-image:none;box-shadow:none
}
.cf-submit:hover,.faq-mini-submit:hover{filter:brightness(1.03);transform:none}
.cf-submit{width:100%}

.faq-shell{padding:0;overflow:hidden}
.faq-head{padding:32px 32px 0}
.faq-accordion{margin:0;padding:0 32px 40px}
.faq-item{border:1px solid #edf0f4;border-radius:18px;background:#fff;box-shadow:0 8px 24px rgba(15,23,42,.03);margin-bottom:14px;overflow:hidden}
.faq-trigger{width:100%;display:flex;align-items:center;gap:14px;background:none;border:none;cursor:pointer;padding:22px 24px;text-align:left}
.faq-icon{flex-shrink:0;width:24px;height:24px;position:relative;color:var(--primary);background:#fff2f2;border-radius:999px}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:currentColor;border-radius:2px;transition:transform .25s,opacity .25s}
.faq-icon::before{width:2px;height:12px;top:6px;left:11px}.faq-icon::after{width:12px;height:2px;top:11px;left:6px}
.faq-item.is-open .faq-icon::before{transform:rotate(90deg);opacity:0}
.faq-question{font-size:18px;font-weight:700;color:#111827;line-height:1.35}
.faq-body{display:none;padding:0 24px 24px 62px}.faq-item.is-open .faq-body{display:block}
.faq-answer{font-size:15px;color:#475569;line-height:1.8;border-left:3px solid #fee2e2;padding-left:16px}
.faq-contact-section{border-top:1px solid #edf0f4;background:linear-gradient(180deg,#fff,#fffaf9);padding:32px}
.faq-contact-inner{display:grid;grid-template-columns:340px 1fr;gap:28px;align-items:start}
.faq-contact-left{font-size:15px;color:#475569;line-height:1.8}
.faq-contact-left p{margin:0 0 16px}
.faq-here-link{color:var(--primary);font-weight:700;text-decoration:none}
.faq-mini-form{display:flex;flex-direction:column;gap:14px}
.faq-mini-label{font-size:13px;font-weight:700;color:#334155}
.faq-mini-textarea{min-height:160px;resize:vertical}
.faq-mini-submit-row{display:flex;justify-content:flex-end;padding-top:4px}
.faq-shield{display:flex;justify-content:center;margin-top:24px}.faq-shield svg{width:80px;height:auto;opacity:.92}

@media (max-width: 900px){
  .cf-row,.faq-contact-inner{grid-template-columns:1fr}
  .cf-checkgroup{grid-template-columns:1fr}
  .cf-field--half{max-width:100%}
}
@media (max-width: 768px){
  .faq-hero,.contact-hero,.about-hero{padding:48px 20px}
  .faq-hero-title,.contact-hero-title,.about-hero-title{font-size:24px}
  .faq-hero-sub,.contact-hero-sub,.about-hero-sub{font-size:14px}
  .contact-shell,.faq-shell{padding:22px;border-radius:22px}
  .faq-shell{padding:0}
  .faq-head{padding:24px 20px 0}
  .faq-accordion{padding:0 20px 28px}
  .faq-contact-section{padding:24px 20px}
  .faq-trigger{padding:18px 18px}
  .faq-body{padding:0 18px 20px 50px}
  .contact-heading,.faq-heading{font-size:26px}
}


/* ===== Home: Why Choose Salvado ===== */
.why-salvado-home{padding:48px 18px 72px;background:#fff}
.why-salvado-home__shell{max-width:1200px;margin:0 auto}
.why-salvado-home__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(520px,550px);gap:56px;align-items:center}
.why-salvado-home__content{text-align:center;padding:0 28px}
.why-salvado-home__title{margin:0 0 18px;color:var(--primary);font-size:25px;line-height:1.2;font-weight:800}
.why-salvado-home__text{margin:0 auto 30px;max-width:580px;color:#243041;font-size:18px;line-height:1.55}
.why-salvado-home__btn{display:inline-flex;align-items:center;justify-content:center;min-width:128px;padding:13px 28px;border-radius:999px;background:var(--primary);color:#fff;text-decoration:none;font-weight:700;font-size:16px;box-shadow:0 10px 24px rgba(210,0,0,.18);transition:transform .2s ease, filter .2s ease}
.why-salvado-home__btn:hover{filter:brightness(.95);transform:translateY(-1px)}
.why-salvado-home__media img{display:block;width:100%;height:auto;border-radius:0;box-shadow:0 10px 24px rgba(0,0,0,.14)}
@media(max-width:980px){.why-salvado-home__grid{grid-template-columns:1fr;gap:32px}.why-salvado-home__content{padding:0}.why-salvado-home__text{font-size:17px;max-width:720px}.why-salvado-home__media{max-width:720px;margin:0 auto}}
@media(max-width:640px){.why-salvado-home{padding:34px 16px 54px}.why-salvado-home__title{font-size:22px}.why-salvado-home__text{font-size:16px}}

/* Home services carousel */
.home-services-carousel{padding:26px 16px 54px;background:#fff}
.home-services-carousel__shell{position:relative;max-width:1120px;margin:0 auto;background:#ececec;padding:0px 56px}
.home-services-carousel__track{position:relative}
.home-service-slide{display:none}
.home-service-slide.is-active{display:block}
.home-service-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,1fr);align-items:center;gap:26px}
.home-service-image{display:flex;align-items:center;justify-content:center}
.home-service-image img{display:block;width:100%;max-width:430px;height:260px;object-fit:cover}
.home-service-content{text-align:center;padding:0 18px}
.home-service-content h3{margin:0 0 16px;color:var(--primary);font-size:27px;line-height:1.15;font-weight:800}
.home-service-content p{margin:0 auto 24px;max-width:470px;color:#1d1d1d;font-size:17px;line-height:1.35}
.home-service-content .btn{display:inline-flex;align-items:center;justify-content:center;min-width:108px;padding:10px 22px;border-radius:999px;background:var(--primary);color:#fff;text-decoration:none;font-weight:700;font-size:15px;line-height:1}
.home-services-carousel__nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border:0;background:#8a8a8a;color:#fff;font-size:34px;line-height:40px;text-align:center;cursor:pointer;z-index:2;padding:0}
.home-services-carousel__nav--prev{left:12px}
.home-services-carousel__nav--next{right:12px}
.home-services-carousel__nav:hover{background:#000}
@media (max-width: 980px){
  .home-services-carousel__shell{padding:16px 18px 22px}
  .home-service-grid{grid-template-columns:1fr;gap:20px}
  .home-service-image img{max-width:100%;height:auto}
  .home-service-content{padding:0 8px 6px}
  .home-service-content h3{font-size:24px}
  .home-service-content p{font-size:16px;max-width:620px}
}
@media (max-width: 640px){
  .home-services-carousel{padding:18px 10px 38px}
  .home-services-carousel__shell{padding:12px 12px 18px}
  .home-services-carousel__nav{width:34px;height:34px;font-size:28px;line-height:34px}
  .home-services-carousel__nav--prev{left:8px}
  .home-services-carousel__nav--next{right:8px}
  .home-service-content h3{font-size:21px}
  .home-service-content p{font-size:15px}
  .home-service-content .btn{padding:9px 18px;font-size:14px}
}


/* ===== Home Safe Categories ===== */
.home-safe-categories{padding:38px 18px 54px;background:#fff}
.home-safe-categories__shell{max-width:1200px;margin:0 auto}
.home-safe-categories__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}
.home-safe-category-card{background:#fff;border:1px solid #ececec;border-radius:5px;overflow:hidden;box-shadow:0 10px 24px rgba(15,23,42,.06);display:flex;flex-direction:column;height:100%;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.home-safe-category-card:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(15,23,42,.1);border-color:#e1e1e1}
.home-safe-category-card__media{display:block;aspect-ratio:1/1;background:#f5f5f5;overflow:hidden}
.home-safe-category-card__media img{width:100%;height:100%;display:block;object-fit:cover}
.home-safe-category-card__body{padding:18px 18px 22px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;flex:1}
.home-safe-category-card__title{margin:0;min-height:62px;display:flex;align-items:center;justify-content:center}
.home-safe-category-card__title a{text-decoration:none;color:#b80d0d;font-size:18px;line-height:1.15;font-weight:800}
.home-safe-category-card__btn{display:inline-flex;align-items:center;justify-content:center;min-width:122px;min-height:42px;padding:10px 22px;border-radius:4px;background:#c51616;color:#fff;text-decoration:none;font-size:14px;font-weight:800;transition:filter .15s ease,transform .15s ease}
.home-safe-category-card__btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
@media (max-width:1100px){
  .home-safe-categories__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:640px){
  .home-safe-categories{padding:30px 14px 44px}
  .home-safe-categories__grid{grid-template-columns:1fr;gap:18px}
  .home-safe-category-card__title{min-height:auto}
}


.home-google-reviews{padding:18px 0 48px;background:#f7f7f7}
.home-google-reviews__shell{max-width:var(--max);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:240px minmax(0,1fr);gap:28px;align-items:center}
.home-google-reviews__summary{padding:10px 4px}
.home-google-reviews__eyebrow{font-size:22px;line-height:1.1;font-weight:900;color:#121212;margin-bottom:10px}
.home-google-reviews__stars{font-size:34px;line-height:1;color:#efb300;letter-spacing:2px;margin-bottom:12px}
.home-google-reviews__based{font-size:16px;color:#111827;margin-bottom:14px}
.home-google-reviews__google{display:inline-block;font-size:26px;font-weight:700;letter-spacing:-1px;text-decoration:none;line-height:1}
.home-google-reviews__google .g-blue{color:#4285F4}.home-google-reviews__google .g-red{color:#DB4437}.home-google-reviews__google .g-yellow{color:#F4B400}.home-google-reviews__google .g-green{color:#0F9D58}
.home-google-reviews__slider{position:relative;display:flex;align-items:center;gap:14px;min-width:0}
.home-google-reviews__viewport{overflow:hidden;min-width:0;flex:1}
.home-google-reviews__track{display:flex;gap:18px;transition:transform .28s ease;will-change:transform}
.home-google-review-card{flex:0 0 calc((100% - 36px) / 3);background:#fff;border:1px solid #dadada;border-radius:14px;padding:18px 18px 20px;min-height:205px;box-shadow:0 10px 22px rgba(15,23,42,.05)}
.home-google-review-card__top{display:flex;align-items:flex-start;gap:14px;margin-bottom:12px}
.home-google-review-card__avatar{width:42px;height:42px;border-radius:999px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:23px;font-weight:700;flex-shrink:0}
.home-google-review-card__avatar--slate{background:#546878}.home-google-review-card__avatar--indigo{background:#5b6ccf}.home-google-review-card__avatar--rose{background:#d35d7b}.home-google-review-card__avatar--emerald{background:#0f9d58}.home-google-review-card__avatar--amber{background:#d97706}
.home-google-review-card__meta{min-width:0;flex:1}
.home-google-review-card__meta h3{margin:0;font-size:15px;line-height:1.2;font-weight:800;color:#111827}
.home-google-review-card__meta p{margin:3px 0 0;font-size:14px;color:#8a8a8a}
.home-google-review-card__badge{width:24px;height:24px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0;background:#fff;color:#4285F4;border:1px solid #ececec}
.home-google-review-card__stars{font-size:18px;color:#efb300;letter-spacing:1px;margin-bottom:12px}
.home-google-review-card__verified{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:999px;background:#3b82f6;color:#fff;font-size:11px;font-weight:800;vertical-align:middle;margin-left:6px}
.home-google-review-card__text{margin:0;font-size:15px;line-height:1.45;color:#111827;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.home-google-reviews__nav{width:38px;height:38px;border-radius:999px;border:1px solid #d7d7d7;background:#fff;color:#6b7280;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px 18px rgba(15,23,42,.08);transition:transform .15s ease,background .15s ease,color .15s ease;flex-shrink:0}
.home-google-reviews__nav:hover{transform:translateY(-1px);background:#fafafa;color:#111827}
.home-google-reviews__nav:disabled{opacity:.45;cursor:default;transform:none}
@media(max-width:1099px){.home-google-reviews__shell{grid-template-columns:1fr;gap:20px}.home-google-review-card{flex-basis:calc((100% - 18px) / 2)}}
@media(max-width:699px){.home-google-reviews{padding:10px 0 38px}.home-google-reviews__shell{padding:0 16px}.home-google-reviews__eyebrow{font-size:20px}.home-google-reviews__stars{font-size:30px}.home-google-review-card{flex-basis:100%;min-height:185px}.home-google-reviews__slider{gap:10px}.home-google-reviews__nav{width:34px;height:34px;font-size:20px}}


/* ===== Salvadm Login Refresh ===== */
.admin-login-body{min-height:100vh;margin:0;background:radial-gradient(circle at top left,#f3f4f6 0,#e9edf5 38%,#dfe5ee 100%)}
.admin-login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(320px,1.05fr) minmax(420px,.95fr)}
.admin-login-hero{position:relative;overflow:hidden;background:linear-gradient(145deg,#091224 0%,#101c34 45%,#17284a 100%);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:center;align-items:center}
.admin-login-hero:before{content:"";position:absolute;inset:auto -10% -20% auto;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.05);filter:blur(4px)}
.admin-login-hero:after{content:"";position:absolute;inset:8% auto auto -80px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.04)}
.admin-login-brand,.admin-brand{font-weight:900;letter-spacing:-.03em}
.admin-login-hero--brand{justify-content:center;align-items:center;padding:48px}
.admin-login-brand-wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:min(100%,720px);text-align:center}
.admin-login-logo{display:block;max-width:min(100%,620px);width:100%;height:auto;filter:drop-shadow(0 24px 36px rgba(15,23,42,.22))}
.admin-login-brand-caption{margin-top:18px;font-size:14px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.admin-login-panel{display:flex;align-items:center;justify-content:center;padding:48px 30px}
.auth-card--elevated{width:min(100%,460px);margin:0;background:rgba(255,255,255,.94);border:1px solid rgba(255,255,255,.7);box-shadow:0 30px 80px rgba(15,23,42,.16);border-radius:28px;padding:34px 32px}
.auth-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:#fff1f2;color:var(--primary);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px}
.auth-card--elevated h1{margin:0 0 10px;font-size:40px;line-height:1.05;color:#0f172a}
.auth-subtitle{margin:0 0 22px;color:#64748b;font-size:15px;line-height:1.7}
.auth-form{gap:16px}.auth-field{display:grid;gap:8px}
.auth-card--elevated .form input[type=text],.auth-card--elevated .form input[type=password]{height:54px;border-radius:16px;padding:0 16px;background:#fff;border:1px solid #dbe2ea;box-shadow:inset 0 1px 2px rgba(15,23,42,.03)}
.auth-card--elevated .form input[type=text]:focus,.auth-card--elevated .form input[type=password]:focus{border-color:#94a3b8;box-shadow:0 0 0 4px rgba(148,163,184,.16)}
.auth-submit{width:100%;min-height:54px;border-radius:16px;font-weight:800;font-size:15px;box-shadow:0 16px 28px rgba(184,13,13,.18)}
.admin-brand{font-size:28px;margin-bottom:22px}
.admin-sidebar{background:linear-gradient(180deg, #ffffff 0%, #cee1ff 100%);padding:24px 18px}
.admin-topbar{padding:16px 18px}
.admin-title{font-size:20px;font-weight:900;color:#0f172a}

.admin-shell{transition:grid-template-columns .25s ease}
.admin-topbar-left{display:flex;align-items:center;gap:12px}
.admin-sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;border:1px solid #dbe2ea;background:#fff;color:#0f172a;font-size:20px;line-height:1;cursor:pointer;box-shadow:0 10px 24px rgba(15,23,42,.08);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}
.admin-sidebar-toggle:hover{transform:translateY(-1px);box-shadow:0 16px 30px rgba(15,23,42,.12);background:#f8fafc}
.admin-nav{flex:1;overflow:auto;padding-right:4px}
.admin-logout .btn{width:100%;display:inline-flex;justify-content:center;align-items:center;min-height:46px;border-radius:14px;font-weight:800;font-size:14px}
.admin-logout .btn.btn-ghost{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);border:1px solid rgba(255,255,255,.12);color:#fff;box-shadow:0 14px 28px rgba(220,38,38,.26)}
.admin-logout .btn.btn-ghost:hover{background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);color:#fff;transform:translateY(-1px)}
@media (min-width: 721px){
  body.admin-body.admin-sidebar-collapsed .admin-shell{grid-template-columns:96px 1fr}
  body.admin-body.admin-sidebar-collapsed .admin-brand{font-size:18px;line-height:1.15}
  body.admin-body.admin-sidebar-collapsed .admin-sidebar{padding-left:12px;padding-right:12px}
  body.admin-body.admin-sidebar-collapsed .admin-nav a{font-size:0;padding-left:0;padding-right:0;justify-content:center;display:flex;align-items:center;min-height:42px}
  body.admin-body.admin-sidebar-collapsed .admin-nav a::before{content:'•';font-size:24px;line-height:1;color:#e5e7eb}
  body.admin-body.admin-sidebar-collapsed .admin-nav a.active::before{color:#fff}
  body.admin-body.admin-sidebar-collapsed .admin-logout .btn{font-size:0;padding-left:0;padding-right:0}
  body.admin-body.admin-sidebar-collapsed .admin-logout .btn::before{content:'↩';font-size:20px;line-height:1}
}
@media (max-width: 1100px){.admin-login-shell{grid-template-columns:1fr}.admin-login-hero{padding:34px 26px;min-height:auto}.admin-login-hero--brand{min-height:38vh}.admin-login-logo{max-width:min(100%,420px)}.admin-login-panel{padding:24px 16px 36px}.auth-card--elevated{width:min(100%,560px)}}
@media (max-width: 640px){.admin-login-hero--brand{padding:26px 18px;min-height:30vh}.admin-login-logo{max-width:min(100%,300px)}.admin-login-brand-caption{font-size:11px}.auth-card--elevated{padding:24px 20px;border-radius:22px}.auth-card--elevated h1{font-size:31px}}


/* Salvado admin login refresh */
.admin-login-body{min-height:100vh;margin:0;background:linear-gradient(135deg,#edf2f7 0%,#e4eaf2 42%,#d9e1eb 100%)}
.admin-login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(360px,1.08fr) minmax(460px,.92fr)}
.admin-login-hero{position:relative;overflow:hidden;background:linear-gradient(150deg, #0a1630 0%, #95a3be 52%, #183661 100%);color:#fff;padding:64px;display:flex;flex-direction:column;justify-content:center;align-items:center}
.admin-login-hero:before{content:"";position:absolute;inset:-10% auto auto -8%;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.05);filter:blur(2px)}
.admin-login-hero:after{content:"";position:absolute;inset:auto -8% -14% auto;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.06);filter:blur(4px)}
.admin-login-hero--brand{padding:56px}
.admin-login-brand-wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;width:min(100%,620px)}
.admin-login-badge{display:inline-flex;align-items:center;min-height:38px;padding:0 16px;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.88);margin-bottom:22px}
.admin-login-logo--salvado{width:min(100%,250px);max-width:250px;height:auto;filter:drop-shadow(0 18px 32px rgba(8,15,32,.25)) brightness(1.08)}
.admin-login-feature-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:30px;width:min(100%,420px)}
.admin-login-feature-card{display:flex;align-items:center;gap:12px;padding:16px 18px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.07);backdrop-filter:blur(10px);box-shadow:0 16px 40px rgba(8,15,32,.14);font-size:15px;font-weight:600;color:rgba(255,255,255,.92)}
.admin-login-feature-dot{width:10px;height:10px;border-radius:50%;background:#7dd3fc;box-shadow:0 0 0 6px rgba(125,211,252,.14)}
.admin-login-panel{display:flex;align-items:center;justify-content:center;padding:48px 34px}
.auth-card--elevated{width:min(100%,470px);margin:0;background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.72);box-shadow:0 28px 72px rgba(15,23,42,.14);border-radius:30px;padding:34px 32px}
.auth-card-top{display:flex;align-items:center;gap:14px;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid #e8edf3}
.auth-card-logo{width:42px;height:42px;object-fit:contain;border-radius:12px;background:#fff;padding:6px;box-shadow:0 10px 20px rgba(15,23,42,.08)}
.auth-card-meta{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.auth-card-kicker{font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#5b6b82}
.auth-card-line{height:1px;flex:1;background:linear-gradient(90deg,#d8e0ea 0%,rgba(216,224,234,0) 100%)}
.auth-eyebrow,.auth-card--elevated h1,.auth-subtitle{display:none!important}
.auth-form{gap:18px}
.auth-field{display:grid;gap:8px}
.auth-field label{font-size:13px;font-weight:800;letter-spacing:.01em;color:#0f172a}
.auth-card--elevated .form input[type=text],.auth-card--elevated .form input[type=password]{height:56px;border-radius:16px;padding:0 16px;background:#fff;border:1px solid #d8e1eb;box-shadow:inset 0 1px 2px rgba(15,23,42,.03);font-size:15px;color:#0f172a}
.auth-card--elevated .form input[type=text]::placeholder,.auth-card--elevated .form input[type=password]::placeholder{color:#8a97a8}
.auth-card--elevated .form input[type=text]:focus,.auth-card--elevated .form input[type=password]:focus{border-color:#94a3b8;box-shadow:0 0 0 4px rgba(148,163,184,.14)}
.auth-password-wrap{position:relative}
.auth-password-wrap input{padding-right:82px!important;width:100%}
.auth-password-toggle{position:absolute;top:50%;right:10px;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;min-width:62px;height:38px;padding:0 12px;border:1px solid #d9e2ec;border-radius:12px;background:#f8fafc;color:#334155;font-size:12px;font-weight:800;cursor:pointer;transition:all .2s ease}
.auth-password-toggle:hover{background:#eef2f7;border-color:#cdd8e4}
.auth-submit{width:100%;min-height:56px;border-radius:16px;font-weight:900;font-size:15px;letter-spacing:.01em;box-shadow:0 18px 30px rgba(184,13,13,.18);background:linear-gradient(135deg,#cf1313 0%,#b80d0d 100%)}
.auth-submit:hover{filter:none;transform:translateY(-1px);background:linear-gradient(135deg,#e01717 0%,#be1010 100%)}
@media (max-width: 1100px){.admin-login-shell{grid-template-columns:1fr}.admin-login-hero{padding:36px 24px;min-height:auto}.admin-login-hero--brand{min-height:38vh}.admin-login-brand-wrap{align-items:center;text-align:center}.admin-login-feature-grid{width:min(100%,520px)}.admin-login-panel{padding:28px 16px 38px}.auth-card--elevated{width:min(100%,560px)}}
@media (max-width: 640px){.admin-login-hero--brand{padding:24px 18px;min-height:28vh}.admin-login-logo--salvado{max-width:180px}.admin-login-feature-grid{gap:10px}.admin-login-feature-card{padding:14px 14px;font-size:14px;border-radius:16px}.auth-card--elevated{padding:24px 20px;border-radius:24px}.auth-card-top{gap:12px;margin-bottom:16px;padding-bottom:14px}}


/* Categories admin refresh */
.category-admin-shell{padding:22px}
.category-admin-grid{display:grid;grid-template-columns:minmax(340px,420px) minmax(0,1fr);gap:22px;align-items:start}
.category-form-card,.category-list-card{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);border:1px solid #e6edf5;border-radius:24px;box-shadow:0 18px 45px rgba(15,23,42,.06)}
.category-form-card{padding:22px}
.category-list-card{padding:18px}
.category-form-card__header,.category-list-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.category-form-card__eyebrow{display:inline-flex;align-items:center;min-height:28px;padding:0 12px;border-radius:999px;background:#eef6ff;color:#0f4c81;font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.category-form-card h2,.category-list-card h2{margin:0;color:#0f172a;font-size:28px;line-height:1.08}
.category-form-card p{margin:10px 0 0;color:#64748b;font-size:14px;line-height:1.6}
.category-list-card__hint{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;border-radius:999px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;font-size:12px;font-weight:700;white-space:nowrap}
.category-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.category-field{display:flex;flex-direction:column;gap:8px}
.category-field--half{grid-column:span 1}
.category-field__label{font-size:13px;font-weight:800;color:#0f172a;letter-spacing:.01em}
.category-input{width:100%;height:52px;border-radius:16px;border:1px solid #d9e4ef;background:#fff;padding:0 16px;font-size:14px;color:#0f172a;outline:none;transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;box-shadow:inset 0 1px 2px rgba(15,23,42,.02)}
.category-input:focus{border-color:#8eb4da;box-shadow:0 0 0 4px rgba(59,130,246,.12)}
select.category-input{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 50%),linear-gradient(135deg,#64748b 50%,transparent 50%);background-position:calc(100% - 20px) calc(50% - 3px),calc(100% - 14px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:42px}
.category-toggle{grid-column:1 / -1;display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid #e2e8f0;border-radius:18px;background:linear-gradient(180deg,#f8fbff 0%,#f5f8fc 100%);cursor:pointer}
.category-toggle input{position:absolute;opacity:0;pointer-events:none}
.category-toggle__slider{position:relative;display:inline-block;flex:0 0 52px;width:52px;height:30px;border-radius:999px;background:#cbd5e1;transition:background .2s ease}
.category-toggle__slider:before{content:"";position:absolute;top:4px;left:4px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 6px 12px rgba(15,23,42,.18);transition:transform .2s ease}
.category-toggle input:checked + .category-toggle__slider{background:#0f4c81}
.category-toggle input:checked + .category-toggle__slider:before{transform:translateX(22px)}
.category-toggle__text{display:flex;flex-direction:column;gap:2px}
.category-toggle__text strong{font-size:14px;color:#0f172a}
.category-toggle__text small{font-size:12px;color:#64748b}
.category-form-actions{grid-column:1 / -1;display:flex;gap:10px;flex-wrap:wrap;padding-top:4px}
.category-form-actions .btn{min-height:46px;padding-left:18px;padding-right:18px}
.category-table-wrap{border:1px solid #e6edf5;border-radius:20px;background:#fff;overflow:auto}
.category-table{min-width:760px}
.category-table thead th{background:#f8fbff;color:#334155;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid #e6edf5}
.category-table tbody td{vertical-align:middle;border-bottom:1px solid #eef2f7}
.category-table tbody tr:hover{background:#fbfdff}
.category-name{display:inline-flex;align-items:center;gap:8px;padding-left:calc(var(--category-depth,0) * 22px);font-weight:800;color:#0f172a}
.category-name__branch{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;background:#eef6ff;color:#0f4c81;font-size:12px;line-height:1}
.category-code{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;font-size:12px;font-weight:700}
.category-status{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;font-size:12px;font-weight:800}
.category-status.is-active{background:#ecfdf5;color:#047857}
.category-status.is-inactive{background:#fef2f2;color:#b91c1c}
@media (max-width: 1100px){.category-admin-grid{grid-template-columns:1fr}.category-form-card{max-width:none}}
@media (max-width: 640px){.category-admin-shell{padding:16px}.category-form-card,.category-list-card{padding:16px}.category-form-grid{grid-template-columns:1fr}.category-field--half{grid-column:1 / -1}.category-form-card h2,.category-list-card h2{font-size:24px}.category-list-card__header{flex-direction:column;align-items:flex-start}.category-toggle{align-items:flex-start}}

/* ===== 404 Page ===== */
.error-404{padding:72px 20px 96px;background:#fff}
.error-404__inner{max-width:760px;margin:0 auto}
.error-404__card{background:#fff;border:1px solid rgba(17,24,39,.08);border-radius:24px;box-shadow:0 20px 48px rgba(17,24,39,.08);padding:56px 32px;text-align:center}
.error-404__code{margin:0 0 10px;font-size:clamp(68px,12vw,124px);line-height:1;font-weight:900;letter-spacing:-.06em;color:#d11212}
.error-404__title{margin:0 0 12px;font-size:clamp(28px,4vw,42px);line-height:1.1;color:#111827;font-weight:900}
.error-404__text{max-width:560px;margin:0 auto 28px;color:#4b5563;font-size:16px;line-height:1.8}
.error-404__actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
@media(max-width:640px){.error-404{padding:48px 16px 72px}.error-404__card{padding:34px 20px;border-radius:20px}.error-404__code{font-size:64px}.error-404__text{font-size:15px}.error-404__actions{flex-direction:column}.error-404__actions .btn{width:100%}}
