/* ============================================================
   Rustic Revolutions — store + admin styles
   Aesthetic: industrial gunmetal, molten-orange accent,
   Oswald condensed display over Inter body. Responsive first.
   ============================================================ */
:root{
  --bg:#15171a; --panel:#1d2024; --panel-2:#24282d;
  --ink:#eef0f2; --muted:#9aa1a9; --line:#33383f;
  --accent:#e2571e;       /* molten orange */
  --accent-2:#f08a4b;     /* heated edge */
  --ok:#3ba776; --err:#d8553f;
  --radius:10px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:'Inter',system-ui,sans-serif; line-height:1.55;
}
a{color:var(--accent-2); text-decoration:none}
a:hover{text-decoration:underline}
.wrap{width:100%; max-width:1080px; margin:0 auto; padding:0 20px}
.muted{color:var(--muted)}
img{max-width:100%; height:auto}

/* ---------- header / footer ---------- */
.site-head{border-bottom:1px solid var(--line); background:var(--panel); position:sticky; top:0; z-index:10}
.head-inner{display:flex; align-items:center; justify-content:space-between; gap:28px; min-height:64px; padding:10px 0; flex-wrap:wrap}
.brand{font-family:'Oswald',sans-serif; font-weight:700; font-size:1.4rem; letter-spacing:.5px; color:var(--ink); text-transform:uppercase; white-space:nowrap; flex-shrink:0}
.brand span{color:var(--accent)}
.main-nav{display:flex; align-items:center; gap:28px; flex-wrap:wrap; row-gap:6px}
.main-nav a{color:var(--muted); font-weight:500; font-size:.9rem; white-space:nowrap; border-bottom:2px solid transparent; padding-bottom:3px; transition:color .15s ease, border-color .15s ease}
.main-nav a:hover{color:var(--ink); text-decoration:none; border-bottom-color:var(--accent)}

/* ---- Hamburger toggle (mobile only; hidden on desktop) ---- */
.nav-toggle{display:none; background:none; border:0; color:var(--ink); cursor:pointer; font-size:1.6rem; line-height:1; padding:6px; margin-left:auto}

/* ---- Shop dropdown ---- */
.nav-dropdown{position:relative; display:inline-block}
.main-nav .nav-shop{display:inline-flex; align-items:center; gap:6px; cursor:pointer; line-height:1; color:var(--ink); font-weight:600; border-bottom-color:var(--accent)}
.nav-shop .caret{font-size:.7em; color:var(--accent); transition:transform .15s ease}
.nav-dropdown:hover .caret{transform:rotate(180deg)}
.nav-menu{
  position:absolute; top:100%; left:0; min-width:210px;
  background:var(--panel-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:6px; margin-top:8px; display:none; flex-direction:column; z-index:50;
  box-shadow:0 10px 30px rgba(0,0,0,.45);
}
/* Bridge the gap so hover doesn't drop when moving cursor down */
.nav-dropdown::after{content:""; position:absolute; top:100%; left:0; right:0; height:10px}
.nav-dropdown:hover .nav-menu, .nav-dropdown:focus-within .nav-menu{display:flex}
.nav-menu a{
  display:block; padding:9px 12px; border-radius:6px; color:var(--muted);
  white-space:nowrap; font-size:.9rem;
}
.nav-menu a:hover{background:var(--panel); color:var(--accent-2); text-decoration:none}

/* ---- Cart link: divider + item count ---- */
.nav-cart{display:inline-flex; align-items:center; gap:8px; padding-left:28px; border-left:1px solid var(--line); line-height:1}
.cart-count{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:20px; height:20px; padding:0 6px; border-radius:20px;
  background:var(--accent); color:#fff; font-size:.72rem; font-weight:700;
}
.site-foot{margin-top:48px; border-top:1px solid var(--line); padding:30px 0 0; color:var(--muted); font-size:.9rem}
.foot-mark{display:block; width:48px; height:48px; border-radius:11px; margin:0 0 14px}
.foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:36px; padding-bottom:22px}
.foot-col{display:flex; flex-direction:column; gap:8px}
.foot-col h4{font-family:'Oswald',sans-serif; text-transform:uppercase; letter-spacing:.5px; font-size:.95rem; color:var(--ink); margin:0 0 6px}
.foot-col a{color:var(--muted)}
.foot-col a:hover{color:var(--accent-2)}
.foot-col a.foot-cta{display:inline-block; padding:9px 18px; border:1px solid var(--accent); border-radius:8px; color:var(--accent-2); font-weight:600; transition:background .15s ease, color .15s ease}
.foot-col a.foot-cta:hover{background:var(--accent); color:#fff}
.foot-logo{font-family:'Oswald',sans-serif; font-weight:700; font-size:1.3rem; text-transform:uppercase; color:var(--ink)}
.foot-logo span{color:var(--accent)}
.foot-brand p{margin:6px 0}
.foot-parent a{color:var(--accent-2)}
.foot-bottom{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px;
  border-top:1px solid var(--line); padding:18px 0; font-size:.85rem}
.foot-bottom a{color:var(--accent-2)}

/* Info pages + checkout payment notice */
.page-prose{max-width:720px; line-height:1.7}
.page-prose h2{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:1.15rem; margin:26px 0 8px}
.page-prose p{margin:0 0 14px}
.edit-note{color:var(--accent-2); font-size:.85rem; font-style:italic; border-left:3px solid var(--accent); padding-left:12px}
.pay-notice{font-size:.82rem; color:var(--muted); background:var(--panel); border:1px solid var(--line); border-radius:8px; padding:10px 12px; margin-top:10px}

@media (max-width:980px){ .foot-grid{grid-template-columns:1fr 1fr; gap:28px} }
@media (max-width:768px){ .foot-grid{grid-template-columns:1fr; gap:24px} }

/* ---------- hero ---------- */
.hero{padding:64px 0 40px; border-bottom:1px solid var(--line); margin-bottom:40px}
/* Image-backed hero: full-bleed photo with a dark gradient so text stays readable */
.hero.hero-image{
  position:relative; background-size:cover; background-position:center;
  border-bottom:none; border-radius:var(--radius); overflow:hidden;
  padding:0; margin:18px 0 40px; min-height:380px;
  display:flex; align-items:center;
}
.hero.hero-image::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(10,12,14,.92) 0%, rgba(10,12,14,.75) 45%, rgba(10,12,14,.35) 100%);
}
.hero.hero-image .hero-content{position:relative; z-index:1; padding:48px; max-width:620px}
.hero.hero-image .hero-sub{color:#d7dbe0}
.eyebrow{text-transform:uppercase; letter-spacing:2px; font-size:.78rem; color:var(--accent); font-weight:600; margin:0 0 14px}
.hero-title{font-family:'Oswald',sans-serif; font-weight:700; font-size:clamp(1.7rem,4.2vw,2.9rem); line-height:1.08; margin:0 0 16px; text-transform:uppercase}
.hero-sub{max-width:560px; color:var(--muted); font-size:1.1rem; margin:0 0 26px}
@media (min-width:980px){ .hero-title{white-space:nowrap} }

/* ---------- buttons ---------- */
.btn{display:inline-block; padding:11px 20px; border-radius:var(--radius); border:1px solid var(--line);
  background:var(--panel-2); color:var(--ink); font-weight:600; cursor:pointer; font-size:.95rem}
.btn:hover{text-decoration:none; border-color:var(--muted)}
.btn-primary{background:var(--accent); border-color:var(--accent); color:#fff}
.btn-primary:hover{background:var(--accent-2); border-color:var(--accent-2)}
.btn-block{display:block; width:100%; text-align:center}

/* ---------- grids / cards ---------- */
.section-head{font-family:'Oswald',sans-serif; text-transform:uppercase; letter-spacing:.5px; font-size:1.5rem; margin:36px 0 18px}
.grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:18px}
.cat-card{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; min-height:120px;
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); font-family:'Oswald',sans-serif;
  text-transform:uppercase; letter-spacing:.5px; color:var(--ink); padding:22px 18px; text-align:center;
  transition:border-color .15s ease, transform .15s ease}
.cat-card:hover{border-color:var(--accent); transform:translateY(-2px); text-decoration:none}
.cat-icon{font-size:2rem; line-height:1; color:var(--accent); transition:color .15s ease}
.cat-card:hover .cat-icon{color:var(--accent-2)}
.prod-card{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; color:var(--ink); display:flex; flex-direction:column; transition:border-color .15s ease}
.prod-card:hover{border-color:var(--accent)}
.prod-card-link{display:flex; flex-direction:column; color:var(--ink)}
.prod-card-link:hover{text-decoration:none}
.prod-img{aspect-ratio:1/1; background:#0e1012 center/cover no-repeat; border-bottom:1px solid var(--line)}
.prod-body{padding:14px}
.prod-body h3{margin:0 0 6px; font-size:1rem; font-weight:600}
.prod-actions{display:flex; gap:8px; padding:0 12px 12px; margin-top:auto}
.prod-actions .btn, .prod-actions .add-form{flex:1; min-width:0}
.prod-actions .add-form{margin:0}
.prod-actions .add-form .btn-primary{width:100%}
.btn-sm{padding:7px 6px; font-size:.78rem; text-align:center; white-space:nowrap; line-height:1.2}
.price{color:var(--accent-2); font-weight:700; margin:0}
.price-lg{font-size:1.6rem}

/* ---------- product detail ---------- */
.crumbs{color:var(--muted); font-size:.88rem; margin:18px 0}
.crumbs a{color:var(--muted)}
.product-detail{display:grid; grid-template-columns:1fr 1fr; gap:36px; margin-top:10px}
.product-media{aspect-ratio:1/1; background:#0e1012 center/cover no-repeat; border:1px solid var(--line); border-radius:var(--radius)}
.product-info h1{font-family:'Oswald',sans-serif; text-transform:uppercase; margin:0 0 10px; font-size:2rem}
.desc{color:var(--muted); margin:18px 0}
.buy-form{display:flex; flex-wrap:wrap; gap:14px; align-items:end; margin-top:10px}
.ship-note{color:var(--muted); font-size:.85rem; margin-top:14px}

/* ---------- forms ---------- */
.field{display:flex; flex-direction:column; gap:6px; margin-bottom:14px}
.field>span{font-size:.85rem; color:var(--muted); font-weight:500}
.field input,.field select,.field textarea{
  background:var(--panel); border:1px solid var(--line); color:var(--ink);
  padding:10px 12px; border-radius:8px; font:inherit; width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--accent); border-color:var(--accent)}
.field.qty{max-width:90px}
.buy-form{display:flex; align-items:flex-end; gap:12px; flex-wrap:wrap}
.buy-form .field{margin-bottom:0}
.buy-form .btn-primary{height:42px}
.buy-form .field.qty input, .buy-form .field select{height:42px; box-sizing:border-box}
.field-row{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; align-items:end}

/* ---------- tables ---------- */
.table{width:100%; border-collapse:collapse; margin:14px 0}
.table th,.table td{text-align:left; padding:10px 12px; border-bottom:1px solid var(--line)}
.table th{color:var(--muted); font-weight:600; font-size:.85rem; text-transform:uppercase; letter-spacing:.5px}
.inline{display:inline}
.qty-input{width:64px; background:var(--panel); border:1px solid var(--line); color:var(--ink); padding:6px; border-radius:6px}
.link-btn{background:none; border:none; color:var(--accent-2); cursor:pointer; font:inherit; padding:0}
.link-btn.danger,.danger{color:var(--err)}

/* ---------- cart / checkout ---------- */
.cart-summary{margin-top:20px; text-align:right}
.cart-actions{display:flex; gap:12px; justify-content:flex-end; margin-top:8px; flex-wrap:wrap}
.grand{font-size:1.2rem}
.checkout-grid{display:grid; grid-template-columns:1.4fr 1fr; gap:30px; align-items:start}
.order-summary,.card{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:20px}
.sum-line{display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid var(--line); font-size:.92rem}
.sum-line.total{font-weight:700; border-bottom:none; font-size:1.1rem; margin-top:6px}
.confirm .table{max-width:640px}

/* ---------- flash ---------- */
.flash{padding:12px 16px; border-radius:8px; margin:14px 0; font-size:.92rem}
.flash-ok{background:rgba(59,167,118,.15); border:1px solid var(--ok); color:#bfe9d4}
.flash-err{background:rgba(216,85,63,.15); border:1px solid var(--err); color:#f2c3b9}

/* ============================================================
   ADMIN
   ============================================================ */
body.admin{display:flex; min-height:100vh}
.admin-side{width:210px; background:var(--panel); border-right:1px solid var(--line); padding:22px 0; flex-shrink:0}
.admin-brand{font-family:'Oswald',sans-serif; text-transform:uppercase; font-weight:600; padding:0 22px 18px; color:var(--accent)}
.admin-side nav{display:flex; flex-direction:column}
.admin-side nav a{color:var(--muted); padding:11px 22px; font-weight:500}
.admin-side nav a:hover{color:var(--ink); background:var(--panel-2); text-decoration:none}
.admin-main{flex:1; padding:30px 44px; max-width:1500px}
.admin-h1{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:1.7rem; margin:0 0 22px}
.admin-h2{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:1.2rem; margin:30px 0 12px}
.admin-head-row{display:flex; justify-content:space-between; align-items:center}
.stat-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:16px; margin-bottom:10px}
.stat{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:18px; display:flex; flex-direction:column; gap:6px}
.stat.highlight{border-color:var(--accent)}
.stat-num{font-family:'Oswald',sans-serif; font-size:1.8rem; font-weight:600}
.stat-label{color:var(--muted); font-size:.82rem; text-transform:uppercase; letter-spacing:.5px}
.badge{display:inline-block; padding:3px 9px; border-radius:20px; font-size:.74rem; font-weight:600; text-transform:uppercase; letter-spacing:.5px; background:var(--panel-2); border:1px solid var(--line)}
.badge-Paid{color:#bfe9d4; border-color:var(--ok)}
.badge-Fulfilled{color:#bcd4f2; border-color:#4a78b0}
.badge-PendingPayment{color:#f2d9b9; border-color:#b08a4a}
.badge-Cancelled,.badge-Refunded{color:#f2c3b9; border-color:var(--err)}
.filter-row,.check-row{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:16px}
.chip{padding:6px 14px; border:1px solid var(--line); border-radius:20px; color:var(--muted); font-size:.85rem}
.chip:hover{border-color:var(--accent); color:var(--ink); text-decoration:none}
.detail-cols{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px}
.card h2{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:1.1rem; margin:0 0 12px}
.profit{font-size:1.05rem}
.back-link{display:inline-block; margin-bottom:12px; color:var(--muted)}
.admin-form{max-width:840px}
.status-form{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.status-form select,.status-form input{background:var(--panel); border:1px solid var(--line); color:var(--ink); padding:9px; border-radius:8px}
.check{display:flex; align-items:center; gap:8px}
.thumb-preview{max-width:120px; border-radius:8px; border:1px solid var(--line); margin:8px 0}
.login-box{max-width:360px; margin:90px auto; background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:32px}
.login-box h1{font-family:'Oswald',sans-serif; text-transform:uppercase; margin:0 0 20px}

/* ---------- responsive ---------- */
@media (max-width:768px){
  .product-detail,.checkout-grid,.detail-cols{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr 1fr}
  body.admin{flex-direction:column}
  .admin-side{width:100%; border-right:none; border-bottom:1px solid var(--line); padding:14px 0}
  .admin-side nav{flex-direction:row; flex-wrap:wrap}
  .admin-main{padding:20px}

  /* ---- Mobile nav: collapse into a hamburger menu ---- */
  .nav-toggle{display:block}
  .main-nav{
    display:none; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0; row-gap:0;
    background:var(--panel); border-bottom:1px solid var(--line);
    box-shadow:0 12px 30px rgba(0,0,0,.45); padding:8px 0; z-index:40;
  }
  .main-nav.open{display:flex}
  .main-nav > a, .main-nav .nav-shop{
    display:flex; align-items:center; padding:14px 20px; font-size:1rem;
    border-bottom:0; border-radius:0; min-height:48px;   /* comfortable tap targets */
  }
  .main-nav > a:hover, .main-nav .nav-shop:hover{border-bottom-color:transparent; background:var(--panel-2)}
  /* Shop categories: always visible, indented under Shop (no hover on touch) */
  .nav-dropdown{display:block; position:static}
  .nav-shop .caret{display:none}
  .nav-menu{
    position:static; display:flex; box-shadow:none; border:0; margin:0;
    padding:0; min-width:0; background:transparent;
  }
  .nav-menu a{padding:11px 20px 11px 36px; font-size:.95rem; border-radius:0}
  .nav-cart{padding:14px 20px; border-left:0; min-height:48px}
  .table{font-size:.9rem; display:block; overflow-x:auto; white-space:nowrap; -webkit-overflow-scrolling:touch}
}

/* ---------- SEO form box ---------- */
.seo-box{border:1px solid var(--line); border-radius:var(--radius); padding:16px 18px; margin:18px 0; background:var(--panel)}
.seo-box legend{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:.95rem; letter-spacing:.5px; color:var(--accent-2); padding:0 8px}
.seo-hint{margin:0 0 12px; font-size:.85rem}
.seo-box .field>span em{color:var(--muted); font-style:normal; font-weight:400; font-size:.8rem}

/* ---------- Validation summary: only an alert when it has real errors ---------- */
.field-validation-valid,
.validation-summary-valid{display:none}
.validation-summary-errors{
  background:rgba(216,85,63,.15); border:1px solid var(--err); color:#f2c3b9;
  padding:12px 16px; border-radius:8px; margin:14px 0; font-size:.92rem;
}
.validation-summary-errors ul{margin:0; padding-left:18px}
.field-validation-error{color:#f2c3b9; font-size:.85rem}

/* ---------- YouTube video section ---------- */
.video-section{margin-top:50px}
.video-head{display:flex; align-items:baseline; justify-content:space-between; flex-wrap:wrap; gap:10px}
.video-channel{display:inline-flex; align-items:center; gap:6px; color:var(--muted); font-size:.9rem}
.video-channel:hover{color:var(--accent-2); text-decoration:none}
.video-channel .ti{color:#ff0000; font-size:1.1rem}
.video-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:18px; margin-top:14px}
.video-card{cursor:pointer; background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; transition:border-color .15s ease}
.video-card:hover{border-color:var(--accent)}
.video-card:focus{outline:2px solid var(--accent); outline-offset:2px}
.video-thumb{position:relative; aspect-ratio:16/9; background:#0e1012 center/cover no-repeat; display:flex; align-items:center; justify-content:center}
.video-thumb iframe{position:absolute; inset:0; border:0}
.video-play{display:flex; align-items:center; justify-content:center; width:54px; height:54px; border-radius:50%;
  background:rgba(226,87,30,.92); color:#fff; font-size:1.5rem; transition:transform .15s ease}
.video-card:hover .video-play{transform:scale(1.1)}
.video-title{margin:0; padding:10px 12px; font-size:.88rem; line-height:1.3;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}

/* ---------- Trust / benefits strip ---------- */
.trust-strip{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:6px 0 30px;
  padding:18px; background:var(--panel); border:1px solid var(--line); border-radius:var(--radius)}
.trust-item{display:flex; align-items:center; justify-content:center; gap:10px; text-align:center; color:var(--ink); font-size:.92rem}
.trust-item .ti{font-size:1.4rem; color:var(--accent); flex-shrink:0}
@media (max-width:768px){
  .trust-strip{grid-template-columns:repeat(2,1fr); gap:16px; font-size:.85rem}
}

/* ---------- Admin: category icon picker + stacked checks ---------- */
.check-stack{display:flex; flex-direction:column; gap:10px; margin:6px 0 16px}
.check-stack .check{display:flex; align-items:center; gap:8px}
.icon-box .icon-preview-row{display:flex; align-items:center; gap:12px; margin-bottom:14px}
.icon-preview{display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px;
  border-radius:8px; background:var(--panel-2); border:1px solid var(--line); color:var(--accent); font-size:1.6rem; flex-shrink:0}
.icon-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(48px,1fr)); gap:8px}
.icon-pick{display:flex; align-items:center; justify-content:center; height:48px; cursor:pointer;
  background:var(--panel-2); border:1px solid var(--line); border-radius:8px; color:var(--muted); font-size:1.3rem; transition:all .12s ease}
.icon-pick:hover{border-color:var(--muted); color:var(--ink)}
.icon-pick.selected{border-color:var(--accent); color:var(--accent); background:rgba(226,87,30,.12)}

/* ---------- Admin product list: toolbar + sortable table ---------- */
.list-toolbar{display:flex; align-items:center; gap:12px; margin:16px 0 18px; flex-wrap:wrap}
.search-wrap{position:relative; flex:1; min-width:220px; max-width:380px}
.search-wrap .ti{position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--muted)}
.search-wrap input{width:100%; padding:9px 12px 9px 36px; background:var(--panel-2); border:1px solid var(--line);
  border-radius:8px; color:var(--ink); font-size:.92rem}
.search-wrap input:focus{outline:none; border-color:var(--accent)}
.filter-select{padding:9px 12px; background:var(--panel-2); border:1px solid var(--line); border-radius:8px;
  color:var(--ink); font-size:.9rem; cursor:pointer}
.filter-select:focus{outline:none; border-color:var(--accent)}
.result-count{margin-left:auto; color:var(--muted); font-size:.85rem}
.sortable-th{cursor:pointer; user-select:none; white-space:nowrap}
.sortable-th:hover{color:var(--accent-2)}
.sort-ind{color:var(--accent); font-size:.8em}
.no-results{text-align:center; color:var(--muted); padding:24px}
.row-actions{white-space:nowrap}

/* ---------- Admin: gallery manager (drag-drop) ---------- */
.gallery-note{font-style:italic}
.drop-zone{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  padding:28px; border:2px dashed var(--line); border-radius:10px; color:var(--muted); cursor:pointer;
  text-align:center; transition:all .15s ease; background:var(--panel-2)}
.drop-zone .ti{font-size:1.8rem; color:var(--muted)}
.drop-zone:hover{border-color:var(--muted)}
.drop-zone.dragover{border-color:var(--accent); color:var(--accent-2); background:rgba(226,87,30,.08)}
.drop-zone.uploading{opacity:.6; pointer-events:none}
.drop-zone .link-like{color:var(--accent-2); text-decoration:underline}
.gallery-grid{display:flex; flex-wrap:wrap; gap:10px; margin-top:14px}
.gallery-thumb{position:relative; width:104px; height:104px; border-radius:8px; overflow:hidden;
  border:1px solid var(--line); background:#0e1012; cursor:grab}
.gallery-thumb img{width:100%; height:100%; object-fit:cover; display:block}
.gallery-thumb.dragging{opacity:.4}
.gallery-thumb .thumb-del{position:absolute; top:4px; right:4px; width:22px; height:22px; border:none;
  border-radius:50%; background:rgba(0,0,0,.65); color:#fff; font-size:1rem; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center}
.gallery-thumb .thumb-del:hover{background:var(--accent)}
.gallery-thumb .main-badge{position:absolute; bottom:0; left:0; right:0; background:var(--accent); color:#fff;
  font-size:.65rem; text-align:center; padding:2px; text-transform:uppercase; letter-spacing:.5px; display:none}
.gallery-thumb.is-main .main-badge{display:block}

/* ---------- Storefront: product gallery viewer ---------- */
.gallery-thumbs{display:flex; gap:8px; margin-top:10px; flex-wrap:wrap}
.gallery-thumb-btn{width:64px; height:64px; border-radius:8px; border:1px solid var(--line);
  background:#0e1012 center/cover no-repeat; cursor:pointer; padding:0; transition:border-color .15s ease}
.gallery-thumb-btn:hover{border-color:var(--muted)}
.gallery-thumb-btn.active{border-color:var(--accent)}

/* ---------- Related products (admin picker + storefront) ---------- */
.related-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:6px 16px; max-height:260px; overflow-y:auto; padding:4px 2px}
.related-pick{display:flex; align-items:center; gap:8px; font-size:.88rem; color:var(--ink)}
.related-pick em{color:var(--muted); font-style:normal; font-size:.82rem}
.related-section{margin-top:50px; border-top:1px solid var(--line); padding-top:30px}

/* ---------- Category page intro + toolbar ---------- */
.cat-intro{margin:6px 0 22px; padding-bottom:22px; border-bottom:1px solid var(--line)}
.cat-intro-head{display:flex; align-items:center; gap:14px}
.cat-intro-icon{font-size:2rem; color:var(--accent); flex-shrink:0}
.cat-intro-head h1{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:1.9rem; margin:0; letter-spacing:.5px}
.cat-intro-desc{max-width:680px; color:var(--muted); margin:12px 0 0; line-height:1.6}
.cat-toolbar{display:flex; align-items:center; justify-content:space-between; gap:12px; margin:0 0 18px; flex-wrap:wrap}
.cat-count{color:var(--muted); font-size:.9rem}
.cat-sort{display:inline-flex; align-items:center; gap:8px; color:var(--muted); font-size:.9rem}
.cat-sort select{padding:8px 10px; background:var(--panel-2); border:1px solid var(--line); border-radius:8px; color:var(--ink); font-size:.88rem; cursor:pointer}
.cat-sort select:focus{outline:none; border-color:var(--accent)}

/* ---------- Admin gallery management ---------- */
.gallery-admin-list{display:flex; flex-direction:column; gap:16px; margin-top:20px; max-width:840px}
.gallery-admin-row{display:flex; gap:16px; background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:14px}
.gallery-admin-thumb{position:relative; width:160px; height:120px; flex-shrink:0; border-radius:8px; background:#0e1012 center/cover no-repeat; border:1px solid var(--line)}
.gallery-admin-thumb .thumb-del{position:absolute; top:6px; right:6px; width:24px; height:24px; border:none; border-radius:50%; background:rgba(0,0,0,.65); color:#fff; cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center}
.gallery-admin-thumb .thumb-del:hover{background:var(--accent)}
.gallery-admin-fields{flex:1; display:flex; flex-direction:column; gap:8px; min-width:0}

/* ---------- Public gallery page ---------- */
.gallery-grid-public{columns:3; column-gap:16px}
.gallery-card{margin:0 0 16px; break-inside:avoid; background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden}
.gallery-img-wrap{position:relative; line-height:0}
.gallery-img-wrap img{width:100%; display:block; cursor:zoom-in}
/* Zoom button, top-right */
.gallery-zoom-btn{position:absolute; top:10px; right:10px; width:36px; height:36px; border:none; border-radius:50%;
  background:rgba(10,12,14,.55); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; opacity:0; transition:opacity .15s ease}
.gallery-img-wrap:hover .gallery-zoom-btn{opacity:1}
/* Buy button overlaid inside the image, bottom-left, semi-transparent until hover */
.gallery-buy-overlay{position:absolute; left:12px; bottom:12px; padding:13px 22px; border-radius:9px;
  background:rgba(226,87,30,.62); color:#fff; font-family:'Oswald',sans-serif; text-transform:uppercase;
  letter-spacing:.6px; font-size:.86rem; font-weight:600; backdrop-filter:blur(3px); transition:background .15s ease}
.gallery-buy-overlay:hover{background:rgba(226,87,30,.92); text-decoration:none; color:#fff}
.gallery-card figcaption{padding:12px 14px}
.gallery-caption{color:var(--ink); font-size:.92rem; line-height:1.4}
@media (max-width:900px){ .gallery-grid-public{columns:2} .gallery-zoom-btn{opacity:1} }
@media (max-width:560px){ .gallery-grid-public{columns:1} }

/* Lightbox / zoom overlay */
.gallery-lightbox{position:fixed; inset:0; background:rgba(8,9,11,.92); z-index:200; display:none;
  align-items:center; justify-content:center; padding:30px}
.gallery-lightbox.open{display:flex}
.gallery-lightbox figure{margin:0; max-width:92vw; max-height:92vh; display:flex; flex-direction:column; align-items:center; gap:12px}
.gallery-lightbox img{max-width:92vw; max-height:82vh; border-radius:8px; object-fit:contain}
.gallery-lightbox figcaption{color:#d7dbe0; font-size:.95rem; text-align:center}
.lightbox-close{position:absolute; top:20px; right:26px; background:none; border:none; color:#fff; font-size:2.4rem;
  line-height:1; cursor:pointer; opacity:.8}
.lightbox-close:hover{opacity:1}

/* ---------- AI SEO + bulk edit admin ---------- */
.seo-ai-row{display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin-bottom:10px}
.seo-ai-row .seo-hint{margin:0; flex:1}
#genSeoBtn{white-space:nowrap; flex-shrink:0}
.bulk-table{width:100%; border-collapse:collapse; font-size:.88rem}
.bulk-table th,.bulk-table td{padding:7px 8px; border-bottom:1px solid var(--line); text-align:left}
.bulk-table th{color:var(--muted); font-weight:600; position:sticky; top:0; background:var(--panel)}
.bulk-table input[type=text],.bulk-table input[type=number],.bulk-table select{width:100%; padding:6px 8px; background:var(--panel-2); border:1px solid var(--line); border-radius:6px; color:var(--ink)}
.bulk-table input[type=number]{max-width:100px}
.bulk-table .bulk-name input{min-width:200px}
.bulk-table td.center{text-align:center}
.bulk-actions{display:flex; gap:10px; align-items:center; margin:18px 0; position:sticky; bottom:0; background:var(--bg); padding:12px 0}

/* ---------- Admin settings page ---------- */
.settings-card{max-width:680px; margin-bottom:24px}
.settings-card legend{display:flex; align-items:center; gap:8px}
.key-set{color:#3ea76a; font-style:normal; font-size:.82rem; margin-left:8px}
.key-unset{color:var(--muted); font-style:normal; font-size:.82rem; margin-left:8px}
.settings-soon{background:var(--panel); border:1px dashed var(--line); border-radius:var(--radius); padding:18px 20px}
.settings-soon h2{font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:1.1rem; margin:0 0 8px}

/* inline label + AI button row for description */
.field-label-inline{color:var(--muted); font-size:.82rem; font-weight:600}
.desc-field{margin-top:4px}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0}

/* ---------- Product health check ---------- */
.health-summary{display:flex; gap:9px; align-items:center; flex-wrap:wrap; padding:9px 14px; border-radius:8px; margin:2px 0 18px; font-size:.88rem; line-height:1.3}
.health-summary i{font-size:1.05rem; flex-shrink:0}
.health-summary.has-gaps{background:rgba(226,87,30,.10); border:1px solid rgba(226,87,30,.28); color:#f1b08f}
.health-summary.has-gaps i{color:var(--accent)}
.health-summary.has-gaps strong{color:#fff}
.health-summary.all-good{background:rgba(62,167,106,.10); border:1px solid rgba(62,167,106,.28); color:#9fd9b8}
.health-summary.all-good i{color:#5fcf90}
.health-summary .muted{font-size:.86rem}
.health-badge{display:inline-block; padding:3px 9px; border-radius:20px; font-size:.78rem; font-weight:600; white-space:nowrap; cursor:default}
.health-badge.ok{background:rgba(62,167,106,.16); color:#5fcf90}
.health-badge.warn{background:rgba(226,87,30,.18); color:#f1925f}
.hidden-by-health{display:none !important}
.filter-select{margin-left:8px}

/* ---------- Per-product issues notice (edit page) ---------- */
.form-issues{background:rgba(226,87,30,.09); border:1px solid rgba(226,87,30,.30); border-radius:8px; padding:12px 16px; margin-bottom:20px; max-width:840px}
.form-issues-head{display:flex; align-items:center; gap:8px; color:#f1b08f; font-weight:600; font-size:.92rem}
.form-issues-head i{color:var(--accent)}
.form-issues ul{margin:8px 0 0; padding-left:30px; color:var(--ink); font-size:.9rem}
.form-issues li{margin:2px 0}
.form-issues-note{margin:8px 0 0; color:var(--muted); font-size:.82rem}

/* dismiss buttons in the issues notice */
.form-issues ul{list-style:none; padding-left:0}
.form-issues li{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:5px 0; border-bottom:1px solid rgba(226,87,30,.15)}
.form-issues li:last-child{border-bottom:none}
.dismiss-issue{background:transparent; border:1px solid rgba(226,87,30,.45); color:#f1925f; border-radius:6px; padding:3px 12px; font-size:.78rem; cursor:pointer; white-space:nowrap}
.dismiss-issue:hover{background:rgba(226,87,30,.18)}
.dismiss-issue:disabled{opacity:.5; cursor:default}

/* ---- Shop grid/list view toggle ------------------------------------- */
.cat-controls{display:inline-flex; align-items:center; gap:14px; flex-wrap:wrap}

.view-toggle{display:inline-flex; border:1px solid var(--line); border-radius:8px; overflow:hidden}
.view-btn{display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px;
    background:var(--panel-2); color:var(--muted); border:0; cursor:pointer; font-size:1.15rem;
    transition:background .15s ease, color .15s ease}
.view-btn + .view-btn{border-left:1px solid var(--line)}
.view-btn:hover{color:var(--ink)}
.view-btn.is-active{background:var(--accent); color:#fff}

/* product description: hidden in grid, shown in list view only */
.prod-desc{margin:8px 0 0; color:var(--muted); font-size:.88rem; line-height:1.45; display:none}

/* List view: reshape the existing cards into full-width rows.
   .grid.as-list out-specifies .grid, so no !important needed. */
.grid.as-list{display:flex; flex-direction:column; gap:14px}
.grid.as-list .prod-card{flex-direction:row; align-items:stretch}
.grid.as-list .prod-card-link{flex-direction:row; flex:1 1 auto; align-items:stretch; min-width:0}
.grid.as-list .prod-img{width:150px; min-width:150px; aspect-ratio:1/1; border-bottom:none; border-right:1px solid var(--line)}
.grid.as-list .prod-body{flex:1; display:flex; flex-direction:column; justify-content:center; min-width:0}
.grid.as-list .prod-desc{display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.grid.as-list .prod-actions{flex-direction:column; justify-content:center; gap:8px; width:170px; min-width:170px; padding:14px; margin:0}
.grid.as-list .prod-actions .btn, .grid.as-list .prod-actions .add-form{flex:initial; width:100%}

@media (max-width:560px){
    /* on narrow screens keep list rows readable */
    .grid.as-list .prod-img{width:104px; min-width:104px}
    .grid.as-list .prod-actions{width:130px; min-width:130px; padding:10px}
}

/* ---- Admin gallery management --------------------------------------- */
.gallery-admin-summary{margin:18px 0 10px; font-size:.9rem}
.gallery-admin-summary strong{color:var(--ink)}

.gallery-badges{display:flex; flex-wrap:wrap; gap:6px; margin-bottom:8px}
.g-badge{display:inline-flex; align-items:center; gap:5px; font-size:.72rem; padding:3px 9px;
    border-radius:999px; border:1px solid var(--line); color:var(--muted); background:var(--panel-2)}
.g-badge i{font-size:.85rem}
.g-badge-hidden{color:var(--err); border-color:rgba(216,85,63,.45)}
.g-badge-linked{color:var(--accent-2); border-color:rgba(240,138,75,.35)}

/* hidden items read as muted at a glance */
.gallery-admin-row.is-hidden{opacity:.6}
.gallery-admin-row.is-hidden .gallery-admin-thumb{filter:grayscale(.55)}

/* ---- Checkout polish: matching cards + summary thumbnails ----------- */
/* Box the shipping form to match the order-summary panel so the two columns
   line up as equal cards instead of a bare form beside a box. */
.checkout-form{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:20px}
.checkout-form > h2:first-child,
.order-summary > h2:first-child{margin-top:0}
.checkout-grid h2{font-size:1.15rem}

.sum-items{margin-bottom:6px}
.sum-item{display:flex; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--line)}
.sum-thumb{width:48px; height:48px; min-width:48px; object-fit:cover; border-radius:8px;
    border:1px solid var(--line); background:var(--panel-2)}
.sum-thumb-empty{display:inline-block}
.sum-item-info{display:flex; flex-direction:column; gap:2px; flex:1; min-width:0}
.sum-item-name{font-size:.9rem; line-height:1.3}
.sum-item-qty{font-size:.78rem; color:var(--muted)}
.sum-item-price{font-size:.92rem; white-space:nowrap; font-weight:500}
.sum-tax-note{font-size:.76rem; margin:12px 0 0}

/* cart "sales tax: calculated at checkout" — informational, not a figure */
.cart-tax-note{color:var(--muted)}
.cart-tax-note strong{font-weight:500; color:var(--muted)}
