/* ============================================================
   LG GENUINE SERVICE — DESIGN SYSTEM
   ============================================================ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --red:       #C8002F;
  --red-dark:  #8a0020;
  --red-glow:  rgba(200,0,47,.12);
  --black:     #0A0A0A;
  --ink:       #1A1A1A;
  --slate:     #2E2E2E;
  --mid:       #6B6B6B;
  --silver:    #A0A0A0;
  --fog:       #E2E2E2;
  --snow:      #F5F5F5;
  --white:     #FFFFFF;
  --f-disp:    'Bebas Neue', sans-serif;
  --f-body:    'DM Sans', sans-serif;
  --f-mono:    'DM Mono', monospace;
  --r:    6px;
  --r-lg: 14px;
  --sh:   0 2px 14px rgba(0,0,0,.07);
  --sh-lg:0 10px 40px rgba(0,0,0,.13);
  --ease: cubic-bezier(.4,0,.2,1);
}

body.dark {
  --ink:    #E8E8E8; --slate: #C0C0C0; --mid: #888;
  --silver: #555; --fog: #2A2A2A; --snow: #1C1C1C;
  --white:  #121212; --black: #F0F0F0;
  --sh:  0 2px 14px rgba(0,0,0,.4);
  --sh-lg: 0 10px 40px rgba(0,0,0,.55);
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:var(--f-body); background:var(--white); color:var(--ink);
  font-size:15px; line-height:1.6;
  transition:background .3s,color .3s; overflow-x:hidden;
}
img { display:block; max-width:100%; }
button { font-family:var(--f-body); cursor:pointer; }
a { text-decoration:none; cursor:pointer; }

.page-sec        { display:none; }
.page-sec.active { display:block; }

/* ============================================================
   HEADER
   ============================================================ */
header {
  position:sticky; top:0; z-index:900;
  background:var(--black); border-bottom:3px solid var(--red);
}
.nav-wrap {
  max-width:1340px; margin:0 auto; padding:0 24px;
  height:64px; display:flex; align-items:center; gap:8px;
}
.logo {
  font-family:var(--f-disp); font-size:22px; letter-spacing:.04em;
  color:var(--white); cursor:pointer; flex-shrink:0; transition:opacity .2s;
}
.logo:hover { opacity:.8; }
.logo span { color:var(--red); }

.nav-links { display:flex; gap:2px; margin-left:20px; }
.nav-btn {
  font-size:13px; font-weight:500; color:var(--silver);
  background:none; border:none; padding:8px 14px; border-radius:var(--r);
  letter-spacing:.02em; transition:all .2s var(--ease);
}
.nav-btn:hover { color:var(--white); background:rgba(255,255,255,.08); }

.nav-actions { display:flex; align-items:center; gap:8px; margin-left:auto; }
.admin-pill {
  font-family:var(--f-mono); font-size:10px; font-weight:700;
  letter-spacing:.1em; background:#fbbf24; color:#111;
  padding:4px 10px; border-radius:20px;
}
.icon-btn {
  position:relative; background:rgba(255,255,255,.08); border:none;
  color:var(--silver); width:38px; height:38px; border-radius:var(--r);
  font-size:16px; display:flex; align-items:center; justify-content:center;
  transition:all .2s var(--ease);
}
.icon-btn:hover { color:var(--white); background:rgba(255,255,255,.14); }
.cart-btn { gap:4px; width:auto; padding:0 12px; font-size:15px; }
.cart-badge {
  position:absolute; top:-5px; right:-5px;
  background:var(--red); color:white; border-radius:50%;
  width:18px; height:18px; font-size:10px; font-weight:700;
  display:flex; align-items:center; justify-content:center; font-family:var(--f-mono);
}
.btn-primary {
  background:var(--red); color:white; border:none;
  font-weight:600; font-size:13px; letter-spacing:.04em;
  padding:9px 18px; border-radius:var(--r);
  transition:all .2s var(--ease); white-space:nowrap;
}
.btn-primary:hover { background:var(--red-dark); transform:translateY(-1px); }

/* Hamburger + Mobile menu */
.hamburger {
  display:none; background:none; border:none;
  color:var(--silver); font-size:22px; padding:8px; margin-left:4px;
}
.mobile-menu {
  display:none; position:absolute; top:64px; left:0; right:0;
  background:var(--black); border-bottom:2px solid var(--red);
  z-index:899; padding:10px 0;
}
.mobile-menu.open { display:block; }
.mobile-menu button, .mobile-menu .mob-tel {
  display:block; width:100%; font-family:var(--f-body);
  font-size:15px; font-weight:500; color:var(--silver);
  background:none; border:none; padding:14px 24px;
  text-align:left; transition:all .2s;
}
.mobile-menu button:hover, .mobile-menu .mob-tel:hover {
  color:var(--white); background:rgba(255,255,255,.05);
}
.mob-tel { text-decoration:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position:relative; overflow:hidden; background:var(--ink);
  min-height:400px; display:flex; align-items:center;
}
.hero-bg {
  position:absolute; inset:0;
  background:url('https://images.unsplash.com/photo-1556911220-e15b29be8c8f?q=80&w=1600') center/cover;
  opacity:.16;
}
.hero-noise {
  position:absolute; inset:0; pointer-events:none; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}
.hero-stripe { position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--red); }
.hero-inner {
  position:relative; z-index:1;
  max-width:1340px; margin:0 auto; padding:72px 24px; width:100%;
}
.eyebrow {
  font-family:var(--f-mono); font-size:11px; color:var(--red);
  letter-spacing:.18em; text-transform:uppercase; margin-bottom:14px;
  display:flex; align-items:center; gap:10px;
}
.eyebrow::before { content:''; width:24px; height:1px; background:var(--red); }
.hero h1 {
  font-family:var(--f-disp); font-size:clamp(56px,8vw,100px);
  line-height:.93; letter-spacing:.02em; color:var(--white); margin-bottom:22px;
}
.hero h1 em { color:var(--red); font-style:normal; }
.hero-sub { color:var(--silver); font-size:15px; max-width:400px; margin-bottom:32px; line-height:1.7; }
.search-bar {
  display:flex; max-width:560px; border-radius:var(--r); overflow:hidden; box-shadow:var(--sh-lg);
}
.search-bar input {
  flex:1; border:none; outline:none; padding:14px 20px;
  background:var(--white); color:var(--ink); font-family:var(--f-body); font-size:14px;
}
.search-bar input::placeholder { color:var(--silver); }
.search-bar button {
  background:var(--red); color:white; border:none; padding:14px 26px;
  font-weight:600; font-size:13px; letter-spacing:.04em; transition:background .2s;
}
.search-bar button:hover { background:var(--red-dark); }

/* ============================================================
   TRUST BAR
   ============================================================ */
.trust-bar {
  background:var(--white); border-bottom:1px solid var(--fog);
  padding:0 24px;
}
.trust-inner {
  max-width:1340px; margin:0 auto;
  display:flex; align-items:stretch; overflow-x:auto;
  scrollbar-width:none;
}
.trust-inner::-webkit-scrollbar { display:none; }
.trust-item {
  display:flex; align-items:center; gap:12px;
  padding:18px 24px; flex-shrink:0; white-space:nowrap;
}
.trust-icon { font-size:22px; flex-shrink:0; }
.trust-item div { display:flex; flex-direction:column; gap:2px; }
.trust-item strong { font-size:13px; font-weight:700; color:var(--ink); }
.trust-item span { font-size:11px; color:var(--mid); }
.trust-divider { width:1px; background:var(--fog); align-self:stretch; margin:12px 0; flex-shrink:0; }

/* ============================================================
   CATEGORY STRIP
   ============================================================ */
.cat-strip {
  background:var(--snow); border-bottom:1px solid var(--fog);
  padding:0 24px; display:flex; overflow-x:auto; scrollbar-width:none;
}
.cat-strip::-webkit-scrollbar { display:none; }
.cat-btn {
  font-size:13px; font-weight:500; color:var(--mid);
  background:none; border:none; border-bottom:3px solid transparent;
  padding:14px 20px; white-space:nowrap; flex-shrink:0;
  transition:all .2s var(--ease); letter-spacing:.02em;
}
.cat-btn:hover { color:var(--ink); }
.cat-btn.active { color:var(--red); border-bottom-color:var(--red); }

/* ============================================================
   PRODUCT GRID
   ============================================================ */
.grid-wrap { max-width:1340px; margin:0 auto; padding:36px 24px; }
.grid-meta { font-family:var(--f-mono); font-size:12px; color:var(--mid); margin-bottom:20px; }
.product-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px,1fr));
  gap:22px;
}
.card {
  background:var(--white); border:1px solid var(--fog);
  border-radius:var(--r-lg); overflow:hidden; cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:rgba(200,0,47,.25); }
.card-img { width:100%; height:190px; background:var(--snow); overflow:hidden; position:relative; }
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.card:hover .card-img img { transform:scale(1.05); }
.card-cat-badge {
  position:absolute; top:12px; left:12px;
  font-family:var(--f-mono); font-size:10px; font-weight:500;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--red); color:white; padding:3px 9px; border-radius:3px;
}
.card-body { padding:16px; }
.card-name {
  font-size:14px; font-weight:600; color:var(--ink); line-height:1.4;
  margin-bottom:4px; min-height:42px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.card-model { font-family:var(--f-mono); font-size:11px; color:var(--silver); margin-bottom:14px; }
.card-footer { display:flex; align-items:center; justify-content:space-between; }
.card-price { font-family:var(--f-disp); font-size:23px; letter-spacing:.02em; color:var(--ink); }
.card-price small { font-family:var(--f-mono); font-size:12px; color:var(--mid); }
.btn-add {
  background:var(--red); color:#fff; border:none; padding:8px 14px;
  border-radius:var(--r); font-size:12px; font-weight:700; letter-spacing:.04em;
  transition:background .2s, transform .15s;
  flex-shrink:0;
}
.btn-add:hover  { background:var(--red-dark); transform:translateY(-1px); }
.btn-add:active { transform:translateY(0); }
.empty-state { grid-column:1/-1; text-align:center; padding:80px 20px; color:var(--mid); }
.empty-state .icon { font-size:48px; margin-bottom:14px; }
.empty-state h3 { font-size:20px; color:var(--ink); margin-bottom:6px; }

/* ============================================================
   SERVICES SECTION
   ============================================================ */
.services-section {
  background:var(--snow); padding:80px 24px;
  border-top:1px solid var(--fog);
}
.services-wrap { max-width:1340px; margin:0 auto; }
.services-head { text-align:center; margin-bottom:52px; }
.sec-h2 {
  font-family:var(--f-disp); font-size:clamp(36px,5vw,56px);
  line-height:.95; margin-bottom:12px; letter-spacing:.02em;
}
.sec-h2 em { color:var(--red); font-style:normal; }
.sec-desc { color:var(--mid); font-size:15px; line-height:1.7; margin-top:8px; }

.services-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px,1fr));
  gap:24px;
}
.svc-card {
  background:var(--white); border:1px solid var(--fog);
  border-radius:var(--r-lg); padding:32px 28px;
  cursor:pointer; transition:all .25s var(--ease);
  display:flex; flex-direction:column;
}
.svc-card:hover {
  border-color:var(--red); transform:translateY(-4px);
  box-shadow:var(--sh-lg);
}
.svc-card:hover .svc-icon { transform:scale(1.15); }
.svc-icon { font-size:38px; margin-bottom:18px; transition:transform .25s; display:inline-block; }
.svc-card h3 {
  font-family:var(--f-disp); font-size:22px; letter-spacing:.03em;
  color:var(--ink); margin-bottom:10px;
}
.svc-card p { font-size:13px; color:var(--mid); line-height:1.6; flex:1; margin-bottom:18px; }
.svc-price {
  font-family:var(--f-mono); font-size:12px; font-weight:600;
  color:var(--red); letter-spacing:.06em;
  background:var(--red-glow); padding:5px 12px;
  border-radius:20px; display:inline-block; align-self:flex-start;
}

/* ============================================================
   WHY SECTION
   ============================================================ */
.why-section { background:var(--ink); padding:80px 24px; }
.why-wrap {
  max-width:1340px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.why-text .eyebrow { color:var(--red); }
.why-text .sec-h2 { color:var(--white); margin-bottom:16px; }
.why-text .sec-desc { color:var(--silver); }
.btn-why {
  display:inline-block; margin-top:28px;
  background:var(--red); color:white; border:none;
  font-family:var(--f-disp); font-size:18px; letter-spacing:.06em;
  padding:14px 28px; border-radius:var(--r); transition:all .2s var(--ease);
}
.btn-why:hover { background:var(--red-dark); transform:translateY(-2px); }

.why-stats {
  display:grid; grid-template-columns:1fr 1fr; gap:2px;
}
.stat-item {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  padding:32px 28px; display:flex; flex-direction:column; gap:8px;
  transition:background .2s;
}
.stat-item:hover { background:rgba(200,0,47,.12); border-color:rgba(200,0,47,.3); }
.stat-num {
  font-family:var(--f-disp); font-size:48px; color:var(--red);
  line-height:1; letter-spacing:.02em;
}
.stat-label { font-size:13px; color:var(--silver); letter-spacing:.02em; }

/* ============================================================
   BOOKING LAYOUT
   ============================================================ */
.booking-outer { background:var(--snow); min-height:100vh; padding:60px 24px; }
.booking-layout {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:1fr 360px; gap:40px; align-items:start;
}
.display-title { font-family:var(--f-disp); font-size:44px; color:var(--ink); margin-bottom:8px; line-height:1; }
.section-sub { color:var(--mid); font-size:14px; margin-bottom:36px; }

.form-card {
  background:var(--white); border:1px solid var(--fog);
  border-radius:var(--r-lg); padding:40px; box-shadow:var(--sh);
}
.card-title { font-family:var(--f-disp); font-size:26px; letter-spacing:.04em; margin-bottom:24px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.span-2 { grid-column:1/-1; }
.field { display:flex; flex-direction:column; gap:6px; }
.field label { font-size:11px; font-weight:700; color:var(--mid); letter-spacing:.07em; text-transform:uppercase; }
.field input, .field select, .field textarea {
  background:var(--snow); border:1.5px solid var(--fog);
  border-radius:var(--r); padding:11px 14px;
  font-family:var(--f-body); font-size:14px; color:var(--ink);
  outline:none; transition:border-color .2s,background .2s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color:var(--red); background:var(--white);
}
.field textarea { resize:vertical; min-height:96px; }
.mb-14 { margin-bottom:14px; }

.btn-submit {
  width:100%; padding:16px; border:none; border-radius:var(--r);
  background:var(--red); color:white;
  font-family:var(--f-disp); font-size:20px;
  letter-spacing:.06em; transition:all .2s var(--ease);
  margin-top:28px;
}
.btn-submit:hover { background:var(--red-dark); transform:translateY(-1px); }
.img-preview { width:100px; margin-top:10px; border-radius:var(--r); border:1px solid var(--fog); }

/* Booking sidebar */
.booking-sidebar { display:flex; flex-direction:column; gap:20px; }
.sidebar-card {
  border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh);
}
.sidebar-title {
  font-family:var(--f-disp); font-size:18px; letter-spacing:.06em;
  color:var(--ink); margin-bottom:20px;
}
.why-book { background:var(--white); border:1px solid var(--fog); padding:28px; }
.sidebar-list { list-style:none; display:flex; flex-direction:column; gap:18px; }
.sidebar-list li { display:flex; align-items:flex-start; gap:14px; }
.sb-icon { font-size:20px; flex-shrink:0; margin-top:2px; }
.sidebar-list strong { font-size:13px; font-weight:700; color:var(--ink); display:block; margin-bottom:2px; }
.sidebar-list p { font-size:12px; color:var(--mid); margin:0; line-height:1.5; }

.call-card {
  background:var(--ink); padding:28px; text-align:center;
}
.call-label { font-family:var(--f-mono); font-size:11px; color:var(--silver); letter-spacing:.12em; text-transform:uppercase; margin-bottom:10px; }
.call-number {
  display:block; font-family:var(--f-disp); font-size:28px; color:var(--red);
  letter-spacing:.03em; margin-bottom:20px; transition:opacity .2s;
}
.call-number:hover { opacity:.8; }
.call-hours { border-top:1px solid rgba(255,255,255,.1); padding-top:16px; }
.call-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 0; border-bottom:1px solid rgba(255,255,255,.06);
}
.call-row:last-child { border-bottom:none; }
.call-row span { font-size:12px; color:var(--silver); }
.call-row strong { font-size:13px; color:var(--white); font-weight:600; }
.call-note { font-size:11px; color:var(--mid); margin-top:14px; line-height:1.5; }

.areas-card { background:var(--white); border:1px solid var(--fog); padding:28px; }
.area-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:4px; }
.area-tags span {
  font-size:12px; font-weight:600; color:var(--ink);
  background:var(--snow); border:1px solid var(--fog);
  padding:5px 12px; border-radius:20px; letter-spacing:.02em;
  transition:all .2s;
}
.area-tags span:hover { background:var(--red-glow); border-color:var(--red); color:var(--red); }

/* ============================================================
   ADMIN
   ============================================================ */
.admin-page { background:var(--snow); min-height:100vh; padding:40px 24px; }
.admin-wrap { max-width:1100px; margin:0 auto; }
.admin-top { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:28px; }
.btn-danger {
  background:#fee2e2; color:#991b1b; border:none;
  padding:10px 20px; border-radius:var(--r);
  font-size:13px; font-weight:700; letter-spacing:.03em; transition:all .2s;
}
.btn-danger:hover { background:var(--red); color:white; }
.tab-bar { display:flex; border-bottom:2px solid var(--fog); margin-bottom:28px; }
.tab-btn {
  font-size:13px; font-weight:600; color:var(--mid); background:none; border:none;
  padding:12px 22px; border-bottom:3px solid transparent; margin-bottom:-2px;
  transition:all .2s var(--ease); letter-spacing:.02em;
}
.tab-btn:hover { color:var(--ink); }
.tab-btn.active { color:var(--red); border-bottom-color:var(--red); }
.tab-panel { display:none; }
.tab-panel.active { display:block; animation:fadeUp .3s var(--ease); }
.table-wrap { border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--fog); background:var(--white); }
.admin-tbl { width:100%; border-collapse:collapse; }
.admin-tbl th {
  background:var(--snow); padding:13px 16px; text-align:left;
  font-size:11px; font-weight:700; color:var(--mid);
  letter-spacing:.08em; text-transform:uppercase; border-bottom:1px solid var(--fog);
}
.admin-tbl td { padding:14px 16px; font-size:13px; border-bottom:1px solid var(--fog); vertical-align:middle; }
.admin-tbl tr:last-child td { border-bottom:none; }
.admin-tbl tr:hover td { background:var(--snow); }
.cat-tag {
  font-family:var(--f-mono); font-size:10px; font-weight:600;
  padding:3px 10px; border-radius:20px; letter-spacing:.05em;
  background:#e0f2fe; color:#0369a1;
}
.btn-sm { font-size:11px; font-weight:700; letter-spacing:.03em; padding:5px 12px; border-radius:var(--r); border:none; transition:all .2s; cursor:pointer; }
.btn-edit { background:var(--fog); color:var(--ink); }
.btn-edit:hover { background:var(--ink); color:white; }
.btn-del  { background:#fee2e2; color:#991b1b; margin-left:6px; }
.btn-del:hover  { background:var(--red); color:white; }

/* ============================================================
   MODALS
   ============================================================ */
.modal-backdrop {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,.65); backdrop-filter:blur(5px);
  display:none; align-items:center; justify-content:center; padding:20px;
}
.modal-backdrop.open { display:flex; }
.modal-box {
  background:var(--white); border-radius:var(--r-lg);
  width:100%; max-width:520px; max-height:92vh; overflow:hidden;
  display:flex; flex-direction:column; box-shadow:0 24px 80px rgba(0,0,0,.3);
  animation:modalIn .25s cubic-bezier(.34,1.56,.64,1);
}
.detail-box { max-width:740px; }
@keyframes modalIn { from { opacity:0; transform:scale(.94) translateY(12px); } to { opacity:1; transform:scale(1) translateY(0); } }
.modal-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; border-bottom:1px solid var(--fog); flex-shrink:0;
}
.modal-title { font-family:var(--f-disp); font-size:22px; letter-spacing:.03em; }
.modal-x {
  width:32px; height:32px; border-radius:50%;
  background:var(--fog); border:none; font-size:20px;
  color:var(--mid); display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.modal-x:hover { background:var(--red); color:white; }
.modal-body { padding:24px; flex:1; }
.modal-body.scrollable { overflow-y:auto; max-height:52vh; }
.modal-foot { padding:20px 24px; border-top:1px solid var(--fog); flex-shrink:0; }
.login-logo { font-family:var(--f-disp); font-size:36px; text-align:center; letter-spacing:.04em; margin-bottom:28px; }
.login-logo span { color:var(--red); }
.note { font-size:12px; color:var(--mid); text-align:center; margin-top:12px; }

/* Cart items */
.cart-empty { text-align:center; padding:48px 0; color:var(--mid); }
.cart-empty .icon { font-size:44px; margin-bottom:12px; }
.cart-empty p { font-size:14px; }
.cart-item { display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid var(--fog); }
.cart-item:last-child { border-bottom:none; }
.cart-thumb { width:58px; height:58px; border-radius:var(--r); object-fit:cover; background:var(--snow); flex-shrink:0; }
.cart-info { flex:1; min-width:0; }
.cart-name { font-size:13px; font-weight:600; margin-bottom:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cart-sub { font-family:var(--f-mono); font-size:12px; color:var(--mid); }
.qty-ctrl { display:flex; align-items:center; border:1.5px solid var(--fog); border-radius:24px; overflow:hidden; }
.qty-btn { background:none; border:none; width:32px; height:32px; font-size:17px; color:var(--mid); display:flex; align-items:center; justify-content:center; transition:all .18s; font-weight:600; }
.qty-btn:hover { background:var(--red); color:white; }
.qty-num { font-family:var(--f-mono); font-size:13px; font-weight:600; min-width:28px; text-align:center; }
.cart-total-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; }
.cart-total-label { font-size:13px; color:var(--mid); font-weight:600; }
.cart-total-val { font-family:var(--f-disp); font-size:30px; color:var(--red); }

/* Detail */
.detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; padding:24px; }
.detail-img { width:100%; border-radius:var(--r); object-fit:cover; aspect-ratio:1/1; background:var(--snow); }
.detail-info { display:flex; flex-direction:column; }
.detail-cat { font-family:var(--f-mono); font-size:10px; font-weight:700; color:var(--red); letter-spacing:.12em; text-transform:uppercase; margin-bottom:8px; }
.detail-name { font-family:var(--f-disp); font-size:30px; line-height:1.1; margin-bottom:8px; }
.detail-model { font-family:var(--f-mono); font-size:12px; color:var(--silver); margin-bottom:20px; }
.detail-price { font-family:var(--f-disp); font-size:42px; color:var(--red); margin-bottom:24px; line-height:1; }
.detail-price small { font-family:var(--f-mono); font-size:14px; color:var(--mid); }
.detail-badges { font-size:12px; color:var(--mid); margin-top:14px; line-height:2; }

/* ============================================================
   CHATBOT
   ============================================================ */
.chat-fab {
  position:fixed; bottom:28px; right:28px; z-index:800;
  width:56px; height:56px; border-radius:50%;
  background:var(--red); color:white; border:none; font-size:24px;
  box-shadow:0 4px 20px rgba(200,0,47,.45);
  display:flex; align-items:center; justify-content:center; transition:all .2s var(--ease);
}
.chat-fab:hover { transform:scale(1.1); background:var(--red-dark); }
.chat-window {
  position:fixed; bottom:96px; right:28px; z-index:800;
  width:320px; height:460px; border-radius:var(--r-lg); background:var(--white);
  border:1px solid var(--fog); box-shadow:0 16px 56px rgba(0,0,0,.2);
  display:flex; flex-direction:column; overflow:hidden;
  opacity:0; pointer-events:none;
  transform:scale(.9) translateY(16px) translateX(8px);
  transition:all .25s cubic-bezier(.34,1.3,.64,1);
}
.chat-window.open { opacity:1; pointer-events:all; transform:scale(1) translateY(0) translateX(0); }
.chat-head { background:var(--red); padding:14px 16px; display:flex; align-items:center; gap:12px; flex-shrink:0; }
.chat-avatar { width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:16px; }
.chat-head-info { flex:1; }
.chat-name  { color:white; font-size:14px; font-weight:600; }
.chat-status{ color:rgba(255,255,255,.7); font-size:11px; }
.chat-close { background:none; border:none; color:rgba(255,255,255,.7); font-size:22px; padding:0; line-height:1; transition:color .2s; }
.chat-close:hover { color:white; }
.chat-msgs { flex:1; overflow-y:auto; padding:14px; display:flex; flex-direction:column; gap:10px; background:var(--snow); }
.msg { max-width:82%; font-size:13px; line-height:1.5; padding:9px 13px; border-radius:12px; animation:fadeUp .2s ease; }
.msg.bot  { background:var(--white); color:var(--ink); border:1px solid var(--fog); align-self:flex-start; border-radius:4px 12px 12px 12px; }
.msg.user { background:var(--red); color:white; align-self:flex-end; border-radius:12px 4px 12px 12px; }
.chat-input-row { display:flex; border-top:1px solid var(--fog); background:var(--white); flex-shrink:0; }
.chat-input-row input { flex:1; border:none; outline:none; padding:12px 14px; font-size:13px; font-family:var(--f-body); background:none; color:var(--ink); }
.chat-input-row button { background:none; border:none; padding:12px 16px; color:var(--red); font-weight:700; font-size:13px; transition:color .2s; }
.chat-input-row button:hover { color:var(--red-dark); }

/* ============================================================
   TOAST
   ============================================================ */
.toast {
  position:fixed; bottom:24px; left:50%; z-index:2000;
  transform:translateX(-50%) translateY(70px);
  background:var(--ink); color:white; padding:12px 24px;
  border-radius:28px; font-size:13px; font-weight:500;
  box-shadow:var(--sh-lg); white-space:nowrap; pointer-events:none;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.toast.show { transform:translateX(-50%) translateY(0); }
.toast.ok  { background:#065f46; }
.toast.err { background:var(--red); }

/* ============================================================
   FOOTER
   ============================================================ */
footer { background:var(--black); }

/* CTA band */
.footer-cta {
  background:var(--red); padding:32px 24px;
}
.footer-cta-inner {
  max-width:1340px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.footer-cta-label { font-family:var(--f-mono); font-size:11px; color:rgba(255,255,255,.7); letter-spacing:.12em; text-transform:uppercase; margin-bottom:4px; }
.footer-cta-title { font-family:var(--f-disp); font-size:clamp(20px,3vw,30px); color:white; letter-spacing:.04em; }
.footer-cta-actions { display:flex; gap:12px; flex-wrap:wrap; }
.footer-btn-book {
  background:white; color:var(--red); border:none;
  font-family:var(--f-disp); font-size:16px; letter-spacing:.06em;
  padding:12px 24px; border-radius:var(--r); transition:all .2s; white-space:nowrap;
}
.footer-btn-book:hover { background:var(--ink); color:white; }
.footer-btn-call {
  display:inline-flex; align-items:center;
  background:rgba(255,255,255,.15); color:white;
  font-family:var(--f-disp); font-size:16px; letter-spacing:.06em;
  padding:12px 24px; border-radius:var(--r); transition:all .2s;
  border:2px solid rgba(255,255,255,.3); white-space:nowrap;
}
.footer-btn-call:hover { background:rgba(255,255,255,.25); }

/* Main footer grid */
.footer-main { padding:56px 24px 40px; }
.footer-grid {
  max-width:1340px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1.4fr; gap:40px;
}
.footer-logo {
  font-family:var(--f-disp); font-size:26px; color:white;
  letter-spacing:.04em; margin-bottom:14px;
}
.footer-logo span { color:var(--red); }
.footer-tagline { font-size:13px; color:var(--silver); line-height:1.7; margin-bottom:20px; max-width:280px; }
.footer-badges { display:flex; flex-wrap:wrap; gap:8px; }
.f-badge {
  font-family:var(--f-mono); font-size:10px; font-weight:600; letter-spacing:.06em;
  background:rgba(255,255,255,.06); color:var(--silver);
  border:1px solid rgba(255,255,255,.1); padding:5px 12px; border-radius:20px;
}

.footer-col-title {
  font-family:var(--f-mono); font-size:10px; font-weight:700;
  color:white; letter-spacing:.12em; text-transform:uppercase; margin-bottom:16px;
}
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links li a {
  font-size:13px; color:var(--silver); transition:color .2s;
  display:block;
}
.footer-links li a:hover { color:white; }

.footer-contact { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-contact li { display:flex; align-items:flex-start; gap:10px; }
.footer-contact li span:first-child { font-size:14px; flex-shrink:0; margin-top:1px; }
.footer-contact li a { font-size:13px; color:var(--silver); transition:color .2s; }
.footer-contact li a:hover { color:white; }
.footer-contact li span:last-child { font-size:13px; color:var(--silver); }

.footer-hours { border-top:1px solid rgba(255,255,255,.08); padding-top:0; }
.hours-row { display:flex; justify-content:space-between; padding:7px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.hours-row:last-child { border-bottom:none; }
.hours-row span { font-size:12px; color:var(--silver); }
.hours-row strong { font-size:12px; color:white; }

/* Bottom bar */
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.08);
  padding:20px 24px;
}
.footer-bottom-inner {
  max-width:1340px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.footer-bottom p { font-size:12px; color:var(--silver); }
.footer-bottom strong { color:white; }
.footer-bottom-links { display:flex; gap:20px; }
.footer-bottom-links a { font-size:12px; color:var(--silver); transition:color .2s; }
.footer-bottom-links a:hover { color:white; }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px) {
  .footer-grid { grid-template-columns:1fr 1fr 1fr; }
  .brand-col { grid-column:1/-1; }
  .why-wrap { grid-template-columns:1fr; gap:40px; }
  .why-stats { grid-template-columns:repeat(4,1fr); }
}
@media (max-width:900px) {
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .booking-layout { grid-template-columns:1fr; }
  .booking-sidebar { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
  .call-card { grid-column:1/-1; }
}
@media (max-width:700px) {
  .form-grid { grid-template-columns:1fr; }
  .span-2 { grid-column:auto; }
  .detail-grid { grid-template-columns:1fr; }
  .form-card { padding:24px 18px; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .why-stats { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .footer-cta-inner { flex-direction:column; align-items:flex-start; }
  .booking-sidebar { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .product-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .services-grid { grid-template-columns:1fr; }
  .why-stats { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .chat-window { right:8px; width:calc(100vw - 16px); }
  .nav-wrap { padding:0 14px; }
  .btn-primary { display:none; }
  .trust-item { padding:14px 16px; }
}

/* ============================================================
   LEGAL PAGES — FAQ & TERMS & CONDITIONS
   ============================================================ */
.legal-page {
  background:var(--snow); min-height:100vh; padding:60px 24px 80px;
}
.legal-wrap {
  max-width:860px; margin:0 auto;
}
.back-btn {
  background:none; border:1.5px solid var(--fog); color:var(--mid);
  font-size:13px; font-weight:600; padding:8px 16px; border-radius:var(--r);
  cursor:pointer; margin-bottom:32px; display:inline-flex; align-items:center; gap:6px;
  transition:all .2s var(--ease); letter-spacing:.02em;
}
.back-btn:hover { border-color:var(--red); color:var(--red); }

.legal-title {
  font-family:var(--f-disp); font-size:clamp(42px,6vw,72px);
  line-height:.93; letter-spacing:.02em; color:var(--ink);
  margin-bottom:20px;
}
.legal-title em { color:var(--red); font-style:normal; }
.legal-intro {
  font-size:15px; color:var(--mid); line-height:1.7;
  max-width:600px; margin-bottom:52px; padding-bottom:32px;
  border-bottom:2px solid var(--fog);
}
.legal-intro a { color:var(--red); font-weight:600; }
.legal-intro a:hover { text-decoration:underline; }

/* ── FAQ ─────────────────────────────────────────────────────── */
.faq-group { margin-bottom:48px; }
.faq-group-title {
  font-family:var(--f-disp); font-size:26px; letter-spacing:.04em;
  color:var(--ink); margin-bottom:20px; padding-bottom:12px;
  border-bottom:2px solid var(--fog);
}

.faq-item {
  border:1px solid var(--fog); border-radius:var(--r-lg);
  margin-bottom:10px; background:var(--white); overflow:hidden;
  transition:box-shadow .2s var(--ease);
}
.faq-item:hover { box-shadow:var(--sh); }
.faq-item.open { border-color:rgba(200,0,47,.25); box-shadow:0 0 0 3px var(--red-glow); }

.faq-q {
  width:100%; background:none; border:none; text-align:left;
  padding:18px 20px; display:flex; justify-content:space-between; align-items:center;
  font-family:var(--f-body); font-size:14px; font-weight:600; color:var(--ink);
  cursor:pointer; gap:12px; line-height:1.5;
  transition:color .2s;
}
.faq-q:hover { color:var(--red); }
.faq-item.open .faq-q { color:var(--red); }

.faq-chevron {
  font-size:18px; color:var(--mid); flex-shrink:0; transition:transform .25s var(--ease);
  display:inline-block;
}
.faq-item.open .faq-chevron { transform:rotate(180deg); color:var(--red); }

.faq-a {
  display:none; padding:0 20px 20px; border-top:1px solid var(--fog);
  animation:fadeUp .2s var(--ease);
}
.faq-item.open .faq-a { display:block; }
.faq-a p { font-size:14px; color:var(--mid); line-height:1.75; margin-bottom:10px; }
.faq-a p:last-child { margin-bottom:0; }
.faq-a ul { margin:10px 0 10px 20px; }
.faq-a ul li { font-size:14px; color:var(--mid); line-height:1.75; margin-bottom:4px; }
.faq-a ul li strong { color:var(--ink); }
.faq-a a { color:var(--red); font-weight:600; }
.faq-a a:hover { text-decoration:underline; }

.faq-cta {
  background:var(--ink); border-radius:var(--r-lg); padding:36px 40px;
  text-align:center; margin-top:48px;
}
.faq-cta p { font-family:var(--f-disp); font-size:26px; color:white; margin-bottom:20px; letter-spacing:.04em; }
.faq-cta-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.faq-btn-call {
  background:var(--red); color:white; font-family:var(--f-disp);
  font-size:17px; letter-spacing:.05em; padding:12px 28px; border-radius:var(--r);
  transition:all .2s;
}
.faq-btn-call:hover { background:var(--red-dark); }
.faq-btn-book {
  background:rgba(255,255,255,.1); color:white; border:2px solid rgba(255,255,255,.3);
  font-family:var(--f-disp); font-size:17px; letter-spacing:.05em;
  padding:12px 28px; border-radius:var(--r); cursor:pointer; transition:all .2s;
}
.faq-btn-book:hover { background:rgba(255,255,255,.2); }

/* ── Terms & Conditions ─────────────────────────────────────── */
.terms-body { display:flex; flex-direction:column; gap:0; }
.terms-section {
  padding:28px 0; border-bottom:1px solid var(--fog);
}
.terms-section:last-child { border-bottom:none; }
.terms-section h2 {
  font-family:var(--f-disp); font-size:22px; letter-spacing:.04em;
  color:var(--ink); margin-bottom:14px;
}
.terms-section h3 {
  font-size:14px; font-weight:700; color:var(--ink);
  margin:16px 0 8px; letter-spacing:.02em;
}
.terms-section p {
  font-size:14px; color:var(--mid); line-height:1.8; margin-bottom:10px;
}
.terms-section p:last-child { margin-bottom:0; }
.terms-section ul { margin:8px 0 10px 20px; }
.terms-section ul li { font-size:14px; color:var(--mid); line-height:1.8; margin-bottom:4px; }
.terms-section a { color:var(--red); font-weight:600; }
.terms-section a:hover { text-decoration:underline; }
.terms-section strong { color:var(--ink); }
.terms-section em { color:var(--mid); font-style:italic; }

/* Responsive */
@media (max-width:600px) {
  .legal-page { padding:40px 16px 60px; }
  .faq-q { font-size:13px; padding:14px 16px; }
  .faq-a { padding:0 16px 16px; }
  .faq-cta { padding:28px 20px; }
  .faq-cta-btns { flex-direction:column; }
  .terms-section { padding:20px 0; }
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 52px;
  padding-bottom: 48px;
  border-bottom: 2px solid var(--fog);
}
.about-stat {
  background: var(--white);
  border: 1.5px solid var(--fog);
  border-radius: var(--r-lg);
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
  transition: box-shadow .2s var(--ease);
}
.about-stat:hover { box-shadow: var(--sh); }
.about-num {
  font-family: var(--f-disp);
  font-size: 36px;
  letter-spacing: .02em;
  color: var(--red);
  line-height: 1;
}
.about-lbl {
  font-size: 12px;
  font-weight: 600;
  color: var(--mid);
  letter-spacing: .04em;
  text-transform: uppercase;
}

.about-body { display: flex; flex-direction: column; gap: 0; }

.about-section {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  padding: 32px 0;
  border-bottom: 1px solid var(--fog);
  align-items: flex-start;
}
.about-section:last-child { border-bottom: none; }

.about-section-icon {
  font-size: 28px;
  margin-top: 4px;
  text-align: center;
}
.about-section-content h2 {
  font-family: var(--f-disp);
  font-size: 22px;
  letter-spacing: .04em;
  color: var(--ink);
  margin-bottom: 12px;
}
.about-section-content p {
  font-size: 14px;
  color: var(--mid);
  line-height: 1.8;
  margin-bottom: 10px;
}
.about-section-content p:last-child { margin-bottom: 0; }
.about-section-content strong { color: var(--ink); }

.about-contact-list {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.about-contact-list li {
  font-size: 14px;
  color: var(--mid);
  line-height: 1.6;
}
.about-contact-list a { color: var(--red); font-weight: 600; }
.about-contact-list a:hover { text-decoration: underline; }

.about-cta {
  background: var(--ink);
  border-radius: var(--r-lg);
  padding: 36px 40px;
  text-align: center;
  margin-top: 48px;
}
.about-cta h3 {
  font-family: var(--f-disp);
  font-size: 28px;
  color: white;
  letter-spacing: .04em;
  margin-bottom: 20px;
}
.about-cta-btns {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ============================================================
   SHIPPING PAGE — summary cards & table
   ============================================================ */
.shipping-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 48px;
}
.ship-card {
  background: var(--white);
  border: 1.5px solid var(--fog);
  border-radius: var(--r-lg);
  padding: 22px 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
  transition: box-shadow .2s var(--ease);
}
.ship-card:hover { box-shadow: var(--sh); }
.ship-icon { font-size: 28px; }
.ship-card strong { font-size: 13px; font-weight: 700; color: var(--ink); }
.ship-card p { font-size: 12px; color: var(--mid); line-height: 1.5; margin: 0; }

.shipping-table {
  border: 1.5px solid var(--fog);
  border-radius: var(--r);
  overflow: hidden;
  margin: 14px 0;
}
.st-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  padding: 12px 16px;
  font-size: 13px;
  color: var(--mid);
  border-bottom: 1px solid var(--fog);
}
.st-row:last-child { border-bottom: none; }
.st-row.st-head {
  background: var(--fog);
  font-weight: 700;
  color: var(--ink);
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* ============================================================
   WARRANTY — ACL mandatory box
   ============================================================ */
.acl-box {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  background: #fff8f8;
  border: 2px solid rgba(200,0,47,.2);
  border-left: 4px solid var(--red);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  margin-bottom: 40px;
}
.acl-box-icon { font-size: 28px; flex-shrink: 0; margin-top: 2px; }
.acl-box-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 8px;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.acl-box p {
  font-size: 13px;
  color: var(--mid);
  line-height: 1.75;
  margin: 0;
}

/* Dark mode overrides for new sections */
[data-theme="dark"] .about-stat,
[data-theme="dark"] .ship-card { background: var(--card); border-color: var(--fog); }
[data-theme="dark"] .acl-box { background: rgba(200,0,47,.06); }
[data-theme="dark"] .st-row.st-head { background: rgba(255,255,255,.05); }
[data-theme="dark"] .shipping-table { border-color: var(--fog); }
[data-theme="dark"] .st-row { border-color: var(--fog); }

/* Responsive */
@media (max-width: 768px) {
  .about-stats { grid-template-columns: repeat(2, 1fr); }
  .shipping-summary { grid-template-columns: repeat(2, 1fr); }
  .about-section { grid-template-columns: 1fr; gap: 10px; }
  .about-section-icon { display: none; }
  .st-row { grid-template-columns: 1.2fr 1fr 1fr; font-size: 12px; }
}
@media (max-width: 480px) {
  .about-stats { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .shipping-summary { grid-template-columns: 1fr 1fr; }
  .about-cta { padding: 28px 20px; }
  .acl-box { flex-direction: column; gap: 10px; }
}

/* Mobile menu divider */
.mob-menu-divider {
  height: 1px;
  background: rgba(255,255,255,.12);
  margin: 6px 0;
}

/* ============================================================
   LOGIN MODAL — Firebase Auth
   ============================================================ */
.login-modal-box {
  max-width: 420px;
  border-radius: 20px;
  overflow: hidden;
  border: none;
  box-shadow: 0 24px 80px rgba(0,0,0,.25);
}

.login-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 0;
}
.login-brand-mark {
  display: flex;
  align-items: center;
  gap: 8px;
}
.login-brand-lg {
  font-family: var(--f-disp);
  font-size: 22px;
  color: var(--red);
  letter-spacing: .06em;
  line-height: 1;
}
.login-brand-text {
  font-size: 12px;
  font-weight: 600;
  color: var(--mid);
  letter-spacing: .04em;
  text-transform: uppercase;
}

.login-modal-body {
  padding: 16px 28px 28px;
}

.login-icon-wrap {
  text-align: center;
  margin-bottom: 4px;
}
.login-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, var(--red) 0%, #a0001f 100%);
  border-radius: 18px;
  font-size: 28px;
  box-shadow: 0 8px 24px rgba(200,0,47,.3);
}

.login-title {
  font-family: var(--f-disp);
  font-size: 28px;
  letter-spacing: .05em;
  color: var(--ink);
  text-align: center;
  margin: 12px 0 4px;
}
.login-sub {
  font-size: 13px;
  color: var(--mid);
  text-align: center;
  margin-bottom: 24px;
  letter-spacing: .02em;
}

.login-error {
  background: #fff0f2;
  border: 1.5px solid rgba(200,0,47,.25);
  border-left: 3px solid var(--red);
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 13px;
  color: var(--red);
  font-weight: 500;
  margin-bottom: 16px;
}
.login-error::before { content: '⚠️ '; }

.login-field {
  margin-bottom: 16px;
}
.login-field label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 7px;
}
.login-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.login-input-icon {
  position: absolute;
  left: 13px;
  font-size: 15px;
  pointer-events: none;
  z-index: 1;
}
.login-input-wrap input {
  width: 100%;
  border: 1.5px solid var(--fog);
  border-radius: 10px;
  padding: 11px 44px 11px 38px;
  font-size: 14px;
  font-family: var(--f-body);
  color: var(--ink);
  background: var(--white);
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}
.login-input-wrap input:focus {
  border-color: var(--red);
  box-shadow: 0 0 0 3px var(--red-glow, rgba(200,0,47,.12));
}
.login-input-wrap input::placeholder { color: var(--fog); }

.login-eye {
  position: absolute;
  right: 10px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 16px;
  opacity: .4;
  transition: opacity .2s;
  padding: 4px;
}
.login-eye:hover { opacity: .8; }

.login-submit-btn {
  width: 100%;
  height: 48px;
  background: var(--red);
  color: white;
  border: none;
  border-radius: 12px;
  font-family: var(--f-disp);
  font-size: 18px;
  letter-spacing: .08em;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 8px;
  transition: background .2s, transform .1s, box-shadow .2s;
  box-shadow: 0 4px 16px rgba(200,0,47,.3);
}
.login-submit-btn:hover {
  background: #a0001f;
  box-shadow: 0 6px 20px rgba(200,0,47,.4);
}
.login-submit-btn:active { transform: scale(.98); }
.login-submit-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none;
}
.login-btn-arrow {
  font-size: 20px;
  font-family: var(--f-body);
  font-weight: 300;
}

.login-footer-note {
  text-align: center;
  font-size: 11px;
  color: var(--mid);
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  opacity: .7;
}
.login-secure-badge {
  background: var(--fog);
  border-radius: 20px;
  padding: 3px 8px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
}

/* Dark mode */
[data-theme="dark"] .login-modal-body { background: var(--card); }
[data-theme="dark"] .login-input-wrap input { background: var(--snow); }
[data-theme="dark"] .login-error { background: rgba(200,0,47,.1); }
[data-theme="dark"] .login-secure-badge { background: rgba(255,255,255,.1); }

@media (max-width: 480px) {
  .login-modal-box { border-radius: 16px; }
  .login-modal-body { padding: 12px 20px 24px; }
}
