/* ═══════════════════════════════════════════════════════════
   狮礼茶 — Refined Design System
   高端茶叶电商 · 克制 · 留白 · 材质感
   ═══════════════════════════════════════════════════════════ */

/* ═══════════ TOKENS ═══════════ */
:root {
  /* Colors */
  --c-ink: #1c1c1e;
  --c-ink-soft: #3a3a3c;
  --c-ink-muted: #8e8e93;
  --c-paper: #faf9f6;
  --c-paper-warm: #f5f2ea;
  --c-surface: #ffffff;
  --c-tea: #3a5a40;
  --c-tea-soft: #588157;
  --c-bronze: #a67c46;
  --c-bronze-soft: #c49a5e;
  --c-bronze-pale: #faf6ef;
  --c-red: #c44e4e;
  --c-red-soft: #faf4f4;
  --c-border: #e8e4dc;
  --c-border-light: #f0ede7;
  --c-success: #588157;
  --c-shadow-a: rgba(0,0,0,.03);
  --c-shadow-b: rgba(0,0,0,.06);
  --c-shadow-c: rgba(0,0,0,.10);

  /* Typography */
  --font-song: 'Songti SC', 'STSongti', 'Noto Serif SC', 'SimSun', 'KaiTi', serif;
  --font-sans: 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'WenQuanYi Micro Hei', sans-serif;
  --font-mono: 'SF Mono', 'Menlo', 'Consolas', monospace;

  /* Scale */
  --text-xs: .75rem;
  --text-sm: .8125rem;
  --text-base: .9375rem;
  --text-md: 1.0625rem;
  --text-lg: 1.25rem;
  --text-xl: 1.5rem;
  --text-2xl: 1.875rem;
  --text-3xl: 2.25rem;

  /* Spacing */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-8: 32px; --sp-10: 40px;
  --sp-12: 48px; --sp-16: 64px; --sp-20: 80px;

  /* Radii */
  --r-sm: 4px; --r-md: 8px; --r-lg: 12px;

  /* Motion */
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --t-fast: .15s; --t-base: .25s; --t-slow: .4s; --t-glacial: .6s;
}

/* ═══════════ RESET ═══════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:var(--font-sans);font-size:var(--text-base);
  background:var(--c-paper);color:var(--c-ink);
  line-height:1.65;letter-spacing:.01em;
  background-image:
    radial-gradient(ellipse at 20% 10%,rgba(166,124,70,.025) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 90%,rgba(58,90,64,.02) 0%,transparent 60%);
}
::selection{background:rgba(166,124,70,.18);color:var(--c-ink)}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--c-ink-muted)}

/* ═══════════ TYPOGRAPHY ═══════════ */
h1,h2,h3,h4{font-family:var(--font-song);font-weight:600;color:var(--c-ink);letter-spacing:.02em}
h1{font-size:var(--text-3xl);line-height:1.25}
h2{font-size:var(--text-2xl);line-height:1.3}
h3{font-size:var(--text-xl);line-height:1.35}
h4{font-size:var(--text-lg);line-height:1.4}
a{color:var(--c-tea);text-decoration:none;transition:color var(--t-fast) var(--ease)}
a:hover{color:var(--c-bronze)}

/* ═══════════ LAYOUT ═══════════ */
.container{max-width:1200px;margin:0 auto;padding:0 var(--sp-6)}
/* Admin: flex layout when sidebar is present */
.container:has(.sidebar){display:flex;max-width:none;padding:0}

/* ═══════════ HEADER ═══════════ */
header{
  background:var(--c-ink);color:var(--c-surface);
  padding:var(--sp-8) 0;text-align:center;
  position:relative;overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.08);
}
header::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 25% 50%,rgba(196,154,94,.08) 0%,transparent 55%),
    radial-gradient(ellipse at 75% 50%,rgba(88,129,87,.05) 0%,transparent 55%);
}
header h1{
  font-family:var(--font-song);font-size:2.2rem;font-weight:700;
  letter-spacing:.14em;position:relative;z-index:1;
  background:linear-gradient(180deg,#f0e6d3,#d4c090,#c4a060);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
header h1::after{
  content:'';display:block;width:36px;height:2px;
  background:var(--c-bronze-soft);margin:var(--sp-3) auto 0;
}
header p{font-size:var(--text-sm);color:rgba(255,255,255,.65);margin-top:var(--sp-2);position:relative;z-index:1;letter-spacing:.04em}
header a{color:rgba(255,255,255,.65);font-size:var(--text-sm);padding:6px 14px;border:1px solid rgba(255,255,255,.18);border-radius:var(--r-sm);transition:all var(--t-fast)}
header a:hover{color:#fff;border-color:rgba(255,255,255,.35)}

/* ═══════════ NAVIGATION ═══════════ */
nav{
  display:flex;align-items:center;justify-content:flex-start;
  padding:0 var(--sp-6);height:56px;
  background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--c-border);
  position:sticky;top:0;z-index:100;
}
@media(min-width:1240px){nav{padding:0 calc((100vw - 1200px)/2)}}
nav a{
  color:var(--c-ink-soft);font-size:var(--text-sm);font-weight:500;
  letter-spacing:.03em;padding:var(--sp-3) var(--sp-5);
  position:relative;transition:color var(--t-fast) var(--ease);
}
nav a::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:0;height:1.5px;background:var(--c-bronze);
  transition:width var(--t-base) var(--ease);
}
nav a:hover{color:var(--c-ink)}
nav a:hover::after{width:calc(100% - var(--sp-5)*2)}

/* ═══════════ HERO ═══════════ */
.hero-section{
  background:linear-gradient(170deg,#1c1c1e 0%,#2a2724 40%,#1c1c1e 70%,#2c2620 100%);
  color:var(--c-surface);text-align:center;
  padding:var(--sp-16) var(--sp-6);margin:var(--sp-8) 0 var(--sp-12);
  border-radius:var(--r-lg);position:relative;overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
}
.hero-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    url('/static/images/lion-pattern.svg') center/65% no-repeat,
    radial-gradient(ellipse at 30% 40%,rgba(196,154,94,.06) 0%,transparent 50%),
    radial-gradient(ellipse at 70% 60%,rgba(88,129,87,.03) 0%,transparent 50%);
}
/* Corner accent */
.hero-section::after{
  content:'';position:absolute;top:var(--sp-5);right:var(--sp-5);
  width:32px;height:32px;pointer-events:none;
  border-top:1px solid rgba(196,154,94,.3);border-right:1px solid rgba(196,154,94,.3);
}
.hero-section h2{
  font-family:var(--font-song);font-size:var(--text-3xl);font-weight:600;
  color:#f5edd8;letter-spacing:.06em;position:relative;z-index:1;
  max-width:700px;margin:0 auto;
}
.hero-section p{
  font-size:var(--text-base);color:rgba(255,255,255,.72);
  margin-top:var(--sp-4);position:relative;z-index:1;font-weight:300;
}

/* ═══════════ SECTION TITLES ═══════════ */
.section-title{
  font-family:var(--font-song);font-size:var(--text-2xl);font-weight:600;
  text-align:center;margin:var(--sp-16) 0 var(--sp-8);
  letter-spacing:.05em;
}
.section-title::after{
  content:'';display:block;width:40px;height:2px;
  background:var(--c-bronze);margin:var(--sp-4) auto 0;
}

/* ═══════════ CARDS ═══════════ */
.product-grid,.article-grid{
  display:grid;gap:var(--sp-6);margin-top:var(--sp-6);
}
.product-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.article-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}

.product-card,.article-card{
  background:var(--c-surface);border-radius:var(--r-md);
  border:1px solid var(--c-border-light);
  box-shadow:0 1px 2px var(--c-shadow-a);
  overflow:hidden;transition:all var(--t-slow) var(--ease);
  position:relative;
}
.product-card:hover,.article-card:hover{
  transform:translateY(-4px);
  box-shadow:0 1px 2px var(--c-shadow-a),0 8px 24px var(--c-shadow-b);
  border-color:var(--c-border);
}
.product-image,.article-image{
  width:100%;height:220px;object-fit:cover;display:block;
  transition:transform var(--t-glacial) var(--ease);
}
.product-card:hover .product-image,.article-card:hover .article-image{
  transform:scale(1.04);
}
.product-card h3,.article-card h3{
  font-family:var(--font-song);font-size:var(--text-md);font-weight:600;
  padding:var(--sp-5) var(--sp-5) var(--sp-2);letter-spacing:.02em;
}
.product-card>p,.article-card>p{
  font-size:var(--text-sm);color:var(--c-ink-muted);line-height:1.6;
  padding:0 var(--sp-5);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.product-card .product-price-section{padding:var(--sp-4) var(--sp-5)}
.product-price{font-size:var(--text-md);font-weight:600;color:var(--c-red);padding:0 var(--sp-5) var(--sp-4)}
.discount-info-badge{
  display:inline-block;font-size:var(--text-xs);font-weight:600;
  background:var(--c-bronze-pale);color:var(--c-bronze);
  padding:2px 10px;border-radius:20px;letter-spacing:.04em;
}
.discount-price{font-size:var(--text-md);font-weight:600;color:var(--c-red)}
.original-price{font-size:var(--text-sm);color:var(--c-ink-muted);text-decoration:line-through}
.product-card .btn,.article-card .btn-outline{margin:0 var(--sp-5) var(--sp-5)}

/* ═══════════ BUTTONS ═══════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 24px;font-size:var(--text-sm);font-weight:500;
  font-family:var(--font-sans);letter-spacing:.03em;
  border-radius:var(--r-sm);border:none;cursor:pointer;
  text-decoration:none;transition:all var(--t-base) var(--ease);
  position:relative;overflow:hidden;
}
.btn{background:var(--c-tea);color:var(--c-surface)}
.btn:hover{background:#2d4732;color:var(--c-surface);transform:translateY(-1px);box-shadow:0 4px 12px rgba(58,90,64,.2)}
.btn-outline{background:transparent;border:1.5px solid var(--c-tea);color:var(--c-tea)}
.btn-outline:hover{background:var(--c-tea);color:var(--c-surface)}
.btn-accent{background:var(--c-bronze);color:var(--c-surface)}
.btn-accent:hover{background:#8c6532;color:var(--c-surface);box-shadow:0 4px 12px rgba(166,124,70,.25)}
.btn-danger{background:transparent;border:1px solid var(--c-red);color:var(--c-red)}
.btn-danger:hover{background:var(--c-red);color:var(--c-surface)}
.btn-sm{padding:6px 14px;font-size:var(--text-xs)}
.btn-secondary{background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-ink-soft)}
.btn-secondary:hover{background:var(--c-paper);color:var(--c-ink);transform:none;box-shadow:none}
.add-btn{
  display:inline-flex;align-items:center;padding:9px 20px;
  font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);
  background:var(--c-bronze);color:var(--c-surface);
  border:none;border-radius:var(--r-sm);cursor:pointer;
  text-decoration:none;letter-spacing:.03em;
  transition:all var(--t-base) var(--ease);
}
.add-btn:hover{background:#8c6532;color:var(--c-surface);box-shadow:0 4px 12px rgba(166,124,70,.25)}

/* ═══════════ FORMS ═══════════ */
.form-group{margin-bottom:var(--sp-5)}
.form-group label{
  display:block;margin-bottom:var(--sp-1);font-size:var(--text-sm);
  font-weight:600;color:var(--c-ink);letter-spacing:.02em;
}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:10px 14px;font-size:var(--text-sm);font-family:var(--font-sans);
  color:var(--c-ink);background:var(--c-surface);
  border:1px solid var(--c-border);border-radius:var(--r-sm);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  outline:none;border-color:var(--c-bronze);
  box-shadow:0 0 0 3px rgba(166,124,70,.08);
}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--c-ink-muted)}
.form-group textarea{resize:vertical;min-height:140px}
input[type="checkbox"]{accent-color:var(--c-bronze)}

/* ═══════════ TABLES ═══════════ */
table{width:100%;border-collapse:collapse;background:var(--c-surface);border-radius:var(--r-md);overflow:hidden;border:1px solid var(--c-border-light)}
thead{background:var(--c-ink)}
thead th{color:var(--c-surface);padding:10px 14px;font-size:var(--text-xs);font-weight:500;letter-spacing:.04em;text-align:left}
tbody tr{border-bottom:1px solid var(--c-border-light);transition:background var(--t-fast)}
tbody tr:hover{background:var(--c-bronze-pale)}
tbody td{padding:10px 14px;font-size:var(--text-sm);color:var(--c-ink-soft)}

/* ═══════════ FLASH MESSAGES ═══════════ */
.flash-messages{position:fixed;top:80px;right:var(--sp-6);z-index:1000}
.flash-message{
  background:var(--c-tea);color:var(--c-surface);
  padding:12px 20px;border-radius:var(--r-sm);
  font-size:var(--text-sm);letter-spacing:.02em;
  box-shadow:0 4px 16px rgba(58,90,64,.25);
  margin-bottom:var(--sp-2);
  animation:toastIn .35s var(--ease);
}
.flash-error{background:var(--c-red)!important}
@keyframes toastIn{from{transform:translateX(60px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ═══════════ CART ═══════════ */
.cart-container{
  background:var(--c-surface);border-radius:var(--r-md);
  padding:var(--sp-10);border:1px solid var(--c-border-light);
  box-shadow:0 1px 2px var(--c-shadow-a);
}
.cart-header{text-align:center;margin-bottom:var(--sp-8)}
.cart-header h1{font-family:var(--font-song)}
.cart-item{display:flex;align-items:center;gap:var(--sp-5);padding:var(--sp-5) 0;border-bottom:1px solid var(--c-border-light)}
.cart-item:last-child{border-bottom:none}
.cart-item-image{width:90px;height:90px;object-fit:cover;border-radius:var(--r-sm);flex-shrink:0}
.cart-item-info{flex:1}
.cart-item-info h3{font-family:var(--font-song);font-size:var(--text-base);margin-bottom:var(--sp-1)}
.cart-item-price{font-size:var(--text-base);font-weight:600;color:var(--c-red)}
.cart-item-controls{display:flex;align-items:center;gap:var(--sp-3)}
.quantity-btn{
  width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--c-border);background:var(--c-surface);
  color:var(--c-ink);border-radius:var(--r-sm);font-size:1rem;
  cursor:pointer;transition:all var(--t-fast);
}
.quantity-btn:hover{background:var(--c-tea);color:var(--c-surface);border-color:var(--c-tea)}
.quantity-input{width:48px;text-align:center;border:1px solid var(--c-border);border-radius:var(--r-sm);padding:5px;font-size:var(--text-sm);font-family:var(--font-sans)}
.remove-btn{padding:6px 14px;background:transparent;border:1px solid var(--c-red);color:var(--c-red);border-radius:var(--r-sm);font-size:var(--text-xs);cursor:pointer;transition:all var(--t-fast)}
.remove-btn:hover{background:var(--c-red);color:var(--c-surface)}
.cart-total{margin-top:var(--sp-6);padding:var(--sp-5);background:var(--c-bronze-pale);border-radius:var(--r-sm)}
.cart-total h3{font-family:var(--font-song)}
.cart-total .total-price{font-size:var(--text-2xl);font-weight:700;color:var(--c-red)}
.cart-actions{display:flex;gap:var(--sp-3);justify-content:flex-end;margin-top:var(--sp-5)}
.empty-cart{text-align:center;padding:var(--sp-16) var(--sp-6)}
.empty-cart h2{font-family:var(--font-song);color:var(--c-ink-muted);margin-bottom:var(--sp-5)}

/* ═══════════ ORDERS ═══════════ */
.orders-container{}
.orders-header{text-align:center;margin-bottom:var(--sp-8)}
.orders-header h1{font-family:var(--font-song)}
.order-card{
  background:var(--c-surface);border:1px solid var(--c-border-light);
  border-radius:var(--r-md);padding:var(--sp-6);margin-bottom:var(--sp-5);
  box-shadow:0 1px 2px var(--c-shadow-a);
  transition:box-shadow var(--t-base) var(--ease);
}
.order-card:hover{box-shadow:0 1px 2px var(--c-shadow-a),0 6px 20px var(--c-shadow-b)}
.order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--c-border-light)}
.order-id{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600}
.order-status{display:inline-block;padding:2px 12px;border-radius:20px;font-size:var(--text-xs);font-weight:600}
.order-status.pending{background:var(--c-bronze-pale);color:var(--c-bronze)}
.order-status.paid{background:rgba(88,129,87,.1);color:var(--c-tea)}
.order-status.verified_paid{background:rgba(88,129,87,.1);color:var(--c-tea)}
.order-status.shipped{background:rgba(58,90,124,.08);color:#3a5a7c}
.order-status.delivered{background:rgba(90,58,108,.08);color:#5a3a6c}
.order-status.completed{background:rgba(88,129,87,.08);color:var(--c-tea)}
.order-status.cancelled{background:var(--c-red-soft);color:var(--c-red)}
.order-item{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-3) 0;border-bottom:1px solid var(--c-border-light)}
.order-item:last-child{border-bottom:none}
.order-item-image{width:52px;height:52px;object-fit:cover;border-radius:var(--r-sm);flex-shrink:0}
.order-item-info h4{font-size:var(--text-sm);margin-bottom:2px}
.order-item-price{font-size:var(--text-sm);font-weight:600;color:var(--c-red)}
.order-total{text-align:right;font-size:var(--text-md);font-weight:600}
.order-actions{display:flex;gap:var(--sp-2);justify-content:flex-end;margin-top:var(--sp-4)}
.order-info p{font-size:var(--text-sm);color:var(--c-ink-soft);margin-bottom:2px}
.order-info strong{color:var(--c-ink)}

/* ═══════════ PROFILE ═══════════ */
.profile-container{}
.profile-header{text-align:center;margin-bottom:var(--sp-8)}
.profile-header h1{font-family:var(--font-song)}
.profile-tabs{
  display:flex;gap:var(--sp-1);margin-bottom:var(--sp-8);
  border-bottom:2px solid var(--c-border);padding-bottom:0;
}
.profile-tab{
  padding:10px 18px;border:none;border-radius:var(--r-sm) var(--r-sm) 0 0;
  background:transparent;color:var(--c-ink-muted);font-size:var(--text-sm);
  font-weight:500;font-family:var(--font-sans);cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:all var(--t-fast) var(--ease);
}
.profile-tab:hover{color:var(--c-ink);background:var(--c-paper)}
.profile-tab.active{color:var(--c-bronze);border-bottom-color:var(--c-bronze);background:var(--c-bronze-pale)}
.profile-section{display:none;padding:var(--sp-6) 0}
.profile-section.active{display:block}
.profile-section-title{
  font-family:var(--font-song);font-size:var(--text-lg);font-weight:600;
  margin-bottom:var(--sp-6);padding-bottom:var(--sp-3);
  border-bottom:1px solid var(--c-border-light);
}
.form-actions{margin-top:var(--sp-6);display:flex;gap:var(--sp-3)}
.user-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:600}
.user-badge.admin{background:rgba(58,90,124,.1);color:#3a5a7c}
.user-badge.vip{background:var(--c-bronze-pale);color:var(--c-bronze)}
.user-badge.member{background:rgba(88,129,87,.1);color:var(--c-tea)}

/* ═══════════ INFO GROUP ═══════════ */
.info-group{margin-bottom:var(--sp-5)}
.info-group label{display:block;font-size:var(--text-xs);font-weight:600;color:var(--c-ink-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--sp-1)}
.info-group input,.info-group select,.info-group textarea{
  width:100%;padding:10px 14px;border:1px solid var(--c-border);
  border-radius:var(--r-sm);font-size:var(--text-sm);font-family:var(--font-sans);
  color:var(--c-ink);background:var(--c-surface);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.info-group input:hover,.info-group select:hover,.info-group textarea:hover{
  border-color:var(--c-ink-muted);
}
.info-group input:focus,.info-group select:focus,.info-group textarea:focus{
  outline:none;border-color:var(--c-bronze);box-shadow:0 0 0 3px rgba(166,124,70,.08);
  background:var(--c-surface);
}
.info-value{font-size:var(--text-base);color:var(--c-ink);padding:8px 14px;background:var(--c-paper);border-radius:var(--r-sm);border:1px solid var(--c-border-light)}

/* ═══════════ CARDS (Address, Invoice) ═══════════ */
.address-card,.invoice-card{
  background:var(--c-surface);border:1px solid var(--c-border-light);
  border-radius:var(--r-sm);padding:var(--sp-5);margin-bottom:var(--sp-4);
  box-shadow:0 1px 2px var(--c-shadow-a);
}
.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-3)}
.card-title{font-weight:600;font-size:var(--text-base)}
.card-actions{display:flex;gap:var(--sp-2)}
.address-info,.invoice-info{font-size:var(--text-sm);color:var(--c-ink-soft);line-height:1.6}
.default-badge{display:inline-block;padding:1px 8px;border-radius:20px;font-size:var(--text-xs);font-weight:600;background:var(--c-bronze-pale);color:var(--c-bronze);margin-top:var(--sp-2)}
.address-actions{display:flex;gap:var(--sp-2);margin-top:var(--sp-3)}

/* ═══════════ EMPTY STATES ═══════════ */
.empty-state,.no-articles,.no-addresses,.no-materials{
  text-align:center;padding:var(--sp-16) var(--sp-6);color:var(--c-ink-muted);
}
.empty-state h3{font-size:var(--text-lg);margin-bottom:var(--sp-2)}
.empty-state p{margin-bottom:var(--sp-5)}
.bottom-actions{text-align:center;margin-top:var(--sp-8)}

/* ═══════════ PRODUCT DETAIL ═══════════ */
.product-detail{}
.product-detail>h1{
  font-family:var(--font-song);font-size:var(--text-2xl);text-align:center;
  margin-bottom:var(--sp-8);padding-bottom:var(--sp-4);
  border-bottom:1px solid var(--c-border);
}
.product-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-10);align-items:start;margin-bottom:var(--sp-10)}
.product-detail-grid .product-image{
  width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;
  border-radius:var(--r-md);border:1px solid var(--c-border-light);
  box-shadow:0 1px 2px var(--c-shadow-a),0 4px 16px var(--c-shadow-b);
}
.product-detail .product-info{display:flex;flex-direction:column;gap:var(--sp-5)}
.product-detail .product-info .product-price{font-size:var(--text-2xl);font-weight:700;color:var(--c-red)}
.product-detail .product-info .discount-price{font-size:var(--text-2xl);font-weight:700;color:var(--c-red)}
.product-detail .price-row{display:flex;align-items:baseline;gap:var(--sp-3)}
.product-detail .product-stock{font-size:var(--text-sm);color:var(--c-ink-muted);padding:6px 14px;background:var(--c-paper);border-radius:var(--r-sm);border:1px solid var(--c-border-light);display:inline-block;width:fit-content}
.product-detail .quantity-selector{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap;padding:var(--sp-4) 0;border-top:1px solid var(--c-border-light);border-bottom:1px solid var(--c-border-light)}
.product-detail .quantity-label{font-size:var(--text-sm);font-weight:500;color:var(--c-ink)}
.product-detail .quantity-control{display:flex;align-items:center;gap:var(--sp-2)}
.product-detail .action-buttons{display:flex;gap:var(--sp-3)}
.product-detail .action-buttons .btn{flex:1;text-align:center;min-width:130px;padding:12px 20px}
.product-description{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-md);padding:var(--sp-8);margin-top:var(--sp-8)}
.product-description h2{font-family:var(--font-song);font-size:var(--text-lg);margin-bottom:var(--sp-5);padding-bottom:var(--sp-3);border-bottom:1px solid var(--c-border-light)}
.product-description .content{font-size:var(--text-base);line-height:1.9;color:var(--c-ink-soft)}
.product-description .content img{max-width:100%;border-radius:var(--r-sm);margin:var(--sp-4) 0}

/* ═══════════ ORDER DETAIL ═══════════ */
.order-detail-container{}
.order-detail-container h1{font-family:var(--font-song);text-align:center;margin-bottom:var(--sp-8)}
.order-section{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-md);padding:var(--sp-6);margin-bottom:var(--sp-5);box-shadow:0 1px 2px var(--c-shadow-a)}
.order-section h2{font-size:var(--text-md);margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--c-border-light)}
.info-row{display:flex;align-items:center;padding:7px 0;border-bottom:1px solid var(--c-border-light)}
.info-row:last-child{border-bottom:none}
.info-label{width:110px;flex-shrink:0;font-size:var(--text-sm);font-weight:600;color:var(--c-ink-muted)}
.info-row .info-value{flex:1;background:transparent;border:none;padding:0;font-size:var(--text-base)}
.status-badge{display:inline-block;padding:3px 12px;border-radius:20px;font-size:var(--text-xs);font-weight:600}
.status-badge.status-pending{background:var(--c-bronze-pale);color:var(--c-bronze)}
.status-badge.status-paid{background:rgba(88,129,87,.1);color:var(--c-tea)}
.status-badge.status-shipped{background:rgba(58,90,124,.08);color:#3a5a7c}
.status-badge.status-completed{background:rgba(88,129,87,.08);color:var(--c-tea)}
.status-badge.status-cancelled{background:var(--c-red-soft);color:var(--c-red)}

/* ═══════════ CHECKOUT ═══════════ */
.checkout-container{}
.checkout-container h1{font-family:var(--font-song);font-size:var(--text-2xl);text-align:center;margin-bottom:var(--sp-8)}
.cart-items{margin-bottom:var(--sp-8)}
.cart-items h2{font-family:var(--font-song);font-size:var(--text-md);margin-bottom:var(--sp-4)}
.cart-items table{width:100%}
.cart-items thead{background:var(--c-ink)}
.cart-items thead th{color:var(--c-surface);padding:8px 12px;font-size:var(--text-xs);font-weight:500;letter-spacing:.04em;text-align:left}
.cart-items tbody td{padding:8px 12px;font-size:var(--text-sm);border-bottom:1px solid var(--c-border-light)}
.checkout-container .cart-total{font-size:var(--text-xl)!important;font-weight:700;color:var(--c-red)}
.no-address{color:var(--c-ink-muted);margin:var(--sp-4) 0}
.invoice-section,.remark-section,.checkout-section{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-md);padding:var(--sp-5);margin-bottom:var(--sp-5)}
.invoice-section h3,.remark-section h3,.checkout-section h3{font-size:var(--text-base);margin-bottom:var(--sp-4)}

/* ═══════════ FORM CONTAINER ═══════════ */
.form-container{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-md);padding:var(--sp-8);box-shadow:0 1px 2px var(--c-shadow-a)}
.form-container h1,.form-container h2{font-family:var(--font-song);text-align:center;margin-bottom:var(--sp-6)}

/* ═══════════ AUTH PAGES ═══════════ */
body.auth-page{background:linear-gradient(170deg,#1c1c1e,#2a2724,#1c1c1e);min-height:100vh;display:flex;align-items:center;justify-content:center}
body.auth-page::before{content:'';position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse at 30% 35%,rgba(196,154,94,.05) 0%,transparent 50%),radial-gradient(ellipse at 70% 65%,rgba(88,129,87,.03) 0%,transparent 50%)}
body.auth-page nav{position:fixed;top:0;left:0;right:0;background:rgba(28,28,30,.9);backdrop-filter:blur(20px);text-align:center;padding:16px 0;z-index:100;border-bottom:1px solid rgba(255,255,255,.06)}
body.auth-page nav a{color:rgba(255,255,255,.72);margin:0 20px;font-size:var(--text-sm);transition:color var(--t-fast)}
body.auth-page nav a:hover{color:#fff}
.login-container,.register-container{background:rgba(255,255,255,.97);border-radius:var(--r-md);padding:var(--sp-10) var(--sp-8);width:100%;max-width:420px;box-shadow:0 20px 50px rgba(0,0,0,.25);position:relative;z-index:1;margin-top:60px}
.login-header,.register-header{text-align:center;margin-bottom:var(--sp-8)}
.login-header h1,.register-header h1{font-family:var(--font-song);font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--sp-1);letter-spacing:.08em}
.login-header p,.register-header p{color:var(--c-ink-muted);font-size:var(--text-sm)}
.form-footer{text-align:center;margin-top:var(--sp-5);color:var(--c-ink-muted);font-size:var(--text-sm)}
.form-footer a{color:var(--c-bronze)}
.form-footer a:hover{color:var(--c-ink)}

/* ═══════════ ADDRESS PAGE ═══════════ */
.addresses-container{}
.addresses-container h1{font-family:var(--font-song);text-align:center;margin-bottom:var(--sp-8)}

/* ═══════════ PAYMENT ═══════════ */
.payment-container{text-align:center}
.payment-methods{display:flex;gap:var(--sp-6);justify-content:center;margin:var(--sp-8) 0}
.payment-method{text-align:center;cursor:pointer}
.payment-method img{width:160px;height:160px;object-fit:contain;border:1px solid var(--c-border-light);border-radius:var(--r-md);padding:var(--sp-4);background:var(--c-surface);transition:border-color var(--t-fast)}
.payment-method:hover img{border-color:var(--c-bronze)}

/* ═══════════ ADMIN LAYOUT ═══════════ */
main.content,.content{flex:1;padding:var(--sp-8);background:var(--c-paper);min-height:calc(100vh - 64px)}
.sidebar{
  width:250px;background:var(--c-ink);color:rgba(255,255,255,.65);padding:var(--sp-6) 0;
  flex-shrink:0;border-right:1px solid rgba(255,255,255,.06);
}
.sidebar h2{font-family:var(--font-song);font-size:var(--text-base);color:var(--c-bronze-soft);padding:0 var(--sp-6) var(--sp-5);border-bottom:1px solid rgba(255,255,255,.08);letter-spacing:.06em}
.sidebar ul{list-style:none;padding:var(--sp-3) 0}
.sidebar ul li a{display:block;padding:9px var(--sp-6);color:rgba(255,255,255,.5);font-size:var(--text-sm);letter-spacing:.03em;transition:all var(--t-fast);border-left:2px solid transparent}
.sidebar ul li a:hover{color:#fff;background:rgba(255,255,255,.04);border-left-color:var(--c-bronze)}
.sidebar ul ul{padding:0}
.sidebar ul ul li a{padding:7px var(--sp-6) 7px 40px;font-size:var(--text-xs);color:rgba(255,255,255,.35)}
.sidebar ul ul li a:hover{color:rgba(255,255,255,.6)}

/* ═══════════ ADMIN COMPONENTS ═══════════ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--sp-5);margin-bottom:var(--sp-8)}
.stats-grid .stat-card{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-md);padding:var(--sp-6);text-align:center;box-shadow:0 1px 2px var(--c-shadow-a)}
.stats-grid .stat-card h3{font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;color:var(--c-ink-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--sp-2)}
.stats-grid .stat-card .number{font-family:var(--font-song);font-size:2rem;font-weight:700;color:var(--c-bronze)}
.action-buttons{display:flex;gap:var(--sp-2);flex-wrap:wrap}
.action-btn{display:inline-block;padding:4px 12px;border-radius:var(--r-sm);font-size:var(--text-xs);font-weight:500;text-decoration:none;border:1px solid transparent;transition:all var(--t-fast)}
.edit-btn{background:rgba(88,129,87,.08);color:var(--c-tea);border-color:var(--c-tea)}
.edit-btn:hover{background:var(--c-tea);color:var(--c-surface)}
.delete-btn{background:var(--c-red-soft);color:var(--c-red);border-color:var(--c-red)}
.delete-btn:hover{background:var(--c-red);color:var(--c-surface)}
.publish-btn{background:var(--c-bronze-pale);color:var(--c-bronze);border-color:var(--c-bronze)}
.publish-btn:hover{background:var(--c-bronze);color:var(--c-surface)}
.unpublish-btn{background:var(--c-ink-soft);color:var(--c-surface)}
.unpublish-btn:hover{background:var(--c-ink)}
.status-published{display:inline-block;padding:2px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:600;background:rgba(88,129,87,.1);color:var(--c-tea)}
.status-unpublished{display:inline-block;padding:2px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:600;background:var(--c-ink-soft);color:var(--c-surface)}
.back-link{display:inline-block;margin-bottom:var(--sp-5);color:var(--c-ink-muted);font-size:var(--text-sm)}
.back-link:hover{color:var(--c-bronze)}
.btn-group{display:flex;gap:var(--sp-2);flex-wrap:wrap}

/* ═══════════ ADMIN TABLE IMAGES ═══════════ */
.products-table td img,.articles-table td img{width:56px;height:56px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--c-border-light)}
.admin-preview-img{max-width:260px;max-height:260px;object-fit:contain;border-radius:var(--r-md);border:1px solid var(--c-border)}

/* ═══════════ MATERIALS ═══════════ */
.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:var(--sp-4)}
.material-card{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-md);overflow:hidden;box-shadow:0 1px 2px var(--c-shadow-a);transition:all var(--t-base) var(--ease);position:relative}
.material-card:hover{transform:translateY(-2px);box-shadow:0 1px 2px var(--c-shadow-a),0 6px 18px var(--c-shadow-b)}
.material-card img{width:100%;height:140px;object-fit:cover;display:block;cursor:pointer}
.material-card video{width:100%;height:140px;object-fit:cover}
.material-placeholder{display:flex;align-items:center;justify-content:center;height:140px;background:var(--c-paper);color:var(--c-ink-muted)}
.material-card .material-name{font-size:var(--text-xs);font-weight:600;padding:var(--sp-2) var(--sp-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.material-card .material-meta{font-size:var(--text-xs);color:var(--c-ink-muted);padding:0 var(--sp-3) var(--sp-2)}
.material-card .action-buttons{padding:0 var(--sp-3) var(--sp-3)}

/* ═══════════ CONVERSATION ═══════════ */
.conversation-container{background:var(--c-surface);border:1px solid var(--c-border-light);border-radius:var(--r-md);overflow:hidden}
.conversation-info{padding:var(--sp-5);border-bottom:1px solid var(--c-border-light);background:var(--c-paper)}
.conversation-messages{padding:var(--sp-5)}
.conversation-messages .message{padding:var(--sp-4);border-radius:var(--r-sm);margin-bottom:var(--sp-3);line-height:1.6;font-size:var(--text-sm)}
.conversation-messages .message.user{background:var(--c-bronze-pale);border-left:3px solid var(--c-bronze)}
.conversation-messages .message.admin{background:rgba(88,129,87,.08);border-left:3px solid var(--c-tea)}

/* ═══════════ PAGE TITLE & CATEGORY FILTER ═══════════ */
.page-title{
  font-family:var(--font-song);font-size:var(--text-2xl);font-weight:600;
  text-align:center;margin:var(--sp-8) 0 var(--sp-6);
}
.category-filter{
  display:flex;flex-wrap:wrap;gap:var(--sp-2);justify-content:center;
  margin-bottom:var(--sp-8);
}
.category-btn{
  display:inline-block;padding:7px 20px;border:1px solid var(--c-border);
  border-radius:20px;font-size:var(--text-sm);color:var(--c-ink-soft);
  text-decoration:none;background:var(--c-surface);
  transition:all var(--t-fast) var(--ease);
}
.category-btn:hover{color:var(--c-bronze);border-color:var(--c-bronze)}
.category-btn.active{background:var(--c-bronze);color:var(--c-surface);border-color:var(--c-bronze)}

/* ═══════════ ARTICLE DETAIL ═══════════ */
.article-detail{}
.article-detail h1{
  font-family:var(--font-song);font-size:var(--text-3xl);font-weight:700;
  text-align:center;margin-bottom:var(--sp-8);line-height:1.35;
  letter-spacing:.04em;
}
.article-detail>.article-image{
  width:100%;height:auto;max-height:480px;object-fit:cover;
  border-radius:var(--r-md);margin-bottom:var(--sp-8);
  border:1px solid var(--c-border-light);
}
.article-detail .article-content{
  max-width:780px;margin:0 auto;
  font-size:var(--text-md);line-height:2.1;color:var(--c-ink-soft);
}
.article-detail .article-content p{margin-bottom:var(--sp-6)}
.article-detail .article-content h2,.article-detail .article-content h3{
  font-family:var(--font-song);color:var(--c-ink);margin:var(--sp-8) 0 var(--sp-4);
}
.article-detail .article-content h2{font-size:var(--text-xl)}
.article-detail .article-content h3{font-size:var(--text-lg)}
.article-detail .article-content img{
  max-width:100%;border-radius:var(--r-sm);margin:var(--sp-5) 0;
}
.article-detail .article-content blockquote{
  border-left:3px solid var(--c-bronze);padding:var(--sp-3) var(--sp-5);
  margin:var(--sp-5) 0;background:var(--c-bronze-pale);
  font-style:italic;color:var(--c-ink-soft);
}
.article-detail .article-content ul,.article-detail .article-content ol{
  padding-left:var(--sp-6);margin:var(--sp-4) 0;
}
.article-detail .article-content li{margin-bottom:var(--sp-2)}

/* ═══════════ CATEGORY TAGS ═══════════ */
.category-list{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-6)}
.category-tag{padding:6px 16px;border:1px solid var(--c-border);border-radius:20px;font-size:var(--text-sm);color:var(--c-ink-soft);cursor:pointer;transition:all var(--t-fast);background:var(--c-surface)}
.category-tag:hover,.category-tag.active{background:var(--c-bronze);color:var(--c-surface);border-color:var(--c-bronze)}

/* ═══════════ UTILITIES ═══════════ */
.text-muted{color:var(--c-ink-muted)}

/* ═══════════ FOOTER ═══════════ */
footer{
  background:var(--c-ink);color:rgba(255,255,255,.55);
  padding:var(--sp-12) 0 var(--sp-6);margin-top:var(--sp-16);
  position:relative;
}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c-bronze),transparent)}
.footer-content{max-width:1200px;margin:0 auto;padding:0 var(--sp-6);display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--sp-8)}
.footer-section h3{font-family:var(--font-song);font-size:var(--text-sm);color:var(--c-surface);margin-bottom:var(--sp-5);letter-spacing:.06em;padding-bottom:var(--sp-2);position:relative}
.footer-section h3::after{content:'';position:absolute;bottom:0;left:0;width:20px;height:1px;background:var(--c-bronze)}
.footer-section p{font-size:var(--text-sm);line-height:1.8;color:rgba(255,255,255,.4)}
.footer-section ul{list-style:none}
.footer-section ul li{margin-bottom:var(--sp-2)}
.footer-section ul li a{color:rgba(255,255,255,.4);font-size:var(--text-sm);transition:color var(--t-fast)}
.footer-section ul li a:hover{color:var(--c-bronze-soft)}
.footer-bottom{text-align:center;margin-top:var(--sp-8);padding-top:var(--sp-5);border-top:1px solid rgba(255,255,255,.06)}
.footer-bottom p{font-size:var(--text-xs);color:rgba(255,255,255,.25);letter-spacing:.04em}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:768px){
  :root{--sp-6:16px;--sp-8:24px;--sp-10:28px;--sp-12:32px;--sp-16:40px}
  .container{padding:0 var(--sp-4)}
  header h1{font-size:1.6rem}
  nav{flex-wrap:wrap;height:auto;padding:var(--sp-2) var(--sp-4)}
  nav a{padding:var(--sp-2) var(--sp-3);font-size:var(--text-xs)}
  .hero-section{padding:var(--sp-10) var(--sp-4);margin:var(--sp-5) 0}
  .hero-section h2{font-size:var(--text-xl)}
  .section-title{font-size:var(--text-xl)}
  .product-grid,.article-grid{grid-template-columns:1fr}
  .product-detail-grid{grid-template-columns:1fr;gap:var(--sp-6)}
  .cart-item{flex-direction:column;align-items:flex-start}
  .cart-item-image{width:100%;height:140px}
  .order-header{flex-direction:column;align-items:flex-start;gap:var(--sp-2)}
  .order-item{flex-direction:column;align-items:flex-start}
  .cart-actions,.order-actions{flex-direction:column}
  .cart-actions .btn,.order-actions .btn{width:100%}
  .profile-info{grid-template-columns:1fr}
  .profile-tabs{overflow-x:auto;flex-wrap:nowrap}
  .footer-content{grid-template-columns:1fr}
  .container:not(:has(.sidebar)){display:block}
  .sidebar{width:100%}
  .stats-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:769px) and (max-width:1100px){
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .article-grid{grid-template-columns:repeat(2,1fr)}
  .product-detail-grid{grid-template-columns:1fr 1fr;gap:var(--sp-6)}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
