:root {
  --bg: #ffffff;
  --bg-warm: #faf8f5;
  --bg-soft: #f5f5f0;
  --text: #1a1a1a;
  --text-secondary: #555555;
  --text-muted: #888888;
  --border: #e8e8e8;
  --border-light: #f0f0f0;
  --primary: #e84c6c;
  --primary-dark: #d43d5c;
  --primary-light: #fff0f3;
  --accent-teal: #0d7377;
  --accent-teal-dark: #0a5a5d;
  --success: #22c55e;
  --warning: #f59e0b;
  --danger: #ef4444;
  --radius-sm: 8px;
  --radius: 16px;
  --radius-lg: 20px;
  --shadow: 0 2px 12px rgba(0,0,0,0.06);
  --shadow-md: 0 8px 30px rgba(0,0,0,0.08);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.10);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;font-size:15px}
a{color:var(--text);text-decoration:none}
a:hover{color:var(--primary)}
img{max-width:100%;display:block}
.container{max-width:1500px;margin:0 auto;padding:0 24px}

/* ===== Ticker ===== */
.ticker{background:var(--accent-teal);color:#fff;font-size:13px;padding:10px 0;overflow:hidden;position:relative}
.ticker-track{display:flex;gap:48px;animation:ticker 20s linear infinite;white-space:nowrap;width:max-content}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{display:flex;align-items:center;gap:8px}
.ticker-item strong{font-weight:600}
.ticker-item a{color:#a8e6cf;text-decoration:underline}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== Header ===== */
.header{background:linear-gradient(180deg,#fff 0%,#fafafa 100%);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.header-main{padding:20px 0}
.header-main .container{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;padding-top:4px}
.logo img{height:64px;width:auto;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.08))}
.logo:hover{text-decoration:none}
.search-wrap{flex:1;max-width:720px;display:flex;flex-direction:column;gap:6px;position:relative}
.search-popover{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(0,0,0,0.12);border:1px solid var(--border-light);z-index:100;padding:16px;display:none}
.search-popover.show{display:block}
.search-popover-section{margin-bottom:16px}
.search-popover-section:last-child{margin-bottom:0}
.search-popover-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:14px}
.search-popover-header span{color:var(--text-secondary);font-weight:500}
.search-popover-header a{color:var(--text-muted);font-size:13px;text-decoration:none}
.search-popover-header a:hover{color:var(--primary)}
.search-popover-tags{display:flex;flex-wrap:wrap;gap:8px}
.search-popover-tags a{display:inline-block;padding:6px 14px;background:var(--bg-soft);border-radius:var(--radius-sm);font-size:13px;color:var(--text);text-decoration:none;transition:background .15s}
.search-popover-tags a:hover{background:var(--primary);color:#fff}
.search-popover-list{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}
.search-popover-list a{color:var(--text);font-size:13px;text-decoration:none;padding:4px 0;display:block;transition:color .15s}
.search-popover-list a:hover{color:var(--primary)}
.search-form{display:flex;align-items:center;background:#fff;border-radius:var(--radius-lg);border:2px solid var(--border);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.search-form:focus-within{border-color:var(--primary);box-shadow:0 4px 16px rgba(232,76,108,0.15)}
.search-cat{position:relative;flex-shrink:0}
.search-cat select{appearance:none;background:var(--bg-soft);border:none;border-right:1px solid var(--border-light);padding:12px 28px 12px 16px;font-size:14px;color:var(--text-secondary);cursor:pointer;outline:none;font-weight:500}

.search-form input{background:none;border:none;outline:none;flex:1;font-size:15px;color:var(--text);padding:12px 16px;min-width:0}
.search-form input::placeholder{color:var(--text-muted)}
.search-form button{background:var(--primary);color:#fff;border:none;padding:12px 32px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}
.search-form button:hover{background:var(--primary-dark)}
.search-hotwords{display:flex;gap:12px;align-items:center;flex-wrap:wrap;font-size:12px;padding-left:4px}
.search-hotwords a{color:var(--text-muted);text-decoration:none;transition:color .15s}
.search-hotwords a:hover{color:var(--primary)}
.search-hotwords .hot-label{color:var(--primary);font-weight:600}
.header-actions{display:flex;gap:20px;align-items:center;padding-top:12px}
.header-actions a,.header-actions button{background:none;border:none;cursor:pointer;padding:8px;color:var(--text);display:flex;align-items:center;justify-content:center;position:relative}
.header-actions a:hover,.header-actions button:hover{color:var(--primary)}
.header-actions svg{width:22px;height:22px}
.cart-count{position:absolute;top:-2px;right:-2px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}

/* ===== Home Layout ===== */
.home-layout{display:flex;gap:16px;margin:24px 0}
.home-sidebar{width:220px;background:#fff;border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden;flex-shrink:0;height:fit-content;box-shadow:var(--shadow)}
.home-cat-title{padding:14px 16px;font-size:15px;font-weight:700;background:var(--bg-soft);border-bottom:1px solid var(--border-light)}
.home-cat-list{padding:8px 0}
.home-cat-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s;text-decoration:none}
.home-cat-item:hover{background:var(--bg-soft);color:var(--primary);text-decoration:none}
.home-cat-item svg{width:18px;height:18px;opacity:.6;flex-shrink:0}
.home-cat-item:hover svg{opacity:1}
.home-main{flex:1;min-width:0}

/* ===== Hero ===== */
.hero{position:relative;border-radius:var(--radius-lg);overflow:hidden;margin:24px 0;aspect-ratio:3/1;min-height:360px;display:flex;align-items:center;justify-content:center}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,0.35),rgba(0,0,0,0.1))}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;max-width:600px;padding:24px}
.hero-content h1{font-size:3rem;font-weight:700;margin-bottom:12px;line-height:1.2;letter-spacing:-1px}
.hero-content p{font-size:1.15rem;margin-bottom:28px;opacity:0.95}
.hero-btns{display:flex;gap:16px;justify-content:center}
.btn-pill{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;padding:14px 32px;border-radius:100px;border:none;cursor:pointer;font-size:15px;font-weight:600;transition:all .2s}
.btn-pill:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none;color:#fff}
.btn-pill-outline{background:rgba(255,255,255,0.2);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,0.4)}
.btn-pill-outline:hover{background:rgba(255,255,255,0.35);color:#fff}

/* ===== Section Titles ===== */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px}
.section-head h2{font-size:1.6rem;font-weight:700;letter-spacing:-0.3px}
.section-head a{font-size:14px;color:var(--primary);font-weight:500}
.section-head a:hover{text-decoration:underline}

/* ===== Category Pills ===== */
.cat-scroll{display:flex;gap:16px;overflow-x:auto;padding:8px 0 16px;margin-bottom:8px;scrollbar-width:none}
.cat-scroll::-webkit-scrollbar{display:none}
.cat-pill{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:transform .2s}
.cat-pill:hover{transform:translateY(-4px);text-decoration:none}
.cat-pill:hover .cat-pill-img{box-shadow:var(--shadow-md)}
.cat-pill-img{width:100px;height:100px;border-radius:50%;overflow:hidden;background:var(--bg-soft);box-shadow:var(--shadow);transition:box-shadow .2s}
.cat-pill-img img{width:100%;height:100%;object-fit:cover}
.cat-pill span{font-size:13px;font-weight:500;color:var(--text-secondary)}

/* ===== Product Card ===== */
.product-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;padding:24px 0}
@media(max-width:1200px){.product-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:1024px){.product-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.product-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
.product-card{background:var(--bg);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s;position:relative;border:1px solid var(--border-light)}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.product-img-wrap{position:relative;aspect-ratio:1;background:var(--bg-soft);overflow:hidden}
.product-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.product-card:hover .product-img-wrap img{transform:scale(1.05)}
.product-badge{position:absolute;top:12px;left:12px;background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:5px 10px;border-radius:20px;z-index:2}
.product-badge.stock-low{background:var(--warning);color:#fff}
.product-badge.stock-out{background:var(--text-muted);color:#fff}
.product-wishlist{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.9);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s;z-index:2}
.product-card:hover .product-wishlist{opacity:1}
.product-wishlist:hover{background:#fff;color:var(--primary)}
.product-swatches{position:absolute;bottom:12px;left:12px;display:flex;gap:6px;z-index:2}
.swatch{width:18px;height:18px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--border);cursor:pointer}
.product-body{padding:16px}
.product-brand{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:4px}
.product-name{font-size:14px;font-weight:500;color:var(--text);line-height:1.4;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:40px}
.product-name:hover{color:var(--primary)}
.product-price-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.product-price{font-size:16px;font-weight:700;color:var(--text)}
.product-price del{font-size:13px;color:var(--text-muted);font-weight:400;margin-left:4px}
.product-price .save{color:var(--primary);font-size:12px;font-weight:600;background:var(--primary-light);padding:2px 8px;border-radius:10px;margin-left:4px}

/* ===== Filters Bar ===== */
.filter-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border-light);margin-bottom:16px;flex-wrap:wrap;gap:12px}
.filter-group{display:flex;gap:12px;align-items:center}
.filter-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:13px;color:var(--text-secondary);cursor:pointer}
.filter-btn:hover{border-color:var(--text-muted)}
.filter-btn svg{width:14px;height:14px}
.sort-select{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:13px;color:var(--text-secondary);cursor:pointer;outline:none}
.result-count{font-size:14px;color:var(--text-muted)}

/* ===== Breadcrumb ===== */
.breadcrumb{display:flex;align-items:center;gap:8px;padding:20px 0;font-size:13px;color:var(--text-muted)}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--text)}
.breadcrumb-sep{opacity:0.5}

/* ===== Product Detail ===== */
.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:32px 0}
@media(max-width:768px){.pd-grid{grid-template-columns:1fr;gap:32px}}
.pd-gallery{position:sticky;top:100px}
.pd-main-img{width:100%;aspect-ratio:1;background:var(--bg-soft);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px}
.pd-main-img img{width:100%;height:100%;object-fit:cover}
.pd-thumb-list{display:flex;gap:12px;overflow-x:auto}
.pd-thumb{width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid transparent;cursor:pointer;background:var(--bg-soft);flex-shrink:0}
.pd-thumb img{width:100%;height:100%;object-fit:cover}
.pd-thumb.active{border-color:var(--primary)}
.pd-info{padding-top:8px}
.pd-brand{font-size:13px;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}
.pd-name{font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:12px;letter-spacing:-0.5px}
.pd-meta{display:flex;align-items:center;gap:16px;margin-bottom:20px;font-size:14px;color:var(--text-muted)}
.pd-meta .rating{display:flex;align-items:center;gap:4px;color:var(--warning)}
.pd-price{font-size:1.8rem;font-weight:700;margin-bottom:24px;display:flex;align-items:center;gap:12px}
.pd-price del{font-size:1.1rem;color:var(--text-muted);font-weight:400}
.pd-price .save-tag{background:var(--primary-light);color:var(--primary);font-size:13px;font-weight:600;padding:4px 12px;border-radius:20px}
.pd-actions{display:flex;gap:12px;margin-bottom:24px}
.pd-qty{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.pd-qty button{width:44px;height:48px;border:none;background:var(--bg);cursor:pointer;font-size:18px;color:var(--text)}
.pd-qty button:hover{background:var(--border-light)}
.pd-qty input{width:60px;height:48px;border:none;text-align:center;font-size:16px;font-weight:600;outline:none}
.pd-add{flex:1;height:48px;background:var(--text);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}
.pd-add:hover{background:var(--primary)}
.pd-desc{color:var(--text-secondary);line-height:1.8;margin-bottom:32px}
.pd-features{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.pd-feature{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary);padding:10px 14px;background:var(--bg-soft);border-radius:var(--radius-sm)}
.pd-feature svg{width:18px;height:18px;color:var(--success);flex-shrink:0}

/* ===== Cart ===== */
.page-title{font-size:1.8rem;font-weight:700;margin:32px 0 24px;letter-spacing:-0.3px}
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:40px;padding-bottom:60px}
@media(max-width:900px){.cart-layout{grid-template-columns:1fr}}
.cart-item{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid var(--border-light)}
.cart-item-img{width:100px;height:100px;border-radius:var(--radius);overflow:hidden;background:var(--bg-soft);flex-shrink:0}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1}
.cart-item-name{font-weight:600;margin-bottom:4px}
.cart-item-variant{font-size:13px;color:var(--text-muted);margin-bottom:8px}
.cart-item-actions{display:flex;gap:16px;align-items:center;margin-top:8px}
.cart-item-actions button{background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer}
.cart-item-actions button:hover{color:var(--danger)}
.cart-item-price{font-weight:600;font-size:15px}
.cart-summary{background:var(--bg-soft);border-radius:var(--radius);padding:24px;position:sticky;top:100px}
.cart-summary h3{font-size:1.1rem;font-weight:700;margin-bottom:20px}
.summary-row{display:flex;justify-content:space-between;padding:10px 0;font-size:14px;color:var(--text-secondary)}
.summary-row.total{font-size:1.2rem;font-weight:700;color:var(--text);border-top:2px solid var(--border);margin-top:8px;padding-top:16px}
.checkout-btn{width:100%;height:52px;background:var(--text);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;margin-top:16px;transition:all .2s}
.checkout-btn:hover{background:var(--primary)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;background:var(--text);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;line-height:1;text-decoration:none}
.btn:hover{background:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-md);text-decoration:none;color:#fff}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

.btn-primary{background:var(--primary)}
.btn-primary:hover{background:var(--primary-dark)}

.btn-danger{background:var(--danger)}
.btn-danger:hover{background:#dc2626}

.btn-secondary{background:var(--bg-soft);color:var(--text-secondary);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--border-light);color:var(--text);box-shadow:none;transform:none}

.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--text)}
.btn-outline:hover{background:var(--text);color:#fff}

.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}
.btn-ghost:hover{background:var(--bg-soft);color:var(--text);box-shadow:none;transform:none}

.btn-sm{padding:6px 12px;font-size:13px;border-radius:var(--radius-sm)}
.btn-lg{padding:14px 28px;font-size:16px;border-radius:14px}

/* ===== Checkout Button ===== */
.checkout-btn{width:100%;height:52px;background:linear-gradient(135deg,var(--text) 0%,#2d2d2d 100%);color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;margin-top:16px;transition:all .25s;box-shadow:0 4px 16px rgba(0,0,0,0.1)}
.checkout-btn:hover{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,76,108,0.25)}
.checkout-btn:active{transform:translateY(0)}

/* ===== Quantity Input ===== */
.qty-input{display:flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;height:36px}
.qty-input button{width:32px;height:100%;border:none;background:transparent;cursor:pointer;font-size:16px;color:var(--text);display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s}
.qty-input button:hover{background:var(--bg-soft);color:var(--primary)}
.qty-input input{width:44px;height:100%;border:none;text-align:center;font-size:14px;font-weight:600;outline:none;background:transparent}

/* ===== Payment Cards ===== */
.payment-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(max-width:600px){.payment-grid{grid-template-columns:1fr}}
.payment-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;background:var(--bg)}
.payment-card:hover{border-color:var(--text-muted)}
.payment-card.active{border-color:var(--primary);background:var(--primary-light)}
.payment-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;flex-shrink:0}

/* ===== Order Status ===== */
.order-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px}
.status-pending{background:#fef3c7;color:#92400e}
.status-paid{background:#d1fae5;color:#065f46}
.status-processing{background:#dbeafe;color:#1e40af}
.status-shipped{background:#e0e7ff;color:#3730a3}
.status-delivered{background:#d1fae5;color:#065f46}
.status-cancelled{background:#fee2e2;color:#991b1b}
.status-refunded{background:#f3f4f6;color:#4b5563}

/* ===== Section Title ===== */
.section-title{font-size:1.1rem;font-weight:700;margin-bottom:16px;color:var(--text)}

/* ===== Checkout ===== */
.checkout-grid{display:grid;grid-template-columns:1fr 380px;gap:48px;padding:32px 0 60px}
@media(max-width:900px){.checkout-grid{grid-template-columns:1fr}}
.checkout-section{background:var(--bg);border-radius:var(--radius);padding:28px;margin-bottom:20px;border:1px solid var(--border-light)}
.checkout-section h3{font-size:1.1rem;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.checkout-section h3 .step-num{width:28px;height:28px;border-radius:50%;background:var(--text);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form-group{margin-bottom:16px}
.form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--text-secondary)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:14px;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--text)}
#note,.checkout-section textarea{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:14px;outline:none;transition:border-color .2s;resize:vertical;min-height:80px}
#note:focus,.checkout-section textarea:focus{border-color:var(--text)}
.radio-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;margin-bottom:8px}
.radio-card:hover{border-color:var(--text-muted)}
.radio-card.active{border-color:var(--text);background:var(--bg-soft)}
.radio-card input{width:18px;height:18px;accent-color:var(--text)}

/* ===== Auth ===== */
.auth-page{min-height:100vh;display:flex;background:linear-gradient(135deg,#0a5a5d 0%,#0d7377 35%,#14919b 70%,#1ab5a3 100%)}
.auth-left{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden;color:#fff;padding:60px}
.auth-brand{text-align:center;position:relative;z-index:2}
.auth-brand img{height:72px;width:auto;margin-bottom:20px;filter:brightness(0) invert(1) drop-shadow(0 4px 12px rgba(0,0,0,0.15))}
.auth-brand h1{font-size:2.8rem;font-weight:800;margin-bottom:12px;letter-spacing:3px;text-shadow:0 2px 8px rgba(0,0,0,0.2)}
.auth-brand p{font-size:1.05rem;opacity:0.88;font-weight:300;letter-spacing:1px}
.auth-shapes{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.shape{position:absolute;border-radius:50%;background:rgba(255,255,255,0.06)}
.shape-1{width:500px;height:500px;top:-120px;right:-120px}
.shape-2{width:350px;height:350px;bottom:-80px;left:-80px}
.shape-3{width:180px;height:180px;top:60%;left:55%;background:rgba(255,255,255,0.04)}
.auth-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}
.auth-card{width:100%;max-width:460px;background:#fff;border-radius:24px;padding:48px;box-shadow:0 8px 40px rgba(0,0,0,0.1);animation:authFadeIn .7s cubic-bezier(0.22,1,0.36,1), authFloat 4s ease-in-out infinite}
@keyframes authFadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes authFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.auth-header{text-align:center;margin-bottom:32px}
.auth-header h2{font-size:1.75rem;font-weight:700;margin-bottom:8px;color:var(--text)}
.auth-header p{color:var(--text-muted);font-size:14px}
.auth-tabs{display:flex;margin-bottom:28px;background:var(--bg-soft);border-radius:12px;padding:4px}
.auth-tabs a{flex:1;text-align:center;padding:12px;font-size:15px;font-weight:500;color:var(--text-muted);border-radius:10px;transition:all .2s}
.auth-tabs a.active{background:#fff;color:var(--text);box-shadow:0 1px 6px rgba(0,0,0,0.06);font-weight:600}
.auth-field{margin-bottom:20px}
.auth-field label{display:block;margin-bottom:8px;font-size:13px;font-weight:600;color:var(--text-secondary);letter-spacing:0.3px}
.auth-field input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:12px;background:#fff;font-size:15px;outline:none;transition:all .2s}
.auth-field input:focus{border-color:var(--accent-teal);box-shadow:0 0 0 3px rgba(13,115,119,0.08)}
.auth-btn{width:100%;padding:16px;background:var(--text);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .25s;margin-top:4px}
.auth-btn:hover{background:var(--accent-teal);transform:translateY(-1px);box-shadow:0 6px 20px rgba(13,115,119,0.18)}
.auth-forgot{text-align:right;margin-top:12px;font-size:13px}
.auth-forgot a{color:var(--text-muted);font-weight:500;transition:color .15s}
.auth-forgot a:hover{color:var(--accent-teal)}
.auth-link{text-align:center;margin-top:28px;font-size:13px;color:var(--text-muted)}
.auth-link a{color:var(--accent-teal);font-weight:500}
.auth-link a:hover{text-decoration:underline}
@media(max-width:900px){.auth-left{display:none}.auth-right{padding:24px}.auth-card{padding:36px;border-radius:20px;animation:none}}

/* ===== User Center ===== */
.uc-layout{display:grid;grid-template-columns:240px 1fr;gap:32px;padding:32px 0 60px}
@media(max-width:768px){.uc-layout{grid-template-columns:1fr}}
.uc-sidebar{background:var(--bg);border-radius:var(--radius);padding:8px;border:1px solid var(--border-light);position:sticky;top:100px;height:fit-content}
.uc-sidebar a{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:2px}
.uc-sidebar a:hover,.uc-sidebar a.active{background:var(--bg-soft);color:var(--text);text-decoration:none}
.uc-main{background:var(--bg);border-radius:var(--radius);padding:28px;border:1px solid var(--border-light)}

/* ===== Footer ===== */
.footer{background:var(--bg-warm);border-top:1px solid var(--border-light);padding:60px 0 32px;margin-top:auto}
.footer-grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:40px;margin-bottom:40px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-brand{font-size:1.6rem;font-weight:800;margin-bottom:12px}
.footer-brand span{color:var(--primary)}
.footer-desc{color:var(--text-muted);font-size:14px;line-height:1.7;max-width:280px}
.footer-col h4{font-size:14px;font-weight:700;margin-bottom:16px;text-transform:uppercase;letter-spacing:0.5px}
.footer-col a{display:block;color:var(--text-muted);font-size:14px;padding:6px 0;transition:color .2s}
.footer-col a:hover{color:var(--text);text-decoration:none}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border-light);font-size:13px;color:var(--text-muted)}
@media(max-width:600px){.footer-bottom{flex-direction:column;gap:8px;text-align:center}}

/* ===== Toast ===== */
#toast{position:fixed;top:24px;right:24px;background:#fff;border:1px solid var(--border-light);padding:16px 24px;border-radius:var(--radius);z-index:200;transform:translateX(150%);transition:transform .35s cubic-bezier(0.34,1.56,0.64,1);box-shadow:var(--shadow-lg);font-weight:500;font-size:14px;display:flex;align-items:center;gap:10px}
#toast.show{transform:translateX(0)}
#toast.success{color:var(--success);border-color:rgba(34,197,94,0.3)}
#toast.error{color:var(--danger);border-color:rgba(239,68,68,0.3)}

/* ===== Pagination ===== */
.pagination{display:flex;gap:8px;justify-content:center;padding:32px 0}
.pagination a{padding:10px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;min-width:40px;text-align:center}
.pagination a:hover,.pagination a.active{background:var(--text);border-color:var(--text);color:#fff;text-decoration:none}

/* ===== Empty State ===== */
.empty-state{text-align:center;padding:80px 20px;color:var(--text-muted)}
.empty-state h3{font-size:1.2rem;color:var(--text);margin-bottom:8px}

/* ===== Dropdown ===== */
.dropdown{position:relative}
.dropdown-toggle{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);padding:4px 8px;border-radius:var(--radius-sm);white-space:nowrap}
.dropdown-toggle:hover{color:var(--text);background:var(--bg-soft)}
.dropdown-toggle svg{transition:transform .2s}
.dropdown.open .dropdown-toggle svg{transform:rotate(180deg)}
.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:180px;padding:8px 0;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .2s;z-index:150}
.dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:13px;color:var(--text-secondary);transition:all .1s}
.dropdown-item:hover{background:var(--bg-soft);color:var(--text);text-decoration:none}
.dropdown-item.active{background:var(--bg-soft);color:var(--text);font-weight:600}
.header-divider{width:1px;height:20px;background:var(--border-light);margin:0 4px}

/* ===== Reviews ===== */
.review-stats{display:grid;grid-template-columns:200px 1fr;gap:32px;padding:24px;background:var(--bg-soft);border-radius:var(--radius);margin-bottom:24px}
@media(max-width:600px){.review-stats{grid-template-columns:1fr;gap:16px}}
.review-avg{text-align:center}
.review-avg .num{font-size:3rem;font-weight:700;color:var(--text);line-height:1}
.review-avg .stars{color:var(--warning);font-size:1.5rem;margin:8px 0}
.review-avg .count{font-size:14px;color:var(--text-muted)}
.review-bars{display:flex;flex-direction:column;gap:8px;justify-content:center}
.review-bar{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted)}
.review-bar .bar{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.review-bar .fill{height:100%;background:var(--warning);border-radius:4px}
.review-bar .pct{min-width:36px;text-align:right}
.review-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.review-tab{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);font-size:14px;cursor:pointer;transition:all .2s}
.review-tab:hover{border-color:var(--text)}
.review-tab.active{background:var(--text);color:#fff;border-color:var(--text)}
.review-item{padding:20px 0;border-bottom:1px solid var(--border-light)}
.review-item:last-child{border-bottom:none}
.review-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.review-user{display:flex;align-items:center;gap:10px}
.review-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}
.review-name{font-size:14px;font-weight:600}
.review-time{font-size:12px;color:var(--text-muted)}
.review-rating{color:var(--warning);font-size:14px;margin-bottom:6px}
.review-title{font-size:15px;font-weight:600;margin-bottom:6px}
.review-content{font-size:14px;color:var(--text-secondary);line-height:1.6}
.review-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--success);margin-top:8px}
.review-form{background:var(--bg-soft);border-radius:var(--radius);padding:24px;margin-bottom:24px}
.review-form h3{font-size:1rem;font-weight:700;margin-bottom:16px}
.star-input{display:flex;gap:6px;font-size:28px;color:var(--border);cursor:pointer;margin-bottom:16px}
.star-input .star.selected{color:var(--warning)}
.star-input .star:hover{color:var(--warning)}
.review-empty{text-align:center;padding:60px 0;color:var(--text-muted)}
