@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --green:      #1fca72;
  --green-dk:   #17a85c;
  --green-lt:   #d1fae5;
  --green-text: #065f46;
  --yellow:     #fbbf24;
  --red:        #ef4444;
  --red-lt:     #fee2e2;
  --radius-sm:  6px;
  --radius:     10px;
  --radius-lg:  14px;
  --radius-xl:  20px;
  --font-head:  'Sora', system-ui, sans-serif;
  --font-body:  'Inter', system-ui, sans-serif;
  --tr:         .18s ease;
}
[data-theme="light"],:root{--bg:#f9fafb;--bg-card:#ffffff;--bg-input:#ffffff;--bg-hover:#f3f4f6;--bg-muted:#f3f4f6;--border:#e5e7eb;--border-med:#d1d5db;--ink:#111827;--ink-2:#374151;--ink-3:#6b7280;--ink-4:#9ca3af;--hero-bg:#0f0f1a;--hero-bg2:#16213e;--shadow-sm:0 1px 3px rgba(0,0,0,.06);--shadow-md:0 4px 16px rgba(0,0,0,.08);--shadow-lg:0 12px 40px rgba(0,0,0,.12);--navbar-bg:rgba(249,250,251,0.94);--admin-sb:#111827;--admin-sb-text:rgba(255,255,255,0.65)}
[data-theme="dark"]{--bg:#0f0f1a;--bg-card:#1a1a2e;--bg-input:#1e1e35;--bg-hover:#252542;--bg-muted:#1a1a2e;--border:#2d2d4e;--border-med:#3d3d6e;--ink:#f9fafb;--ink-2:#e5e7eb;--ink-3:#9ca3af;--ink-4:#6b7280;--hero-bg:#07070f;--hero-bg2:#0d1226;--shadow-sm:0 1px 3px rgba(0,0,0,.3);--shadow-md:0 4px 16px rgba(0,0,0,.4);--shadow-lg:0 12px 40px rgba(0,0,0,.5);--navbar-bg:rgba(15,15,26,0.97);--admin-sb:#07070f;--admin-sb-text:rgba(255,255,255,0.6)}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background var(--tr),color var(--tr)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Navbar */
.navbar{position:sticky;top:0;z-index:200;background:var(--navbar-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:60px;transition:background var(--tr)}
.navbar-inner{max-width:1280px;margin:0 auto;padding:0 32px;height:100%;display:flex;align-items:center;gap:12px}
.navbar-logo{display:flex;align-items:center;gap:8px;font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--ink);flex-shrink:0}
.navbar-logo-icon{width:28px;height:28px;background:var(--green);border-radius:6px;display:flex;align-items:center;justify-content:center}
.navbar-logo-icon svg{width:14px;height:14px;fill:white}
.navbar-nav{display:flex;align-items:center;gap:2px;flex:1}
.navbar-nav a{padding:6px 11px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--ink-3);transition:all var(--tr)}
.navbar-nav a:hover,.navbar-nav a.active{color:var(--ink);background:var(--bg-hover)}
.navbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.theme-toggle{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--bg-hover);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;transition:all var(--tr);flex-shrink:0}
.theme-toggle:hover{background:var(--border)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 17px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font-body);cursor:pointer;text-decoration:none;border:1px solid transparent;transition:all var(--tr);line-height:1;white-space:nowrap}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-lg{padding:12px 24px;font-size:14px}
.btn-block{width:100%;justify-content:center}
.btn-green{background:var(--green);color:white;border-color:var(--green)}
.btn-green:hover{background:var(--green-dk);border-color:var(--green-dk);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--ink-2);border-color:var(--border-med)}
.btn-outline:hover{background:var(--bg-hover)}
.btn-ghost{background:transparent;color:var(--ink-3);border-color:transparent}
.btn-ghost:hover{color:var(--ink);background:var(--bg-hover)}
.btn-dark{background:var(--ink);color:var(--bg-card);border-color:var(--ink)}
.btn-dark:hover{opacity:.85}
.btn-danger{background:var(--red-lt);color:var(--red);border-color:rgba(239,68,68,.2)}
.btn-danger:hover{background:var(--red);color:white}
.btn-success{background:var(--green-lt);color:var(--green-text);border-color:rgba(31,202,114,.2)}
.btn-success:hover{background:var(--green);color:white}
.btn-outline-white{background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.8)}
.btn-outline-white:hover{border-color:rgba(255,255,255,.5);color:white}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.badge-theme{background:#dbeafe;color:#1d4ed8}
.badge-plugin{background:var(--green-lt);color:var(--green-text)}
.badge-html{background:#fef3c7;color:#92400e}
.badge-free{background:var(--green);color:white}
.badge-active{background:var(--green-lt);color:var(--green-text)}
.badge-draft{background:#fef3c7;color:#92400e}
.badge-archived{background:var(--bg-muted);color:var(--ink-4)}
[data-theme="dark"] .badge-theme{background:#1e3a5f;color:#93c5fd}
[data-theme="dark"] .badge-plugin{background:#064e3b;color:#6ee7b7}
[data-theme="dark"] .badge-html{background:#451a03;color:#fcd34d}

/* Card */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:background var(--tr),border-color var(--tr)}
.card-body{padding:18px 20px}

/* Product card */
.product-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .22s;text-decoration:none;color:inherit;display:block}
.product-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:rgba(31,202,114,.3)}
.product-thumb{aspect-ratio:4/3;position:relative;overflow:hidden;background:var(--bg-muted)}
.product-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.product-card:hover .product-thumb img{transform:scale(1.05)}
.product-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:44px}
.thumb-overlay{position:absolute;inset:0;background:rgba(15,15,26,.72);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.product-card:hover .thumb-overlay{opacity:1}
.thumb-overlay-btn{background:var(--green);color:white;padding:8px 18px;border-radius:var(--radius-sm);font-size:12px;font-weight:700}
.card-badge-tl{position:absolute;top:8px;left:8px}
.card-badge-tr{position:absolute;top:8px;right:8px}
.card-featured-bar{background:linear-gradient(90deg,#f59e0b,#f97316);color:white;font-size:9px;font-weight:700;text-align:center;padding:3px;letter-spacing:.5px;text-transform:uppercase}
.product-info{padding:12px 14px}
.product-name{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.product-cat{font-size:11px;color:var(--ink-4);margin-bottom:10px}
.product-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:8px;margin-top:8px}
.stars{color:var(--yellow);font-size:10px;letter-spacing:1px}
.stars .empty{color:var(--border-med)}
.rating-text{font-size:11px;color:var(--ink-4);margin-left:3px}
.dl-count{font-size:11px;color:var(--ink-4);display:flex;align-items:center;gap:3px}
.version-tag{font-size:10px;background:var(--bg-muted);color:var(--ink-4);padding:2px 6px;border-radius:4px}

/* Grids */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.products-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}

/* Hero */
.hero{background:linear-gradient(135deg,var(--hero-bg) 0%,var(--hero-bg2) 50%,#1a1a2e 100%);padding:56px 0 0;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(31,202,114,.06) 0%,transparent 60%);pointer-events:none}
.hero-inner{max-width:1280px;margin:0 auto;padding:0 32px 44px;display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;position:relative;z-index:1}
.hero-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(31,202,114,.12);border:1px solid rgba(31,202,114,.25);border-radius:100px;padding:4px 12px;margin-bottom:16px}
.hero-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.hero-pill span{font-size:11px;font-weight:600;color:rgba(255,255,255,.75);letter-spacing:.5px}
.hero h1{font-family:var(--font-head);font-size:clamp(26px,3.2vw,46px);font-weight:800;color:white;line-height:1.1;letter-spacing:-.5px;margin-bottom:14px}
.hero h1 span{color:var(--green)}
.hero p{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:24px;max-width:440px}
.hero-search{display:flex;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);overflow:hidden;margin-bottom:18px}
.hero-search input{flex:1;background:transparent;border:none;padding:12px 16px;font-size:13px;color:white;outline:none;font-family:var(--font-body)}
.hero-search input::placeholder{color:rgba(255,255,255,.3)}
.hero-search button{background:var(--green);border:none;padding:0 22px;color:white;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font-body);transition:background var(--tr)}
.hero-search button:hover{background:var(--green-dk)}
.hero-tags{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.hero-tag-label{font-size:11px;color:rgba(255,255,255,.3)}
.hero-tag{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.55);padding:4px 10px;border-radius:100px;font-size:11px;transition:all var(--tr)}
.hero-tag:hover{background:rgba(255,255,255,.14);color:white}
.hero-mock-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hero-mock-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);overflow:hidden;transition:transform .2s,border-color .2s}
.hero-mock-card:hover{transform:translateY(-4px);border-color:rgba(31,202,114,.3)}
.hero-mock-card:nth-child(2),.hero-mock-card:nth-child(4){margin-top:16px}
.hero-mock-thumb{height:76px;display:flex;align-items:center;justify-content:center;font-size:26px}
.hero-mock-info{padding:8px 10px}
.hero-mock-name{font-size:11px;font-weight:600;color:white;margin-bottom:3px}
.hero-mock-meta{font-size:10px;color:rgba(255,255,255,.4)}
.hero-mock-free{color:var(--green);font-weight:700}
.hero-stats{border-top:1px solid rgba(255,255,255,.07);background:rgba(0,0,0,.25)}
.hero-stats-inner{max-width:1280px;margin:0 auto;padding:16px 32px;display:flex;gap:36px;flex-wrap:wrap}
.hero-stat{display:flex;align-items:center;gap:10px}
.hero-stat-icon{width:32px;height:32px;background:rgba(31,202,114,.12);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px}
.hero-stat-num{font-size:17px;font-weight:700;color:white;line-height:1}
.hero-stat-label{font-size:10px;color:rgba(255,255,255,.35);margin-top:2px}

/* Cat strip */
.cat-strip{background:var(--bg-card);border-bottom:2px solid var(--border);position:sticky;top:60px;z-index:100;transition:background var(--tr)}
.cat-strip-inner{max-width:1280px;margin:0 auto;padding:0 32px;display:flex;overflow-x:auto;scrollbar-width:none}
.cat-strip-inner::-webkit-scrollbar{display:none}
.cat-btn{display:flex;align-items:center;gap:6px;padding:13px 15px;font-size:12px;font-weight:600;color:var(--ink-3);white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--tr);flex-shrink:0}
.cat-btn:hover{color:var(--ink)}
.cat-btn.active{color:var(--green-dk);border-bottom-color:var(--green-dk)}
.cat-count{background:var(--bg-muted);padding:1px 6px;border-radius:100px;font-size:10px;color:var(--ink-4)}
.cat-btn.active .cat-count{background:var(--green-lt);color:var(--green-text)}
[data-theme="dark"] .cat-btn.active .cat-count{background:#064e3b;color:#6ee7b7}

/* Main */
.page-main{max-width:1280px;margin:0 auto;padding:32px 32px}

/* Section heads */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.section-title{font-family:var(--font-head);font-size:17px;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:8px;letter-spacing:-.2px}
.section-title::before{content:'';width:3px;height:17px;background:var(--green);border-radius:2px;display:block;flex-shrink:0}
.section-view-all{font-size:12px;font-weight:600;color:var(--green-dk)}
.section-view-all:hover{color:var(--ink)}

/* Cat showcase */
.cat-showcase{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat-box{border-radius:var(--radius-lg);padding:22px;color:white;min-height:116px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s}
.cat-box:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.cat-box-icon{font-size:26px;margin-bottom:9px}
.cat-box-name{font-size:14px;font-weight:700;margin-bottom:3px}
.cat-box-count{font-size:11px;opacity:.7}

/* Divider */
.divider{height:1px;background:var(--border);margin:28px 0}

/* CTA */
.cta-banner{background:linear-gradient(135deg,#07070f,#0d1226);border-radius:var(--radius-xl);padding:44px 48px;display:grid;grid-template-columns:1fr auto;gap:36px;align-items:center;position:relative;overflow:hidden;margin:28px 0}
.cta-banner::before{content:'';position:absolute;width:400px;height:400px;right:-80px;top:-100px;background:radial-gradient(circle,rgba(31,202,114,.15) 0%,transparent 70%);pointer-events:none}
.cta-banner h2{font-family:var(--font-head);font-size:22px;font-weight:800;color:white;margin-bottom:8px}
.cta-banner p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.65}
.cta-btns{display:flex;gap:10px;align-items:center;flex-shrink:0}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.step-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;position:relative;overflow:hidden}
.step-num{font-family:var(--font-head);font-size:48px;font-weight:900;color:var(--border);position:absolute;top:8px;right:14px;line-height:1}
.step-icon{width:42px;height:42px;background:var(--green-lt);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}
[data-theme="dark"] .step-icon{background:#064e3b}
.step-card h3{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:7px}
.step-card p{font-size:12px;color:var(--ink-3);line-height:1.6}

/* Listing */
.listing-layout{display:grid;grid-template-columns:210px 1fr;gap:24px}
.sidebar-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px}
.sidebar-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ink-4);margin-bottom:11px}
.filter-list{list-style:none}
.filter-list li a{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:12px;color:var(--ink-3);border-bottom:1px solid var(--border);transition:color var(--tr)}
.filter-list li:last-child a{border-bottom:none}
.filter-list li a:hover{color:var(--ink)}
.filter-list li a.active{color:var(--green-dk);font-weight:600}
.filter-count{font-size:11px;color:var(--ink-4)}
.listing-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:14px;flex-wrap:wrap}
.listing-count{font-size:13px;color:var(--ink-3)}
.sort-select{padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-body);background:var(--bg-input);color:var(--ink);outline:none;cursor:pointer}

/* Product detail */
.product-hero-layout{display:grid;grid-template-columns:1fr 350px;gap:36px;align-items:start;padding:32px 0}
.product-banner{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9;background:var(--bg-muted)}
.product-banner img{width:100%;height:100%;object-fit:cover}
.product-thumb-row{display:flex;align-items:center;gap:14px;margin:12px 0 18px}
.product-thumb-icon{width:72px;height:72px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);flex-shrink:0;background:var(--bg-muted)}
.product-thumb-icon img{width:100%;height:100%;object-fit:cover}
.product-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:sticky;top:116px}
.download-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;background:var(--green);color:white;border-radius:var(--radius-sm);font-size:14px;font-weight:700;border:none;cursor:pointer;font-family:var(--font-body);transition:all .2s;margin-bottom:11px;text-decoration:none}
.download-btn:hover{background:var(--green-dk);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.download-btn.locked{background:var(--ink-4);cursor:default}
.download-btn.locked:hover{transform:none;box-shadow:none}
.product-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}
.product-stat{text-align:center;padding:10px;background:var(--bg-muted);border-radius:var(--radius-sm)}
.product-stat .num{font-size:19px;font-weight:700;color:var(--ink);line-height:1}
.product-stat .lbl{font-size:10px;color:var(--ink-4);margin-top:3px}
.product-meta-row{display:flex;justify-content:space-between;font-size:12px;padding:6px 0;border-bottom:1px solid var(--border)}
.product-meta-row:last-child{border-bottom:none}
.product-meta-row .lbl{color:var(--ink-4)}
.product-meta-row .val{font-weight:500;color:var(--ink-2)}

/* Tabs */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px}
.tab-btn{padding:9px 15px;font-size:13px;font-weight:600;color:var(--ink-3);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;font-family:var(--font-body);transition:all var(--tr)}
.tab-btn:hover{color:var(--ink)}
.tab-btn.active{color:var(--green-dk);border-bottom-color:var(--green-dk)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* Screenshots */
.screenshots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-top:10px}
.screenshot-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:16/10;border:1px solid var(--border);cursor:pointer}
.screenshot-item img{width:100%;height:100%;object-fit:cover}
.screenshot-del{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.65);color:white;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:11px;opacity:0;transition:opacity .15s;display:flex;align-items:center;justify-content:center}
.screenshot-item:hover .screenshot-del{opacity:1}

/* Auth */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg)}
.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:38px 42px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}
.auth-logo{text-align:center;margin-bottom:24px}
.auth-logo a{font-family:var(--font-head);font-size:18px;font-weight:800;color:var(--ink)}
.auth-title{font-family:var(--font-head);font-size:22px;font-weight:800;margin-bottom:5px;letter-spacing:-.2px}
.auth-subtitle{font-size:13px;color:var(--ink-3);margin-bottom:22px}
.auth-footer{text-align:center;font-size:13px;color:var(--ink-3);margin-top:18px}
.auth-footer a{color:var(--green-dk);font-weight:600}

/* Forms */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--ink-2);margin-bottom:5px}
.form-label .req{color:var(--red);margin-left:2px}
.form-control{width:100%;padding:9px 12px;border:1px solid var(--border-med);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-body);background:var(--bg-input);color:var(--ink);outline:none;transition:border-color var(--tr),background var(--tr);appearance:none}
.form-control:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(31,202,114,.1)}
.form-control.error{border-color:var(--red)}
.form-textarea{min-height:110px;resize:vertical}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%23999' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}
.form-help{font-size:11px;color:var(--ink-4);margin-top:4px}
.form-error{font-size:11px;color:var(--red);margin-top:4px}
.form-check{display:flex;align-items:center;gap:8px}
.form-check input[type=checkbox]{width:15px;height:15px;accent-color:var(--green);flex-shrink:0}

/* Alerts */
.alert{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-radius:var(--radius-sm);font-size:13px;border:1px solid transparent;margin-bottom:14px}
.alert-success{background:var(--green-lt);color:var(--green-text);border-color:rgba(31,202,114,.25)}
.alert-error{background:var(--red-lt);color:#7f1d1d;border-color:rgba(239,68,68,.25)}
.alert-info{background:#dbeafe;color:#1e3a8a;border-color:rgba(59,130,246,.25)}
.alert svg{flex-shrink:0;width:15px;height:15px}
[data-theme="dark"] .alert-success{background:#064e3b;color:#6ee7b7}
[data-theme="dark"] .alert-error{background:#450a0a;color:#fca5a5}
[data-theme="dark"] .alert-info{background:#1e3a5f;color:#93c5fd}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}
table.data-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--bg-card)}
.data-table th{background:var(--bg-muted);padding:9px 13px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-4);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}
.data-table td{padding:11px 13px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--ink-2)}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg-hover)}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:32px}
.pagination a,.pagination span{padding:6px 11px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;text-decoration:none;border:1px solid var(--border);color:var(--ink-3);background:var(--bg-card);transition:all var(--tr)}
.pagination a:hover{background:var(--bg-hover);color:var(--ink)}
.pagination .current{background:var(--green);color:white;border-color:var(--green)}
.pagination .disabled{opacity:.4;pointer-events:none}

/* Star rating */
.star-rating{display:flex;gap:4px;flex-direction:row-reverse;justify-content:flex-end}
.star-rating input{display:none}
.star-rating label{font-size:26px;cursor:pointer;color:var(--border-med);transition:color var(--tr)}
.star-rating input:checked ~ label,.star-rating label:hover,.star-rating label:hover ~ label{color:var(--yellow)}

/* Upload zone */
.upload-zone{border:2px dashed var(--border-med);border-radius:var(--radius-lg);padding:26px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg)}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--green);background:rgba(31,202,114,.04)}
.upload-zone svg{width:30px;height:30px;stroke:var(--ink-4);fill:none;stroke-width:1.5;margin:0 auto 8px}
.upload-zone p{font-size:13px;color:var(--ink-3)}
.upload-zone span{color:var(--green-dk);font-weight:600}
.upload-zone input{display:none}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox img{max-width:90vw;max-height:90vh;border-radius:var(--radius-lg)}
.lightbox-close{position:absolute;top:18px;right:22px;background:rgba(255,255,255,.15);border:none;color:white;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center}

/* Admin */
.admin-layout{display:flex;min-height:100vh}
.admin-sidebar{width:228px;flex-shrink:0;background:var(--admin-sb);position:fixed;top:0;left:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column;z-index:100;transition:transform .25s}
.admin-logo{padding:16px 18px 14px;border-bottom:1px solid rgba(255,255,255,.07);display:block;text-decoration:none}
.admin-logo-name{font-family:var(--font-head);font-size:15px;font-weight:800;color:white}
.admin-logo-sub{font-size:10px;font-weight:400;color:rgba(255,255,255,.3);font-family:var(--font-body);margin-top:2px;text-transform:uppercase;letter-spacing:1px}
.admin-nav{padding:12px 10px;flex:1}
.admin-nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.22);padding:12px 10px 4px}
.admin-nav a{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--admin-sb-text);text-decoration:none;transition:all var(--tr);margin-bottom:2px}
.admin-nav a:hover{background:rgba(255,255,255,.07);color:white}
.admin-nav a.active{background:var(--green);color:white}
.admin-nav a svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
.admin-badge-count{margin-left:auto;background:var(--red);color:white;font-size:10px;font-weight:700;padding:1px 6px;border-radius:100px}
.admin-nav a.active .admin-badge-count{background:rgba(255,255,255,.3)}
.admin-user{padding:12px 18px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}
.admin-avatar{width:28px;height:28px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:white;flex-shrink:0}
.admin-content{margin-left:228px;flex:1;min-width:0}
.admin-topbar{height:54px;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 22px;position:sticky;top:0;z-index:50;transition:background var(--tr)}
.admin-topbar h1{font-size:15px;font-weight:700;color:var(--ink)}
.admin-body{padding:22px}
.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px;margin-bottom:22px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px}
.stat-card .s-label{font-size:11px;color:var(--ink-4);font-weight:500;margin-bottom:4px}
.stat-card .s-num{font-family:var(--font-head);font-size:24px;font-weight:800;color:var(--ink);line-height:1}
.stat-card .s-sub{font-size:11px;color:var(--ink-4);margin-top:4px}
.stat-card.green{background:var(--green);border-color:var(--green)}
.stat-card.green .s-label,.stat-card.green .s-num,.stat-card.green .s-sub{color:white}
.stat-card.green .s-label,.stat-card.green .s-sub{color:rgba(255,255,255,.7)}

/* User dashboard */
.dashboard-header{display:flex;align-items:center;gap:16px;margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.dashboard-avatar{width:58px;height:58px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:white;flex-shrink:0}

/* Footer */
.footer{background:#07070f;color:white;padding:48px 0 22px;margin-top:auto}
.footer-inner{max-width:1280px;margin:0 auto;padding:0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:36px}
.footer-brand .logo{font-family:var(--font-head);font-size:18px;font-weight:800;color:white;display:block;margin-bottom:10px}
.footer-brand p{font-size:13px;color:rgba(255,255,255,.38);line-height:1.65;max-width:230px}
.footer-col h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.28);margin-bottom:13px}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.52);margin-bottom:8px;transition:color var(--tr)}
.footer-col a:hover{color:white}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.22);flex-wrap:wrap;gap:10px}
.footer-bottom a{color:rgba(255,255,255,.38)}
.footer-bottom a:hover{color:white}

/* Utilities */
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.text-muted{color:var(--ink-3)}.text-faint{color:var(--ink-4)}.text-green{color:var(--green-dk)}
.text-sm{font-size:13px}.text-xs{font-size:11px}.fw-700{font-weight:700}.w-full{width:100%}
.d-flex{display:flex}.align-center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}

/* Dark mode fixes */
[data-theme="dark"] .hero-stats{background:rgba(0,0,0,.4)}
[data-theme="dark"] .step-num{color:rgba(255,255,255,.05)}
[data-theme="dark"] .cta-banner{background:linear-gradient(135deg,#07070f,#0d1226)}

/* Responsive */
@media(max-width:1100px){.products-grid{grid-template-columns:repeat(3,1fr)}.products-grid-5{grid-template-columns:repeat(3,1fr)}.cat-showcase{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){.hero-inner{grid-template-columns:1fr;gap:28px}.hero-mock-grid{display:none}.listing-layout{grid-template-columns:1fr}.sidebar-card{display:none}.product-hero-layout{grid-template-columns:1fr}.products-grid,.products-grid-5{grid-template-columns:repeat(2,1fr)}.cta-banner{grid-template-columns:1fr;padding:28px}.steps-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.admin-content{margin-left:0}.admin-sidebar{transform:translateX(-100%)}.admin-sidebar.open{transform:none}}
@media(max-width:600px){.hero-inner{padding:0 20px 32px}.hero-stats-inner{padding:12px 20px;gap:18px}.page-main{padding:20px 16px}.navbar-nav{display:none}.products-grid,.products-grid-5{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.auth-card{padding:26px 22px}.admin-body{padding:14px}.stat-cards{grid-template-columns:repeat(2,1fr)}.cat-showcase{grid-template-columns:1fr 1fr}}

@keyframes pulse{0%,100%{opacity:1}50%{opacity:.75}}
