:root{
  --ink:#1a1a1a; --ink-soft:#3a3631; --paper:#ffffff; --bg:#f7f5f2; --bg2:#efeae2;
  --line:#e4ded4; --muted:#8a8378; --camel:#b08d57; --camel-dk:#8f7044;
  --ok:#2f7d52; --warn:#c0392b; --radius:2px;
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-weight:400;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--camel-dk);text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:600;color:var(--ink);margin:0}
.serif{font-family:var(--serif)}
.muted{color:var(--muted)}
button{font-family:var(--sans);cursor:pointer}
input,select,textarea{font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;width:100%;outline:none}
input:focus,select,textarea:focus{border-color:var(--camel)}
label{display:block;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 6px}
.field{margin-bottom:16px}

/* botones */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:1px solid var(--ink);background:var(--ink);color:#fff;padding:11px 22px;border-radius:var(--radius);font-size:13px;letter-spacing:.06em;text-transform:uppercase;transition:.15s}
.btn:hover{background:#000}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:#fff}
.btn.camel{background:var(--camel);border-color:var(--camel)}
.btn.camel:hover{background:var(--camel-dk);border-color:var(--camel-dk)}
.btn.sm{padding:7px 14px;font-size:11px}
.btn.danger{background:transparent;color:var(--warn);border-color:var(--warn)}
.btn.danger:hover{background:var(--warn);color:#fff}
.btn:disabled{opacity:.5;cursor:not-allowed}
.link{background:none;border:none;color:var(--camel-dk);text-decoration:underline;padding:0;font-size:13px}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.login-hero{background:#14110e center/cover no-repeat;position:relative;display:flex;align-items:flex-end;padding:48px}
.login-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,17,14,.15),rgba(20,17,14,.75))}
.login-hero .tag{position:relative;z-index:1;color:#f3efe8}
.login-hero .tag h2{color:#fff;font-size:34px;font-weight:500;line-height:1.15}
.login-hero .tag p{color:#d8d1c6;max-width:340px;font-size:14px}
.login-form-side{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--paper)}
.login-card{width:100%;max-width:360px}
.login-card .logo{font-family:var(--serif);font-size:30px;letter-spacing:.18em;font-weight:600;text-align:center}
.login-card .logo img{height:54px;display:block;margin:0 auto}
.login-card .sub{text-align:center;color:var(--muted);font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin:6px 0 34px}
.err{color:var(--warn);font-size:13px;margin:8px 0;min-height:18px}
@media(max-width:820px){.login-wrap{grid-template-columns:1fr}.login-hero{display:none}}

/* ===== SHELL ===== */
.shell{min-height:100vh;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:68px;background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.topbar .brand{font-family:var(--serif);font-size:22px;letter-spacing:.16em;font-weight:600;display:flex;align-items:center;gap:12px}
.topbar .brand img{height:34px}
.nav{display:flex;gap:4px}
.nav button{background:none;border:none;padding:10px 16px;font-size:13px;letter-spacing:.04em;color:var(--ink-soft);border-bottom:2px solid transparent;text-transform:uppercase}
.nav button.active{color:var(--ink);border-color:var(--camel)}
.nav button:hover{color:var(--ink)}
.topbar .right{display:flex;align-items:center;gap:16px}
.who{font-size:13px;color:var(--muted);text-align:right;line-height:1.2}
.who b{color:var(--ink);font-weight:500;display:block}
.cart-btn{position:relative;background:var(--ink);color:#fff;border:none;border-radius:var(--radius);padding:10px 16px;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.cart-btn .badge{position:absolute;top:-8px;right:-8px;background:var(--camel);color:#fff;font-size:11px;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.content{flex:1;max-width:1180px;width:100%;margin:0 auto;padding:36px 28px 80px}
.page-title{font-size:30px;font-weight:500;margin-bottom:4px}
.page-sub{color:var(--muted);margin-bottom:28px;font-size:14px}

/* ===== CATALOGO ===== */
.brand-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;border-bottom:1px solid var(--line)}
.brand-tabs button{background:none;border:none;padding:12px 18px;font-family:var(--serif);font-size:20px;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px}
.brand-tabs button.active{color:var(--ink);border-color:var(--camel)}
.coll-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.coll-tabs button{background:var(--paper);border:1px solid var(--line);padding:8px 16px;font-size:13px;letter-spacing:.04em;border-radius:20px;color:var(--ink-soft)}
.coll-tabs button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.block{background:var(--paper);border:1px solid var(--line);margin-bottom:22px;overflow:hidden}
.block img{width:100%;display:block;background:var(--bg2)}
.block .order-row{display:grid;grid-template-columns:1fr 120px 150px;gap:14px;align-items:end;padding:18px 20px;border-top:1px solid var(--line)}
.block .meta{font-size:12px;color:var(--muted);letter-spacing:.04em}
.block .meta b{color:var(--ink);font-family:var(--serif);font-size:16px;display:block;font-weight:600}
@media(max-width:680px){.block .order-row{grid-template-columns:1fr}}
.block-body{padding:18px 20px;border-top:1px solid var(--line)}
.block-body .meta{margin-bottom:10px}
.prod-list{display:flex;flex-direction:column}
.prod-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid var(--bg2)}
.prod-row:last-child{border-bottom:none}
.prod-info{font-size:14px;color:var(--ink-soft);flex:1}
.prod-ref{font-weight:600;color:var(--ink)}
.prod-nom{color:var(--ink-soft)}
.prod-prices{flex:0 0 auto;text-align:right;white-space:nowrap;line-height:1.1;margin-right:4px}
.price-wh{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:.01em}
.price-pvp{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.prod-qty{width:84px;flex:0 0 84px;text-align:center}
.block-foot{display:flex;gap:12px;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.block-foot input{flex:1}
@media(max-width:680px){.block-foot{flex-direction:column;align-items:stretch}.prod-qty{width:80px;flex:0 0 80px}}

/* ===== cards / tables ===== */
.card{background:var(--paper);border:1px solid var(--line);padding:24px;margin-bottom:20px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:680px){.grid2,.grid3{grid-template-columns:1fr}}
table{width:100%;border-collapse:collapse;background:var(--paper)}
th{text-align:left;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding:12px 14px;border-bottom:1px solid var(--line);font-weight:500}
td{padding:12px 14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
tr:hover td{background:#fcfbf9}
.tag-pill{display:inline-block;font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;border-radius:12px;border:1px solid var(--line)}
.st-abierta,.st-recibido{background:#fdf3ec;color:#b5651d;border-color:#f0d8c4}
.st-en_proceso{background:#eef3fb;color:#2c5d99;border-color:#cfe0f3}
.st-resuelta,.st-servido{background:#eef7f0;color:var(--ok);border-color:#cde8d6}
.st-cancelado{background:#f3f3f3;color:#777}
.empty{text-align:center;color:var(--muted);padding:56px 20px;font-family:var(--serif);font-size:20px}

/* ===== drawer cart ===== */
.overlay{position:fixed;inset:0;background:rgba(20,17,14,.45);z-index:50;display:none}
.overlay.show{display:block}
.drawer{position:fixed;top:0;right:-460px;width:440px;max-width:92vw;height:100vh;background:var(--paper);z-index:60;transition:right .25s;display:flex;flex-direction:column;box-shadow:-10px 0 40px rgba(0,0,0,.12)}
.drawer.show{right:0}
.drawer header{padding:22px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer header h3{font-size:22px;font-weight:500}
.drawer .items{flex:1;overflow:auto;padding:10px 24px}
.cart-line{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.cart-line img{width:64px;height:64px;object-fit:cover;background:var(--bg2);border:1px solid var(--line)}
.cart-line .info{flex:1;font-size:13px}
.cart-line .info b{font-family:var(--serif);font-size:15px}
.drawer footer{padding:20px 24px;border-top:1px solid var(--line)}
.modal{position:fixed;inset:0;background:rgba(20,17,14,.5);z-index:80;display:none;align-items:center;justify-content:center;padding:20px}
.modal.show{display:flex}
.modal .box{background:var(--paper);max-width:520px;width:100%;padding:32px;max-height:90vh;overflow:auto}
.modal .box h3{font-size:24px;font-weight:500;margin-bottom:10px}
.terms-box{background:var(--bg);border:1px solid var(--line);padding:16px;font-size:13px;color:var(--ink-soft);max-height:200px;overflow:auto;margin:14px 0}
.check{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--ink-soft)}
.check input{width:auto;margin-top:2px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:14px 26px;font-size:14px;border-radius:var(--radius);z-index:100;opacity:0;transition:.25s;pointer-events:none}
.toast.show{opacity:1}
.toast.err{background:var(--warn)}

/* admin */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.stat-card{background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--camel);padding:22px 20px}
.stat-num{font-family:var(--serif);font-size:34px;font-weight:600;color:var(--ink);line-height:1}
.stat-label{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.stat-sub{font-size:13px;color:var(--ink-soft);margin-top:4px}
@media(max-width:820px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.admin-side{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.admin-side button{background:var(--paper);border:1px solid var(--line);padding:9px 16px;font-size:13px;border-radius:var(--radius);color:var(--ink-soft)}
.admin-side button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}
.spacer{flex:1}
.flex{display:flex;align-items:center;gap:12px}
.between{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.thumb{width:48px;height:48px;object-fit:cover;border:1px solid var(--line);background:var(--bg2)}
.hint{font-size:12px;color:var(--muted);margin-top:6px}
