/* ===== Harlan storefront ===== */
.shop-head{background:linear-gradient(180deg,#fff,var(--bg-2));border-bottom:1px solid var(--line);padding:48px 28px 30px}
.shop-head-inner{max-width:var(--maxw);margin:0 auto}
.shop-head .breadcrumb{margin-bottom:12px}
.shop-head h1{font-size:clamp(30px,4vw,46px)}
.shop-head .sub{color:var(--slate);font-size:18px;margin-top:10px}
.shop-tools{display:flex;gap:14px;margin-top:24px;flex-wrap:wrap;align-items:center}
.search{flex:1;min-width:240px;position:relative}
.search input{width:100%;padding:14px 16px 14px 46px;border:1px solid var(--line);border-radius:10px;font-size:15px;font-family:'Inter',sans-serif;background:#fff}
.search input:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 3px rgba(37,99,168,.12)}
.search svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--slate)}
.cart-btn{display:inline-flex;align-items:center;gap:9px;background:var(--navy);color:#fff;border:0;border-radius:10px;padding:13px 20px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;font-size:15px}
.cart-btn:hover{background:var(--navy-2)}
.cart-btn .badge{background:var(--amber);color:var(--navy);border-radius:999px;min-width:22px;height:22px;display:none;align-items:center;justify-content:center;font-size:13px;font-weight:700;padding:0 6px}

.shop-layout{max-width:var(--maxw);margin:0 auto;padding:30px 28px 90px;display:grid;grid-template-columns:210px 1fr;gap:34px}
.cats{position:sticky;top:92px;align-self:start}
.cats .ct{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--slate);margin-bottom:8px}
.cats button{display:block;width:100%;text-align:left;background:none;border:0;padding:10px 12px;border-radius:8px;font-family:'Inter',sans-serif;font-size:15px;color:var(--slate);cursor:pointer}
.cats button:hover{background:var(--bg-2);color:var(--navy)}
.cats button.active{background:var(--navy);color:#fff;font-weight:600}
.res-count{color:var(--slate);font-size:14px;margin-bottom:14px}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.prod{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px;display:flex;flex-direction:column;transition:.15s;min-height:210px}
.prod:hover{box-shadow:0 16px 36px -20px rgba(14,34,54,.32);transform:translateY(-3px);border-color:#d8dfe8}
.prod .cat{font-size:11px;font-weight:700;color:var(--azure);text-transform:uppercase;letter-spacing:.05em}
.prod h3{font-size:17px;margin:7px 0 5px;color:var(--navy);line-height:1.2}
.prod .spec{color:var(--slate);font-size:14px;flex:1}
.prod .size{align-self:flex-start;margin:12px 0;font-size:12px;font-weight:600;color:var(--navy);background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:4px 10px}
.prod .add{margin-top:auto;background:var(--amber);color:var(--navy);border:0;border-radius:8px;padding:11px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif}
.prod .add:hover{background:var(--amber-d)}
.qty{margin-top:auto;display:flex;align-items:center;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.qty button{flex:none;width:44px;height:42px;border:0;background:var(--bg-2);font-size:18px;cursor:pointer;color:var(--navy)}
.qty button:hover{background:#e6ebf1}
.qty span{flex:1;text-align:center;font-weight:700;color:var(--navy)}
.empty{grid-column:1/-1;text-align:center;color:var(--slate);padding:50px 20px}

/* cart drawer */
.overlay{position:fixed;inset:0;background:rgba(14,34,54,.45);opacity:0;visibility:hidden;transition:.2s;z-index:60}
.overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:-460px;width:430px;max-width:92vw;height:100%;background:#fff;z-index:61;transition:right .25s ease;display:flex;flex-direction:column;box-shadow:-24px 0 70px rgba(14,34,54,.28)}
.drawer.open{right:0}
.drawer-head{padding:20px 22px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer-head h3{font-size:20px}
.drawer-close{background:none;border:0;font-size:26px;line-height:1;cursor:pointer;color:var(--slate)}
.drawer-body{flex:1;overflow:auto;padding:8px 22px}
.citem{padding:14px 0;border-bottom:1px solid var(--line-2)}
.citem .nm{font-weight:600;color:var(--navy);font-size:15px}
.citem .sz{color:var(--slate);font-size:13px;margin:2px 0 6px}
.citem .rm{background:none;border:0;color:#c0392b;cursor:pointer;font-size:13px;padding:0;font-weight:600}
.cart-empty{color:var(--slate);text-align:center;padding:50px 0;line-height:1.6}
.drawer-foot{border-top:1px solid var(--line);padding:18px 22px}
.drawer-foot p{font-size:13px;color:var(--slate);margin-bottom:12px}
.drawer-foot input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:8px;margin-bottom:10px;font-family:'Inter',sans-serif;font-size:14px}
.drawer-foot input:focus{outline:none;border-color:var(--azure)}

@media (max-width:860px){
  .shop-layout{grid-template-columns:1fr}
  .cats{position:static}.cats .ct{display:none}
  .cats{display:flex;gap:8px;overflow:auto;padding-bottom:6px}
  .cats button{white-space:nowrap;width:auto;border:1px solid var(--line)}
  .prod-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){ .prod-grid{grid-template-columns:1fr} }

/* ===== product detail ===== */
.pd{max-width:var(--maxw);margin:0 auto;padding:30px 28px 56px;display:grid;grid-template-columns:1fr 1fr;gap:48px}
.pd-visual{background:linear-gradient(160deg,var(--navy),var(--navy-2));border-radius:16px;min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;padding:34px;text-align:center;position:relative;overflow:hidden}
.pd-visual::after{content:"";position:absolute;width:340px;height:200px;right:-40px;top:-50px;background:radial-gradient(circle,rgba(232,163,23,.18),transparent 60%)}
.pd-visual .pcat{color:var(--amber);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:13px}
.pd-visual .pname{font-family:'Oswald';font-weight:700;font-size:34px;margin-top:10px;line-height:1.1}
.pd-visual .psize{margin-top:16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:9px 15px;font-size:14px}
.pd-info h1{font-size:clamp(26px,3.4vw,38px);margin-bottom:10px}
.pd-info .pspec{color:var(--slate);font-size:17px;margin-bottom:20px}
.pd-meta{list-style:none;padding:0;margin:0 0 24px;border-top:1px solid var(--line)}
.pd-meta li{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);font-size:15px}
.pd-meta li span:first-child{color:var(--slate)}
.pd-meta li span:last-child{font-weight:600;color:var(--navy)}
.pd-buy{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.pd-note{font-size:13px;color:var(--slate);margin-top:14px}
.pd-done{display:none;background:#e8f5ee;color:#1f8f5b;border:1px solid #bfe3cd;border-radius:8px;padding:12px 14px;margin-top:14px;font-weight:600;font-size:14px}
.pd-done a{color:#1f8f5b;text-decoration:underline}
.related{max-width:var(--maxw);margin:0 auto;padding:0 28px 80px}

/* ===== dashboard ===== */
.dash{max-width:var(--maxw);margin:0 auto;padding:30px 28px 70px}
.dash-banner{background:#e7f0fa;color:var(--azure);border:1px solid rgba(37,99,168,.2);border-radius:10px;padding:12px 16px;font-size:14px;font-weight:600;margin-bottom:24px}
.dash-head h1{font-size:clamp(26px,3.4vw,38px)}
.dash-head p{color:var(--slate);margin-top:6px}
.dash-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px}
.kpi .k{font-size:30px;font-weight:800;color:var(--navy);letter-spacing:-.02em}
.kpi .l{color:var(--slate);font-size:14px;margin-top:4px}
.dash-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:24px}
.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px}
.panel h3{font-size:17px;margin-bottom:16px}
.tank{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--line-2)}
.tank:last-child{border-bottom:0}
.tank .tname{flex:none;width:150px;font-weight:600;color:var(--navy);font-size:14px}
.tank .tbar{flex:1;height:10px;background:var(--line-2);border-radius:6px;overflow:hidden}
.tank .tbar span{display:block;height:100%;background:var(--azure);border-radius:6px}
.tank .tbar span.low{background:#d9822b}
.tank .tval{flex:none;width:46px;text-align:right;font-weight:700;font-size:14px;color:var(--navy)}
.ord{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line-2)}
.ord:last-child{border-bottom:0}
.ord .onm{font-weight:600;color:var(--navy);font-size:14px}
.ord .osub{color:var(--slate);font-size:13px}
.ord .reorder{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:8px 13px;font-weight:600;font-size:13px;cursor:pointer;color:var(--navy)}
.ord .reorder:hover{background:#e6ebf1}
.st-pill{font-size:12px;font-weight:600;padding:5px 11px;border-radius:20px;white-space:nowrap}
.st-pill.green{background:#e8f5ee;color:#1f8f5b}
.st-pill.blue{background:#e7f0fa;color:var(--azure)}
@media (max-width:860px){ .pd{grid-template-columns:1fr} .dash-grid{grid-template-columns:1fr} .dash-kpis{grid-template-columns:1fr} }

/* spec list */
.related .panel ul li{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:15px;color:var(--ink)}
.related .panel ul li:last-child{border-bottom:0}
.related .panel ul li span:first-child{color:var(--amber);font-weight:700}
