@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@500;600;700&family=Saira+Condensed:ital,wght@1,600;1,700&display=swap');
/* ===== The Vault Fashion Store — theme: orange & black (SPORTY) ===== */
:root{
  --orange:#ff7a00;
  --orange-dark:#e56e00;
  --black:#111111;
  --ink:#1c1c1c;
  --muted:#6b6b6b;
  --line:#e7e7e7;
  --bg:#fafafa;
  --card:#ffffff;
  --ok:#1f9d55;
  --warn:#e0a800;
  --danger:#d23b3b;
  --radius:12px;
  --shadow:0 6px 22px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Segoe UI',system-ui,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.5;
}
a{color:var(--orange-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:0 18px}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  border:none;border-radius:10px;padding:10px 18px;font-size:15px;font-weight:600;
  background:var(--orange);color:#fff;transition:.15s;text-decoration:none;
}
.btn:hover{background:var(--orange-dark);text-decoration:none}
.btn.black{background:var(--black)}
.btn.black:hover{background:#000}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--orange);color:var(--orange-dark);background:#fff}
.btn.sm{padding:6px 12px;font-size:13px;border-radius:8px}
.btn.danger{background:var(--danger)}
.btn.block{width:100%;justify-content:center}

/* ---- Storefront header ---- */
.topbar{background:var(--black);color:#ddd;font-size:13px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:40px;flex-wrap:wrap}
.topbar a{color:#ffb371}
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.site-header .container{display:flex;align-items:center;gap:22px;height:74px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;color:var(--black)}
.brand .mark{
  width:38px;height:38px;border-radius:9px;background:var(--orange);color:#000;
  display:grid;place-items:center;font-weight:900;font-size:20px;
}
.brand span.v{color:var(--orange)}
.nav{display:flex;gap:18px;margin-left:auto;align-items:center}
.nav a{color:var(--ink);font-weight:600}
.nav a:hover{color:var(--orange-dark);text-decoration:none}

/* ---- Hero ---- */
.hero{background:linear-gradient(120deg,#1a1a1a,#2a2a2a);color:#fff;padding:54px 0}
.hero h1{font-size:40px;margin:0 0 10px}
.hero h1 .v{color:var(--orange)}
.hero p{color:#cfcfcf;font-size:18px;margin:0 0 22px;max-width:620px}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}

/* ---- Filter bar ---- */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:26px 0 18px}
.toolbar form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.input,select{
  padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;background:#fff;
}
.input:focus,select:focus{outline:2px solid var(--orange);border-color:var(--orange)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:7px 14px;border-radius:20px;border:1px solid var(--line);background:#fff;font-size:13px;font-weight:600;color:var(--ink)}
.chip.active,.chip:hover{background:var(--orange);color:#fff;border-color:var(--orange);text-decoration:none}

/* ---- Product grid ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px;margin:18px 0 40px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.18s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.card .ph{aspect-ratio:1/1;background:#f0f0f0;overflow:hidden;position:relative}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .badge{position:absolute;top:10px;left:10px;background:var(--black);color:#fff;font-size:11px;font-weight:700;padding:4px 9px;border-radius:6px}
.card .badge.out{background:var(--danger)}
.card .badge.low{background:var(--warn);color:#000}
.card .body{padding:13px 14px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .cat{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}
.card .name{font-weight:700;font-size:15px;color:var(--ink);margin:0}
.card .price{font-size:18px;font-weight:800;color:var(--orange-dark);margin-top:auto}
.card .foot{padding:0 14px 14px}

/* ---- Product detail ---- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:34px;margin:30px 0}
.pd .gallery{background:#f3f3f3;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1}
.pd .gallery img{width:100%;height:100%;object-fit:cover}
.pd h1{margin:6px 0 8px;font-size:30px}
.pd .price{font-size:30px;font-weight:800;color:var(--orange-dark);margin:10px 0}
.pd .stockline{font-weight:600;margin:6px 0}
.pd .desc{color:#444;margin:14px 0}
.callbox{background:#fff;border:1px solid var(--line);border-left:4px solid var(--orange);border-radius:10px;padding:18px;margin-top:18px}
.callbox h3{margin:0 0 8px}

/* ---- Footer ---- */
.site-footer{background:var(--black);color:#bbb;margin-top:40px;padding:34px 0}
.site-footer a{color:var(--orange)}
.site-footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.site-footer h4{color:#fff;margin:0 0 10px}
.copyright{border-top:1px solid #2a2a2a;margin-top:24px;padding-top:16px;font-size:13px;color:#888}

/* ---- Flash / alerts ---- */
.alert{padding:12px 16px;border-radius:9px;margin:12px 0;font-weight:600}
.alert.success{background:#e7f6ec;color:#1c6b3b;border:1px solid #bfe6cd}
.alert.error{background:#fdecec;color:#a32626;border:1px solid #f3c4c4}
.alert.info{background:#fff3e3;color:#9a5700;border:1px solid #ffd9a8}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.tag{display:inline-block;padding:3px 9px;border-radius:6px;font-size:12px;font-weight:700}
.tag.ok{background:#e7f6ec;color:#1c6b3b}
.tag.low{background:#fff3cd;color:#856404}
.tag.out{background:#fdecec;color:#a32626}

/* ================= BACK OFFICE ================= */
.admin-body{display:flex;min-height:100vh;background:#f4f5f7}
.sidebar{width:240px;background:var(--black);color:#cfcfcf;flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sidebar .logo{padding:20px;font-weight:800;font-size:20px;color:#fff;border-bottom:1px solid #262626;display:flex;align-items:center;gap:9px}
.sidebar .logo .mark{width:32px;height:32px;border-radius:8px;background:var(--orange);color:#000;display:grid;place-items:center;font-weight:900}
.sidebar nav{padding:12px 0;flex:1;overflow-y:auto}
.sidebar nav a{display:flex;align-items:center;gap:11px;padding:12px 20px;color:#cfcfcf;font-weight:600;font-size:14px;border-left:3px solid transparent}
.sidebar nav a:hover{background:#1d1d1d;color:#fff;text-decoration:none}
.sidebar nav a.active{background:#1d1d1d;color:#fff;border-left-color:var(--orange)}
.sidebar nav .grouplabel{padding:14px 20px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:#777}
.sidebar .who{padding:16px 20px;border-top:1px solid #262626;font-size:13px}
.sidebar .who .role{display:inline-block;margin-top:4px;background:var(--orange);color:#000;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:700;text-transform:uppercase}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.main .bar{background:#fff;border-bottom:1px solid var(--line);padding:16px 26px;display:flex;align-items:center;justify-content:space-between}
.main .bar h1{font-size:20px;margin:0}
.main .content{padding:26px;flex:1}

/* Stat cards */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:24px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}
.stat .label{color:var(--muted);font-size:13px;font-weight:600}
.stat .value{font-size:28px;font-weight:800;margin-top:6px}
.stat.orange{border-top:3px solid var(--orange)}
.stat.black{border-top:3px solid var(--black)}

/* Panels & tables */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:24px;overflow:hidden}
.panel .head{padding:15px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.panel .head h2{font-size:16px;margin:0}
.panel .pad{padding:20px}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:11px 16px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
th{background:#fafafa;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
tr:hover td{background:#fcfaf7}
td.right,th.right{text-align:right}
.thumb{width:46px;height:46px;border-radius:8px;object-fit:cover;background:#eee}

/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field.full{grid-column:1/-1}
.field label{font-weight:600;font-size:13px}
.field input,.field select,.field textarea{
  padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;font-family:inherit;background:#fff;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--orange);border-color:var(--orange)}
.field textarea{min-height:90px;resize:vertical}
.hint{font-size:12px;color:var(--muted)}

/* Login */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(120deg,#1a1a1a,#333);padding:20px}
.login-card{background:#fff;border-radius:16px;box-shadow:var(--shadow);width:100%;max-width:400px;overflow:hidden}
.login-card .top{background:var(--black);color:#fff;text-align:center;padding:26px}
.login-card .top .mark{width:50px;height:50px;border-radius:12px;background:var(--orange);color:#000;display:grid;place-items:center;font-weight:900;font-size:26px;margin:0 auto 10px}
.login-card .body{padding:26px}
.demo{margin-top:16px;font-size:13px;color:var(--muted);background:#fafafa;border:1px dashed var(--line);border-radius:9px;padding:12px}

/* POS */
.pos{display:grid;grid-template-columns:1.6fr 1fr;gap:22px;align-items:start}
.pos .pick .search{margin-bottom:14px}
.pos-list{max-height:62vh;overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
.pos-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--line);cursor:pointer}
.pos-item:hover{background:#fff3e3}
.pos-item:last-child{border-bottom:none}
.pos-item .nm{font-weight:600;font-size:14px}
.pos-item .meta{font-size:12px;color:var(--muted)}
.pos-item .pr{margin-left:auto;font-weight:800;color:var(--orange-dark);white-space:nowrap}
.pos-item.disabled{opacity:.45;cursor:not-allowed}
.cart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);position:sticky;top:90px}
.cart .head{background:var(--black);color:#fff;padding:14px 18px;border-radius:var(--radius) var(--radius) 0 0;font-weight:700}
.cart .rows{max-height:46vh;overflow:auto}
.cart-row{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line)}
.cart-row .nm{flex:1;font-size:13px;font-weight:600}
.cart-row input{width:54px;padding:5px;text-align:center;border:1px solid var(--line);border-radius:6px}
.cart-row .x{color:var(--danger);cursor:pointer;font-weight:800;padding:0 4px}
.cart .tots{padding:14px 18px;border-top:2px solid var(--line)}
.cart .totline{display:flex;justify-content:space-between;font-weight:700;font-size:18px;margin-bottom:12px}
.cart .empty-cart{padding:30px;text-align:center;color:var(--muted);font-size:14px}

.barchart{display:flex;align-items:flex-end;gap:10px;height:200px;padding:10px 0}
.barchart .bar{flex:1;background:var(--orange);border-radius:6px 6px 0 0;position:relative;min-height:2px;transition:.2s}
.barchart .bar:hover{background:var(--orange-dark)}
.barchart .bar span{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font-size:11px;color:var(--muted)}
.barchart .bar b{position:absolute;top:-20px;left:0;right:0;text-align:center;font-size:11px;font-weight:700}

@media(max-width:880px){
  .pd,.pos{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .site-footer .cols{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-260px;z-index:100;transition:.2s}
  .sidebar.open{left:0}
  .menu-toggle{display:inline-flex!important}
}
.menu-toggle{display:none}

/* ================= ANIMATIONS & TRANSITIONS ================= */
@keyframes revealUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{0%{opacity:0;transform:scale(.94)}60%{transform:scale(1.02)}100%{opacity:1;transform:scale(1)}}
@keyframes growBar{from{height:0}to{height:var(--h)}}
@keyframes floatUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* Scroll-reveal: hidden until JS adds .in (or shown immediately if JS off) */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease, transform .55s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.no-js .reveal{opacity:1;transform:none}

/* Page-load fades */
.main .content{animation:fadeIn .45s ease both}
.pop-in{animation:popIn .5s cubic-bezier(.2,.8,.2,1) both}

/* Hero intro (storefront) */
.hero h1{animation:floatUp .6s cubic-bezier(.2,.8,.2,1) both}
.hero p{animation:floatUp .6s cubic-bezier(.2,.8,.2,1) .12s both}
.hero .cta{animation:floatUp .6s cubic-bezier(.2,.8,.2,1) .24s both}

/* Buttons: lift + press */
.btn{transition:background .15s, transform .12s, box-shadow .15s}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(255,122,0,.28)}
.btn.black:hover{box-shadow:0 6px 16px rgba(0,0,0,.28)}
.btn:active{transform:translateY(0) scale(.97)}

/* Chips & nav underline */
.chip{transition:background .18s, color .18s, border-color .18s, transform .12s}
.chip:active{transform:scale(.95)}
.nav a{position:relative}
.nav a::after{content:'';position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--orange);transition:right .25s ease}
.nav a:hover::after{right:0}

/* Cards: smoother hover + image zoom */
.card{transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s}
.card .ph img{transition:transform .4s ease}
.card:hover .ph img{transform:scale(1.06)}

/* Product detail gallery zoom */
.pd .gallery img{transition:transform .5s ease}
.pd .gallery:hover img{transform:scale(1.05)}

/* Sidebar links slide */
.sidebar nav a{transition:background .18s, color .18s, border-color .18s, padding-left .18s}
.sidebar nav a:hover{padding-left:26px}

/* Table rows */
tr{transition:background .15s}

/* Panels / stat hover */
.panel{transition:box-shadow .25s, transform .25s}
.stat{transition:box-shadow .25s, transform .25s}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow)}

/* Animated bars (dashboards) */
.barchart .bar.grow{height:var(--h);animation:growBar .8s cubic-bezier(.2,.8,.2,1) both}

/* Mini horizontal bars (top cities) */
.minibar{flex:1;height:8px;background:#f0f0f0;border-radius:6px;overflow:hidden;min-width:60px}
.minibar span{display:block;height:100%;background:linear-gradient(90deg,var(--orange),#ffab57);border-radius:6px;width:0;animation:barFill .9s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes barFill{from{width:0}}

/* Flash messages slide in */
.alert{animation:floatUp .4s ease both}

/* Spinner / loading shimmer (optional reusable) */
.skeleton{background:linear-gradient(90deg,#eee 25%,#f5f5f5 37%,#eee 63%);background-size:200% 100%;animation:shimmer 1.4s infinite}

/* Respect reduced-motion preference */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ================= SPORTY ORANGE THEME ================= */
:root{ --orange-2:#ff9d3c; --orange-deep:#e85d00; }

/* Sporty condensed type on headings, brand, controls */
h1,h2,h3,.brand,.nav a,.btn,.chip,.sidebar .logo,.sidebar nav a,
.card .name,.card .price,.stat .value,th,.cart .head,.pos-item .nm{
  font-family:'Oswald','Segoe UI',system-ui,sans-serif;
  text-transform:uppercase;letter-spacing:.5px;
}
.btn{font-style:italic;font-weight:600;letter-spacing:1px;border-radius:7px}
.card .price{font-style:italic}
.hint,.field label,td,.topbar,.demo,.copyright,p{letter-spacing:0;text-transform:none}

/* Logo as brand mark */
.mark-img{width:42px;height:42px;object-fit:contain;display:inline-block;vertical-align:middle}
.sidebar .logo .mark-img{width:34px;height:34px}
.login-card .top .mark-img{width:70px;height:70px;margin:0 auto 8px;display:block;
  filter:drop-shadow(0 4px 10px rgba(255,122,0,.4))}

/* Header gets an orange race stripe */
.topbar{background:#000}
.site-header{border-bottom:3px solid var(--orange)}
.nav a{font-size:14px}

/* ---- Hero: diagonal orange speed band + speed lines ---- */
.hero{position:relative;overflow:hidden;background:#0d0d0d;padding:64px 0}
.hero::before{content:"";position:absolute;top:-30%;right:-12%;width:62%;height:170%;z-index:0;
  background:linear-gradient(135deg,var(--orange-deep),var(--orange) 55%,var(--orange-2));
  transform:skewX(-13deg);box-shadow:-14px 0 50px rgba(0,0,0,.35)}
.hero::after{content:"";position:absolute;inset:0;z-index:0;
  background:repeating-linear-gradient(115deg,transparent 0 46px,rgba(255,255,255,.04) 46px 49px)}
.hero .container{position:relative;z-index:2}
.hero h1{font-family:'Saira Condensed','Oswald',sans-serif;font-style:italic;font-weight:700;
  font-size:56px;line-height:.95;letter-spacing:.5px;text-shadow:0 3px 22px rgba(0,0,0,.45)}
.hero h1 .v{color:#111;background:#fff;padding:0 10px;display:inline-block;transform:skewX(-8deg)}
.hero p{text-shadow:0 1px 10px rgba(0,0,0,.4)}
.hero .cta .btn{font-size:16px;padding:13px 26px}

/* Section headings get a skewed orange tick */
.panel .head h2{position:relative;padding-left:16px}
.panel .head h2::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) skewX(-12deg);
  width:5px;height:18px;background:var(--orange);border-radius:1px}

/* Chips: sharper, sporty */
.chip{border-radius:6px}

/* Cards: sharper corners + orange speed bar on hover */
.card{border-radius:9px;position:relative}
.card::after{content:"";position:absolute;left:0;bottom:0;height:4px;width:0;z-index:3;
  background:linear-gradient(90deg,var(--orange),var(--orange-2));transition:width .3s ease}
.card:hover::after{width:100%}
.card .badge{border-radius:4px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}

/* Placeholder = the store logo on a sporty orange-striped panel */
.ph.ph-logo{background:linear-gradient(135deg,#fff,#ffe7cf)}
.ph.ph-logo::after{content:"";position:absolute;inset:0;z-index:1;
  background:repeating-linear-gradient(115deg,transparent 0 20px,rgba(255,122,0,.07) 20px 23px)}
.ph.ph-logo img{object-fit:contain!important;padding:24%;position:relative;z-index:2}
.pd .gallery.ph-logo{background:linear-gradient(135deg,#fff,#ffe7cf);display:grid;place-items:center;position:relative}
.pd .gallery.ph-logo::after{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(115deg,transparent 0 28px,rgba(255,122,0,.06) 28px 32px)}
.pd .gallery.ph-logo img{width:62%;height:auto;object-fit:contain;position:relative;z-index:2}
.thumb.thumb-logo{object-fit:contain;background:#fff3e6;padding:5px}

/* Stat cards: subtle orange corner flash */
.stat{position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;right:-22px;top:-22px;width:64px;height:64px;
  background:var(--orange);opacity:.10;transform:rotate(45deg)}
.stat.orange .value{color:var(--orange-deep)}

/* Login card sporty top */
.login-card .top{background:linear-gradient(135deg,#161616,#000)}
.login-card .top h2{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:2px}

/* Buttons keep a tighter active press */
.btn:active{transform:translateY(0) scale(.96)}

/* Payment method radio pills */
.pay-opt{display:flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid var(--line);
  border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;flex:1;justify-content:center;
  font-family:inherit;text-transform:none;letter-spacing:0}
.pay-opt:has(input:checked){background:var(--orange);color:#fff;border-color:var(--orange)}
.pay-opt input{display:none}
