/* ===== VARIABLES ===== */
:root{--primary:#7c3aed;--primary-hover:#6d28d9;--primary-light:rgba(124,58,237,.15);--accent:#06d6a0;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--info:#3b82f6;--bg:#0f0f17;--bg-card:#1a1a2e;--bg-card2:#16213e;--border-color:rgba(255,255,255,.08);--text-primary:#f0f0f5;--text-muted:#8888aa;--radius:12px;--radius-lg:20px;--shadow:0 4px 24px rgba(0,0,0,.4);--shadow-lg:0 8px 40px rgba(0,0,0,.5);--gradient:linear-gradient(135deg,#7c3aed 0%,#06d6a0 100%)}
[data-theme=light]{--bg:#f5f7fa;--bg-card:#fff;--bg-card2:#f0f4ff;--border-color:rgba(0,0,0,.08);--text-primary:#1a1a2e;--text-muted:#6b7280}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text-primary);min-height:100vh;line-height:1.6;transition:background .3s,color .3s}
a{color:var(--primary);text-decoration:none;transition:all .2s}
a:hover{color:var(--accent)}
img{max-width:100%;object-fit:cover}
.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}
.d-flex{display:flex}.align-items-center{align-items:center}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}
.gap-2{gap:.5rem}.gap-3{gap:1rem}.gap-4{gap:1.5rem}
.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mb-0{margin-bottom:0}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.me-2{margin-right:.5rem}.me-3{margin-right:1rem}.ms-2{margin-left:.5rem}.ms-3{margin-left:1rem}
.text-center{text-align:center}.text-muted{color:var(--text-muted)!important}.text-danger{color:var(--danger)!important}.text-success{color:var(--success)!important}.text-primary{color:var(--primary)!important}.text-warning{color:var(--warning)!important}.text-info{color:var(--info)!important}
.bg-transparent{background:transparent}.border-0{border:0}.w-full{width:100%}.text-left{text-align:left}
.d-none{display:none!important}.d-md-none{display:none}.d-inline{display:inline}.text-xs{font-size:.75rem}.text-capitalize{text-transform:capitalize}
.small{font-size:.85rem}.fs-4{font-size:1.5rem}.fs-5{font-size:1.25rem}
.position-absolute{position:absolute}.position-relative{position:relative}.top-0{top:0}.end-0{right:0}.bottom-0{bottom:0}.start-0{left:0}.m-1{margin:.25rem}
.flex-wrap{flex-wrap:wrap}.flex-grow-1{flex-grow:1}
.cursor-pointer{cursor:pointer}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.grid-span-full{grid-column:1/-1}
/* ===== GRADIENT TEXT ===== */
.gradient-text{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
/* ===== NAVBAR ===== */
.navbar{position:sticky;top:0;z-index:1000;background:rgba(15,15,23,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);padding:.75rem 0}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.navbar-brand{font-size:1.4rem;font-weight:800;color:var(--text-primary)!important;display:flex;align-items:center;gap:.4rem}
.navbar-brand span{color:var(--primary)}
.navbar-brand i{color:var(--accent)}
.navbar-nav{display:flex;align-items:center;gap:1.5rem;list-style:none}
.nav-link{color:var(--text-muted);font-weight:500;padding:.25rem 0;position:relative}
.nav-link:hover,.nav-link.active{color:var(--text-primary)}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--gradient);border-radius:2px;transition:width .3s}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.navbar-search{display:flex;align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:50px;padding:.4rem .75rem 0.4rem .75rem;gap:.5rem;min-width:220px}
.navbar-search input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.9rem;width:100%}
.navbar-search i{color:var(--text-muted)}
.navbar-right{display:flex;align-items:center;gap:.75rem}
.btn-nav-outline{border:1px solid var(--border-color);background:transparent;color:var(--text-primary);padding:.4rem 1rem;border-radius:50px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}
.btn-nav-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-nav-primary{background:var(--gradient);color:#fff;padding:.4rem 1rem;border-radius:50px;font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:all .2s}
.btn-nav-primary:hover{opacity:.9;transform:translateY(-1px)}
.theme-toggle{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.theme-toggle:hover{color:var(--primary);border-color:var(--primary)}
.cart-btn{position:relative;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.cart-btn:hover{color:var(--primary);border-color:var(--primary)}
.cart-count{position:absolute;top:-5px;right:-5px;background:var(--danger);color:#fff;border-radius:50%;font-size:.65rem;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-weight:700}
.user-menu{position:relative}
.user-menu-btn{display:flex;align-items:center;gap:.5rem;background:var(--bg-card);border:1px solid var(--border-color);padding:.35rem .75rem;border-radius:50px;cursor:pointer;transition:all .2s}
.user-menu-btn:hover{border-color:var(--primary)}
.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);min-width:200px;padding:.5rem;box-shadow:var(--shadow-lg);display:none;z-index:100}
.user-dropdown.show{display:block;animation:fadeIn .2s ease}
.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:8px;color:var(--text-muted);font-size:.9rem;transition:all .2s}
.dropdown-item:hover{background:var(--primary-light);color:var(--primary)}
.dropdown-divider{border:none;border-top:1px solid var(--border-color);margin:.25rem 0}
.hamburger{display:none;background:transparent;border:none;color:var(--text-primary);cursor:pointer;font-size:1.5rem}
/* ===== HERO ===== */
.hero{padding:5rem 0 4rem;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(124,58,237,.2) 0%,transparent 60%);pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--primary-light);color:var(--primary);border-radius:50px;padding:.3rem .9rem;font-size:.8rem;font-weight:600;margin-bottom:1.5rem;border:1px solid rgba(124,58,237,.3)}
.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.15;margin-bottom:1.25rem}
.hero-sub{color:var(--text-muted);font-size:1.1rem;max-width:600px;margin:0 auto 2rem}
.hero-search{display:flex;max-width:560px;margin:0 auto 2.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:50px;padding:.4rem .4rem .4rem 1.25rem;gap:.5rem}
.hero-search input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:1rem}
.hero-search button{background:var(--gradient);color:#fff;border:none;border-radius:50px;padding:.6rem 1.5rem;font-weight:600;cursor:pointer;transition:all .2s}
.hero-search button:hover{opacity:.9;transform:scale(1.02)}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap}
.hero-stat-item{text-align:center}
.hero-stat-item h3{font-size:2rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-stat-item p{color:var(--text-muted);font-size:.85rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
/* ===== BUTTONS ===== */
.btn-primary-lg{display:inline-flex;align-items:center;gap:.5rem;background:var(--gradient);color:#fff;padding:.75rem 1.75rem;border-radius:50px;font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:all .25s}
.btn-primary-lg:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,58,237,.4);color:#fff}
.btn-primary-sm{display:inline-flex;align-items:center;gap:.4rem;background:var(--gradient);color:#fff;padding:.45rem 1rem;border-radius:50px;font-weight:600;font-size:.875rem;border:none;cursor:pointer;transition:all .2s}
.btn-primary-sm:hover{opacity:.9;transform:translateY(-1px);color:#fff}
.btn-outline-lg{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:var(--text-primary);padding:.75rem 1.75rem;border-radius:50px;font-weight:600;font-size:1rem;border:1px solid var(--border-color);cursor:pointer;transition:all .25s}
.btn-outline-lg:hover{border-color:var(--primary);color:var(--primary)}
.btn-outline-sm{display:inline-flex;align-items:center;gap:.4rem;background:transparent;color:var(--text-primary);padding:.4rem .9rem;border-radius:50px;font-weight:500;font-size:.85rem;border:1px solid var(--border-color);cursor:pointer;transition:all .2s}
.btn-outline-sm:hover{border-color:var(--primary);color:var(--primary)}
.btn-download-sm{display:inline-flex;align-items:center;gap:.35rem;background:rgba(6,214,160,.15);color:var(--accent);padding:.3rem .75rem;border-radius:50px;font-size:.8rem;font-weight:600;border:1px solid rgba(6,214,160,.25);transition:all .2s}
.btn-download-sm:hover{background:var(--accent);color:#000}
.btn-sm{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid}
.btn-outline-primary{border-color:var(--primary);color:var(--primary);background:transparent}
.btn-outline-danger{border-color:var(--danger);color:var(--danger);background:transparent}
.btn-outline-warning{border-color:var(--warning);color:var(--warning);background:transparent}
.btn-icon{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem;border-radius:8px;line-height:1;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}
.btn-icon:hover{color:var(--primary);background:var(--primary-light)}
.full-width{width:100%;justify-content:center}
/* ===== SECTION ===== */
.section{padding:4rem 0}
.section-header{text-align:center;margin-bottom:3rem}
.section-title{font-size:2rem;font-weight:800;margin-bottom:.5rem}
.section-sub{color:var(--text-muted)}
/* ===== FILE CARDS ===== */
.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.5rem}
.file-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all .3s}
.file-card:hover{transform:translateY(-6px);border-color:rgba(124,58,237,.4);box-shadow:var(--shadow-lg)}
.file-card-img{position:relative;height:185px;background:var(--bg-card2);overflow:hidden}
.file-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.file-card:hover .file-card-img img{transform:scale(1.05)}
.file-card-placeholder{display:flex;align-items:center;justify-content:center;height:100%;font-size:3rem;color:var(--primary)}
.featured-badge{position:absolute;top:.6rem;left:.6rem;background:var(--gradient);color:#fff;padding:.2rem .6rem;border-radius:50px;font-size:.7rem;font-weight:700}
.card-tags{position:absolute;bottom:.6rem;left:.6rem;display:flex;gap:.35rem;flex-wrap:wrap}
.tag{background:rgba(0,0,0,.6);backdrop-filter:blur(4px);color:#fff;padding:.15rem .5rem;border-radius:50px;font-size:.7rem}
.file-card-body{padding:1.1rem}
.card-category{font-size:.75rem;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem}
.card-title{font-weight:700;margin-bottom:.5rem;font-size:1rem;line-height:1.3;color:var(--text-primary)}
.card-rating{display:flex;align-items:center;gap:.3rem;font-size:.8rem;margin-bottom:.75rem}
.stars{color:#f59e0b}
.card-price-row{display:flex;align-items:center;justify-content:space-between}
.card-price{font-size:1.2rem;font-weight:800;color:var(--primary)}
.card-price.free{color:var(--accent)}
.btn-add-cart{background:var(--primary-light);color:var(--primary);border:1px solid rgba(124,58,237,.35);padding:.35rem .85rem;border-radius:50px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}
.btn-add-cart:hover{background:var(--primary);color:#fff}
/* ===== CATEGORIES ===== */
.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}
.category-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.5rem 1rem;text-align:center;cursor:pointer;transition:all .3s}
.category-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 4px 20px rgba(124,58,237,.2)}
.cat-icon{font-size:2rem;margin-bottom:.75rem;display:block}
.cat-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}
.cat-count{color:var(--text-muted);font-size:.8rem;margin-top:.25rem}
/* ===== MARKETPLACE ===== */
.marketplace-layout{display:grid;grid-template-columns:260px 1fr;gap:2rem;align-items:start;padding:2rem 0}
.filter-sidebar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;position:sticky;top:80px}
.filter-title{font-weight:700;margin-bottom:1rem;font-size:.95rem}
.filter-group{margin-bottom:1.5rem}
.filter-group label{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem;display:block}
.filter-group select,.filter-group input[type=text]{width:100%;background:var(--bg);border:1px solid var(--border-color);border-radius:8px;padding:.5rem .75rem;color:var(--text-primary);font-size:.875rem;outline:none;transition:border .2s}
.filter-group select:focus,.filter-group input:focus{border-color:var(--primary)}
.filter-btn{width:100%;background:var(--gradient);color:#fff;border:none;padding:.6rem;border-radius:8px;font-weight:600;cursor:pointer;margin-top:.5rem}
.marketplace-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}
.results-info{color:var(--text-muted);font-size:.9rem}
/* ===== FILE DETAIL ===== */
.file-detail-section{padding:2rem 0}
.file-detail-grid{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}
.file-gallery{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.5rem}
.gallery-main{height:360px;overflow:hidden}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:flex;gap:.5rem;padding:1rem;overflow-x:auto}
.gallery-thumb{width:70px;height:55px;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;flex-shrink:0;transition:border .2s}
.gallery-thumb.active,.gallery-thumb:hover{border-color:var(--primary)}
.gallery-thumb img{width:100%;height:100%;object-fit:cover}
.file-sidebar-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;position:sticky;top:80px}
.file-price{font-size:2rem;font-weight:800;margin-bottom:1.25rem;color:var(--primary)}
.file-price.free{color:var(--accent)}
.file-meta-list{list-style:none;margin-bottom:1.25rem}
.file-meta-list li{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color);font-size:.9rem}
.file-meta-list li span:first-child{color:var(--text-muted)}
.btn-buy{width:100%;background:var(--gradient);color:#fff;border:none;padding:.85rem;border-radius:50px;font-size:1rem;font-weight:700;cursor:pointer;margin-bottom:.75rem;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.btn-buy:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,58,237,.4)}
.btn-add-cart-full{width:100%;background:transparent;border:1px solid var(--primary);color:var(--primary);padding:.75rem;border-radius:50px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.btn-add-cart-full:hover{background:var(--primary-light)}
.tab-group{display:flex;gap:.25rem;border-bottom:1px solid var(--border-color);margin-bottom:1.5rem}
.tab-btn{background:transparent;border:none;padding:.6rem 1rem;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;font-weight:500;font-size:.9rem;transition:all .2s}
.tab-btn.active,.tab-btn:hover{color:var(--primary);border-bottom-color:var(--primary)}
.tab-content{display:none}.tab-content.active{display:block}
.review-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}
/* ===== CART ===== */
.cart-section{padding:2rem 0}
.cart-grid{display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}
.cart-items-list{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}
.cart-item{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-bottom:1px solid var(--border-color)}
.cart-item:last-child{border-bottom:none}
.cart-item-img{width:80px;height:60px;border-radius:10px;overflow:hidden;background:var(--bg-card2);flex-shrink:0}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-title{font-weight:600;margin-bottom:.25rem}
.cart-item-cat{color:var(--text-muted);font-size:.8rem}
.cart-item-price{font-size:1.1rem;font-weight:700;color:var(--primary);margin-left:auto;flex-shrink:0}
.btn-remove-cart{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.4rem;border-radius:8px;transition:color .2s}
.btn-remove-cart:hover{color:var(--danger)}
.cart-summary-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;position:sticky;top:80px}
.cart-summary-title{font-weight:700;margin-bottom:1.25rem;font-size:1.1rem}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}
.summary-row.total{border-top:1px solid var(--border-color);font-size:1.1rem;font-weight:700;padding-top:1rem;margin-top:.5rem}
.empty-cart{text-align:center;padding:4rem 2rem}
.empty-cart i{font-size:4rem;color:var(--text-muted);margin-bottom:1rem}
.empty-state-full{text-align:center;padding:4rem 2rem;grid-column:1/-1}
.empty-state-full i{font-size:4rem;color:var(--text-muted);margin-bottom:1rem;display:block}
/* ===== CHECKOUT ===== */
.checkout-section{padding:2rem 0}
.checkout-grid{display:grid;grid-template-columns:1fr 340px;gap:2rem;align-items:start}
.checkout-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}
.panel-title{font-weight:700;margin-bottom:1.25rem;font-size:1.05rem;border-bottom:1px solid var(--border-color);padding-bottom:.75rem}
.order-summary-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--border-color);font-size:.9rem}
.order-summary-total{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;font-weight:700;font-size:1.1rem;color:var(--primary);margin-top:.35rem}
/* ===== PAYMENT SUCCESS ===== */
.success-page{padding:3rem 0;min-height:80vh;display:flex;align-items:center}
.success-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2.5rem;text-align:center;max-width:640px;margin:0 auto;box-shadow:var(--shadow-lg)}
.success-icon{font-size:4rem;color:var(--accent);margin-bottom:1rem;animation:bounceIn .5s ease}
.success-title{font-size:1.8rem;font-weight:800;margin-bottom:.75rem}
.success-amount{font-size:1rem;margin-bottom:2rem;color:var(--text-muted)}
.purchased-files{text-align:left;background:var(--bg-card2);border-radius:var(--radius);padding:1.25rem;margin-bottom:2rem}
.purchased-files h3{font-weight:700;margin-bottom:1rem;font-size:.95rem}
.purchased-file-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:10px;margin-bottom:.5rem;background:var(--bg-card)}
.pf-img{width:50px;height:40px;border-radius:8px;overflow:hidden;background:var(--bg-card2);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}
.pf-img img{width:100%;height:100%;object-fit:cover}
.pf-info{flex:1;font-size:.9rem;font-weight:600}
.success-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
/* ===== AUTH ===== */
.auth-body{background:radial-gradient(circle at 20% 20%,rgba(124,58,237,.15) 0%,var(--bg) 50%),radial-gradient(circle at 80% 80%,rgba(6,214,160,.1) 0%,transparent 50%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}
.auth-wrapper{width:100%;max-width:420px}
.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-lg)}
.auth-brand{display:flex;align-items:center;gap:.5rem;font-size:1.3rem;font-weight:800;color:var(--text-primary);justify-content:center;margin-bottom:1.75rem}
.auth-brand span{color:var(--primary)}
.auth-brand i{color:var(--accent)}
.auth-title{font-size:1.5rem;font-weight:800;text-align:center;margin-bottom:.3rem}
.auth-sub{text-align:center;color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}
.auth-form{display:flex;flex-direction:column;gap:1.1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.85rem;font-weight:500;color:var(--text-muted)}
.form-group input,.form-group textarea,.form-group select,.form-control{background:var(--bg);border:1px solid var(--border-color);border-radius:10px;padding:.65rem .9rem;color:var(--text-primary);font-size:.9rem;outline:none;transition:border .2s;width:100%;font-family:inherit}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus,.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,.1)}
.input-eye{position:relative;display:flex}
.input-eye input{flex:1;border-radius:10px;padding-right:3rem}
.input-eye button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer}
.btn-auth{background:var(--gradient);color:#fff;border:none;padding:.75rem;border-radius:50px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.btn-auth:hover{opacity:.9;transform:translateY(-1px)}
.auth-footer{text-align:center;margin-top:1.5rem;color:var(--text-muted);font-size:.9rem}
.auth-footer a{color:var(--primary);font-weight:600}
.auth-demo{background:rgba(6,214,160,.08);border:1px solid rgba(6,214,160,.2);border-radius:8px;padding:.75rem;text-align:center;margin-top:1rem;font-size:.8rem;color:var(--text-muted)}
.form-errors{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}
.form-errors p{font-size:.85rem;color:var(--danger);margin:.2rem 0}
.form-check{display:flex;align-items:center;gap:.5rem;cursor:pointer}
.form-check input[type=checkbox]{cursor:pointer;accent-color:var(--primary);width:16px;height:16px}
/* ===== FOOTER ===== */
.footer{background:var(--bg-card);border-top:1px solid var(--border-color);padding:3rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand{display:flex;align-items:center;gap:.5rem;font-size:1.3rem;font-weight:800;color:var(--text-primary);margin-bottom:.75rem}
.footer-brand span{color:var(--primary)}
.footer-desc{color:var(--text-muted);font-size:.875rem;line-height:1.7}
.footer-heading{font-weight:700;margin-bottom:1rem;font-size:.9rem}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-links a{color:var(--text-muted);font-size:.875rem;transition:color .2s}
.footer-links a:hover{color:var(--primary)}
.footer-social{display:flex;gap:.75rem;margin-top:1rem}
.social-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-card2);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.95rem;transition:all .2s}
.social-btn:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.footer-bottom{border-top:1px solid var(--border-color);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{color:var(--text-muted);font-size:.85rem}
/* ===== BADGES ===== */
.badge{padding:.25rem .65rem;border-radius:50px;font-size:.75rem;font-weight:600}
.badge-success{background:rgba(34,197,94,.15);color:var(--success);border:1px solid rgba(34,197,94,.25)}
.badge-warning{background:rgba(245,158,11,.15);color:var(--warning);border:1px solid rgba(245,158,11,.25)}
.badge-danger{background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.25)}
.badge-primary{background:var(--primary-light);color:var(--primary);border:1px solid rgba(124,58,237,.25)}
.badge-info{background:rgba(59,130,246,.15);color:var(--info);border:1px solid rgba(59,130,246,.25)}
.badge-secondary{background:rgba(255,255,255,.07);color:var(--text-muted);border:1px solid var(--border-color)}
/* ===== TOASTS ===== */
.toast-wrapper{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;max-width:360px}
.toast{display:flex;align-items:center;gap:.75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:.9rem 1.1rem;box-shadow:var(--shadow-lg);animation:slideUp .3s ease;font-size:.9rem}
.toast-success{border-left:4px solid var(--success)}.toast-error{border-left:4px solid var(--danger)}
.toast-success i{color:var(--success)}.toast-error i{color:var(--danger)}
.toast button{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.1rem}
/* ===== PAGINATION ===== */
.pagination{display:flex;gap:.5rem;justify-content:center}
.page-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);font-weight:600;font-size:.875rem;transition:all .2s}
.page-btn:hover,.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
/* ===== ADMIN ===== */
.admin-body{background:var(--bg);min-height:100vh}
.admin-layout{display:flex;min-height:100vh}
.admin-sidebar{width:250px;flex-shrink:0;background:var(--bg-card);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-brand{padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}
.admin-brand a{font-size:1.2rem;font-weight:800;color:var(--text-primary)}.admin-brand span{color:var(--primary)}.admin-brand i{color:var(--accent)}
.admin-nav{padding:1rem}
.admin-nav-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:700;padding:.5rem .75rem;margin-top:.5rem}
.admin-nav-link{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:8px;color:var(--text-muted);font-size:.9rem;font-weight:500;transition:all .2s;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}
.admin-nav-link:hover,.admin-nav-link.active{background:var(--primary-light);color:var(--primary)}
.admin-main{flex:1;display:flex;flex-direction:column;overflow-x:hidden}
.admin-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100}
.admin-page-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}
.admin-header-right{display:flex;align-items:center;gap:.75rem}
.admin-content-inner{padding:1.5rem;flex:1}
.admin-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:1.5rem}
.admin-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.25rem;display:flex;align-items:center;gap:1rem}
.astat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.35rem;flex-shrink:0}
.bg-primary-light{background:var(--primary-light)}.bg-success-light{background:rgba(34,197,94,.15)}.bg-warning-light{background:rgba(245,158,11,.15)}.bg-info-light{background:rgba(59,130,246,.15)}
.astat-label{font-size:.8rem;color:var(--text-muted);display:block;margin-bottom:.25rem}
.astat-value{font-size:1.4rem;font-weight:800;display:block}
.admin-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.admin-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius)}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}
.panel-header h3{font-weight:700;font-size:.95rem}
.panel-body{padding:1.25rem}
.p-0{padding:0!important}
.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}
.admin-table thead tr{border-bottom:1px solid var(--border-color)}
.admin-table th{padding:.75rem 1rem;text-align:left;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}
.admin-table td{padding:.85rem 1rem;border-bottom:1px solid var(--border-color);vertical-align:middle}
.admin-table tbody tr:last-child td{border-bottom:none}
.admin-table tbody tr:hover{background:rgba(255,255,255,.02)}
.admin-tbl-img{width:45px;height:36px;border-radius:8px;background:var(--bg-card2);display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--primary);flex-shrink:0}
.admin-tbl-img img{width:100%;height:100%;object-fit:cover}
.admin-list{list-style:none}
.admin-list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid var(--border-color)}
.admin-list-item:last-child{border-bottom:none}
.action-btns{display:flex;align-items:center;gap:.35rem}
.admin-search-form{display:flex;align-items:center;background:var(--bg);border:1px solid var(--border-color);border-radius:50px;padding:.35rem .75rem;gap:.5rem}
.admin-search-form input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:.875rem;width:200px}
.admin-img-preview{position:relative;width:80px;height:65px;border-radius:8px;overflow:hidden}
.admin-img-preview img{width:100%;height:100%;object-fit:cover}
.admin-form-grid{display:grid;grid-template-columns:1fr 300px;gap:1.5rem;align-items:start}
.admin-form-main{min-width:0}
.admin-form-sidebar{position:sticky;top:80px}
.form-control-sm{padding:.3rem .6rem;font-size:.8rem;border-radius:6px;background:var(--bg);border:1px solid var(--border-color);color:var(--text-primary);outline:none}
.w-auto{width:auto}
/* ===== USER PANEL ===== */
.user-body{background:var(--bg)}
.user-dashboard-section,.user-page-section{padding:2.5rem 0}
.user-layout{display:grid;grid-template-columns:240px 1fr;gap:2rem;align-items:start}
.user-sidebar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:80px}
.user-sidebar-profile{padding:1.5rem;text-align:center;background:linear-gradient(135deg,var(--primary-light),var(--bg-card));border-bottom:1px solid var(--border-color)}
.user-avatar-lg{width:60px;height:60px;background:var(--gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;margin:0 auto .75rem}
.user-sidebar-profile h3{font-size:1rem;font-weight:700;margin-bottom:.25rem}
.user-sidebar-profile p{color:var(--text-muted);font-size:.8rem}
.user-sidebar-nav{padding:.75rem}
.user-nav-link{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:8px;color:var(--text-muted);font-size:.875rem;font-weight:500;transition:all .2s;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}
.user-nav-link:hover,.user-nav-link.active{background:var(--primary-light);color:var(--primary)}
.user-main-content{min-width:0}
.page-title{font-size:1.5rem;font-weight:800;margin-bottom:.3rem}
.user-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.user-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:1rem;display:flex;align-items:center;gap:.9rem}
.ustat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.ustat-info h3{font-size:1.3rem;font-weight:800;margin-bottom:.15rem}
.ustat-info p{color:var(--text-muted);font-size:.8rem}
.user-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.user-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius)}
.user-table{width:100%;border-collapse:collapse;font-size:.875rem}
.user-table th{padding:.65rem 1rem;text-align:left;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border-color)}
.user-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);vertical-align:middle}
.user-table tbody tr:last-child td{border-bottom:none}
.purchased-mini-item{display:flex;align-items:center;gap:.75rem;padding:.65rem 0;border-bottom:1px solid var(--border-color)}
.purchased-mini-item:last-child{border-bottom:none}
.pmi-icon{font-size:1.2rem;flex-shrink:0}
.pmi-info{flex:1;min-width:0}
.pmi-info a{font-weight:600;font-size:.875rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pmi-info span{font-size:.75rem;color:var(--text-muted)}
.purchased-files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.25rem}
.purchased-file-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all .3s}
.purchased-file-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.pfc-img{height:140px;background:var(--bg-card2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.pfc-img img{width:100%;height:100%;object-fit:cover}
.pfc-img i{font-size:3rem;color:var(--primary)}
.pfc-body{padding:1rem}
.pfc-cat{font-size:.75rem;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:.3rem}
.pfc-title{font-weight:700;font-size:.95rem;color:var(--text-primary);display:block}
.pfc-actions{display:flex;gap:.5rem}
.order-detail-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}
.odc-header{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-card2)}
.odc-body{padding:1.5rem}
.order-items-list{display:flex;flex-direction:column;gap:.75rem}
.order-item-row{display:flex;align-items:center;gap:1rem;background:var(--bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:1rem}
.oir-img{width:60px;height:48px;border-radius:8px;background:var(--bg-card2);overflow:hidden;flex-shrink:0}
.oir-img img{width:100%;height:100%;object-fit:cover}
.oir-info{flex:1;min-width:0}
.oir-title{font-weight:600;font-size:.9rem;display:block;margin-bottom:.2rem}
.oir-price{font-weight:700;color:var(--primary);font-size:.85rem}
/* ===== MODAL ===== */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9000;align-items:center;justify-content:center}
.modal.show{display:flex;animation:fadeIn .2s ease}
.modal-dialog{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}
.modal-title{font-weight:700;font-size:1.05rem}
.modal-close{background:none;border:none;font-size:1.4rem;color:var(--text-muted);cursor:pointer;line-height:1;transition:color .2s}
.modal-close:hover{color:var(--danger)}
.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}
.modal-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}
/* ===== USER AVATAR SM ===== */
.user-avatar-sm{width:32px;height:32px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem;flex-shrink:0}
.admin-profile{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600}
/* ===== STATS ===== */
.stats-section{padding:3rem 0;background:var(--bg-card);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat-card{padding:1rem}
.stat-icon{font-size:2rem;color:var(--primary);margin-bottom:.5rem}
.stat-number{font-size:2rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-label{color:var(--text-muted);font-size:.875rem}
/* ===== CTA ===== */
.cta-section{padding:4rem 0;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(124,58,237,.2) 0%,transparent 60%);pointer-events:none}
.cta-title{font-size:2.2rem;font-weight:800;margin-bottom:1rem}
.cta-sub{color:var(--text-muted);margin-bottom:2rem;font-size:1.05rem}
/* ===== TABLE RESPONSIVE ===== */
.table-responsive{overflow-x:auto}
/* ===== ANIMATIONS ===== */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes bounceIn{0%{transform:scale(.5)}80%{transform:scale(1.1)}100%{transform:scale(1)}}
/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
.file-detail-grid{grid-template-columns:1fr}.checkout-grid{grid-template-columns:1fr}.cart-grid{grid-template-columns:1fr}
.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-grid-2{grid-template-columns:1fr}.admin-form-grid{grid-template-columns:1fr}.admin-form-sidebar{position:static}
.footer-grid{grid-template-columns:1fr 1fr}.marketplace-layout{grid-template-columns:1fr}.filter-sidebar{position:static}
.odc-header{grid-template-columns:repeat(2,1fr)}
.stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
.navbar-nav{display:none}.navbar-search{display:none}.hamburger{display:block}
.hero-stats{gap:2rem}.hero-title{font-size:2rem}
.admin-sidebar{position:fixed;left:-260px;z-index:9990;transition:left .3s}.admin-sidebar.show{left:0}
.admin-header{padding:.75rem 1rem}.admin-content-inner{padding:1rem}
.user-layout{grid-template-columns:1fr}.user-sidebar{position:static}
.user-grid-2{grid-template-columns:1fr}.admin-grid-2{grid-template-columns:1fr}
.user-stats-grid{grid-template-columns:1fr}
.footer-grid{grid-template-columns:1fr}
.files-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.cart-item{flex-wrap:wrap}
.d-md-none{display:block}
.categories-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
.admin-stats-grid{grid-template-columns:1fr 1fr}
}
