:root{
    --plum:#2A1B2E;
    --plum-light:#3D2940;
    --blush:#E9C9CE;
    --gold:#C9A24B;
    --cream:#F7F1ED;
    --rose:#8B3A52;
    --text-soft: rgba(247,241,237,0.65);
    --danger:#D85C5C;
    --success:#6FBF8B;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    font-family:'Vazirmatn',sans-serif;
    background:var(--plum);
    color:var(--cream);
    overflow-x:hidden;
    min-height:100vh;
}
h1,h2,h3,.display{ font-family:'Playfair Display',serif; }
a{ color:inherit; }

/* ===== Header ===== */
header{
    position:fixed; top:0; left:0; right:0;
    display:flex; justify-content:space-between; align-items:center;
    padding:18px 6%;
    z-index:100;
    backdrop-filter: blur(10px);
    background:rgba(42,27,46,0.75);
    border-bottom:1px solid rgba(201,162,75,0.15);
}
.logo{ font-size:1.5rem; letter-spacing:4px; color:var(--gold); font-weight:700; text-decoration:none; }
.logo span{ color:var(--blush); font-style:italic; font-weight:500; }
nav{ display:flex; align-items:center; gap:10px; }
nav a{
    color:var(--cream); text-decoration:none; margin:0 16px;
    font-size:0.92rem; letter-spacing:1px; opacity:0.85;
    transition:opacity .25s, color .25s;
}
nav a:hover{ opacity:1; color:var(--gold); }
.cart-btn, .btn-outline{
    border:1px solid var(--gold); color:var(--gold);
    padding:9px 20px; border-radius:30px; font-size:0.88rem;
    cursor:pointer; background:transparent; transition:all .25s;
    text-decoration:none; display:inline-flex; align-items:center; gap:6px;
}
.cart-btn:hover, .btn-outline:hover{ background:var(--gold); color:var(--plum); }

main{ padding-top:90px; min-height:80vh; }

/* ===== Buttons ===== */
.btn-primary{
    background:var(--gold); color:var(--plum); border:none;
    padding:14px 34px; border-radius:30px; font-size:0.95rem; font-weight:600;
    cursor:pointer; transition:transform .25s, box-shadow .25s;
    font-family:'Vazirmatn',sans-serif; text-decoration:none; display:inline-block;
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(201,162,75,0.3); }
.btn-danger{ background:var(--danger); color:#fff; border:none; padding:10px 22px; border-radius:24px; cursor:pointer; font-family:inherit; }
.btn-sm{ padding:8px 18px; font-size:0.85rem; border-radius:24px; }

/* ===== Containers / Sections ===== */
.container{ max-width:1240px; margin:0 auto; padding:0 6%; }
.section{ padding:60px 0; }
.section-head{ text-align:center; max-width:620px; margin:0 auto 50px; }
.eyebrow{ color:var(--gold); letter-spacing:5px; font-size:0.78rem; text-transform:uppercase; margin-bottom:12px; }
.section-head h2{ font-size:clamp(1.8rem,4vw,2.6rem); margin-bottom:14px; font-weight:700; }
.section-head p{ color:var(--text-soft); line-height:1.9; }

/* ===== Forms (auth, checkout, admin) ===== */
.form-card{
    max-width:440px; margin:40px auto;
    background:var(--plum-light); border-radius:20px; padding:40px;
    border:1px solid rgba(201,162,75,0.12);
}
.form-card h2{ text-align:center; margin-bottom:8px; font-size:1.8rem; }
.form-card .sub{ text-align:center; color:var(--text-soft); margin-bottom:30px; font-size:0.9rem; }
.form-group{ margin-bottom:18px; }
.form-group label{ display:block; margin-bottom:8px; font-size:0.88rem; color:var(--text-soft); }
.form-group input, .form-group textarea, .form-group select{
    width:100%; padding:13px 18px; border-radius:14px;
    border:1px solid rgba(247,241,237,0.15); background:rgba(247,241,237,0.04);
    color:var(--cream); font-size:0.95rem; font-family:'Vazirmatn',sans-serif; outline:none;
    transition:border-color .25s;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus{ border-color:var(--gold); }
.form-group textarea{ resize:vertical; min-height:90px; }
.form-card .btn-primary{ width:100%; text-align:center; }
.form-foot{ text-align:center; margin-top:22px; font-size:0.88rem; color:var(--text-soft); }
.form-foot a{ color:var(--gold); text-decoration:none; }

.alert{ padding:14px 20px; border-radius:14px; margin-bottom:20px; font-size:0.9rem; }
.alert-error{ background:rgba(216,92,92,0.12); border:1px solid rgba(216,92,92,0.3); color:#f3b6b6; }
.alert-success{ background:rgba(111,191,139,0.12); border:1px solid rgba(111,191,139,0.3); color:#bfe8cc; }

/* ===== Search & Filters ===== */
.search-bar{ max-width:900px; margin:0 auto 50px; display:flex; flex-direction:column; align-items:center; gap:22px; }
.search-input-wrap{ width:100%; max-width:560px; position:relative; display:flex; align-items:center; }
.search-icon{ position:absolute; right:20px; font-size:1rem; opacity:0.6; }
#searchInput{
    width:100%; padding:16px 52px 16px 22px; border-radius:30px;
    border:1px solid rgba(201,162,75,0.25); background:rgba(247,241,237,0.04);
    color:var(--cream); font-size:0.95rem; font-family:'Vazirmatn',sans-serif; outline:none;
    transition:border-color .25s, background .25s;
}
#searchInput::placeholder{ color:var(--text-soft); }
#searchInput:focus{ border-color:var(--gold); background:rgba(247,241,237,0.07); }
.filter-chips{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.chip{
    background:transparent; border:1px solid rgba(247,241,237,0.18); color:var(--text-soft);
    padding:9px 22px; border-radius:30px; font-size:0.85rem; font-family:'Vazirmatn',sans-serif;
    cursor:pointer; transition:all .25s; letter-spacing:0.5px; text-decoration:none; display:inline-block;
}
.chip:hover{ border-color:var(--gold); color:var(--gold); }
.chip.active{ background:var(--gold); border-color:var(--gold); color:var(--plum); font-weight:600; }

/* ===== Products Grid ===== */
.products{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.product-card{
    background:var(--plum-light); border-radius:20px; overflow:hidden;
    border:1px solid rgba(255,255,255,0.04); transition:transform .35s, box-shadow .35s, opacity .3s;
    position:relative; text-decoration:none; color:inherit; display:flex; flex-direction:column;
}
.product-card.hidden{ display:none; }
.product-card:hover{ transform:translateY(-8px); box-shadow:0 20px 50px rgba(0,0,0,0.4); }
.product-media{
    height:200px; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden;
    background: linear-gradient(135deg, var(--rose), var(--plum));
}
.product-media img{ width:100%; height:100%; object-fit:cover; }
.product-glyph{ font-size:2.6rem; color:rgba(247,241,237,0.85); }
.badge{
    position:absolute; top:14px; right:14px; background:rgba(42,27,46,0.7); color:var(--gold);
    font-size:0.7rem; letter-spacing:1px; padding:5px 12px; border-radius:20px;
    border:1px solid rgba(201,162,75,0.3); z-index:3;
}
.out-badge{
    position:absolute; top:14px; left:14px; background:rgba(216,92,92,0.85); color:#fff;
    font-size:0.7rem; padding:5px 12px; border-radius:20px; z-index:3;
}
.product-info{ padding:20px; display:flex; flex-direction:column; flex:1; }
.product-info .ptag{ color:var(--gold); font-size:0.7rem; letter-spacing:2px; text-transform:uppercase; margin-bottom:6px; display:block; }
.product-info h3{ font-size:1.05rem; font-weight:600; margin-bottom:8px; }
.product-info p{ color:var(--text-soft); font-size:0.84rem; line-height:1.8; margin-bottom:14px; flex:1; }
.product-foot{ display:flex; justify-content:space-between; align-items:center; }
.price{ font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--blush); font-weight:700; }
.price span{ font-size:0.68rem; color:var(--text-soft); margin-right:4px; }
.add-btn{
    background:transparent; border:1px solid var(--gold); color:var(--gold);
    width:38px; height:38px; border-radius:50%; cursor:pointer; font-size:1.1rem;
    transition:all .25s; display:flex; align-items:center; justify-content:center; font-family:inherit;
}
.add-btn:hover{ background:var(--gold); color:var(--plum); transform:rotate(90deg); }

/* ===== Categories ===== */
.categories{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.cat-card{
    background:var(--plum-light); border:1px solid rgba(201,162,75,0.12); border-radius:18px;
    padding:28px 16px; text-align:center; cursor:pointer; transition:transform .3s, border-color .3s, background .3s;
    text-decoration:none; color:inherit; display:block;
}
.cat-card:hover{ transform:translateY(-6px); border-color:var(--gold); background:linear-gradient(160deg, var(--plum-light), var(--rose)); }
.cat-icon{ font-size:1.8rem; margin-bottom:10px; }
.cat-card h3{ font-size:0.95rem; font-weight:600; }

/* ===== Cart / Checkout / Account / Orders tables ===== */
.cart-table{ width:100%; border-collapse:collapse; margin-bottom:30px; }
.cart-table th, .cart-table td{ padding:16px; text-align:right; border-bottom:1px solid rgba(255,255,255,0.06); }
.cart-table th{ color:var(--gold); font-size:0.85rem; letter-spacing:1px; }
.qty-form{ display:flex; align-items:center; gap:8px; }
.qty-form input{
    width:60px; padding:8px; border-radius:10px; border:1px solid rgba(247,241,237,0.15);
    background:rgba(247,241,237,0.04); color:var(--cream); text-align:center; font-family:inherit;
}
.cart-summary{
    background:var(--plum-light); border-radius:18px; padding:28px; max-width:380px; margin-right:auto;
    border:1px solid rgba(201,162,75,0.12);
}
.cart-summary .row{ display:flex; justify-content:space-between; margin-bottom:12px; color:var(--text-soft); font-size:0.92rem; }
.cart-summary .row.total{ color:var(--cream); font-weight:700; font-size:1.1rem; border-top:1px solid rgba(255,255,255,0.08); padding-top:14px; margin-top:6px; }

.status-pill{
    display:inline-block; padding:5px 14px; border-radius:20px; font-size:0.78rem; font-weight:600;
}
.status-pending{ background:rgba(201,162,75,0.18); color:var(--gold); }
.status-processing{ background:rgba(139,58,82,0.25); color:var(--blush); }
.status-shipped{ background:rgba(111,191,139,0.18); color:var(--success); }
.status-done{ background:rgba(111,191,139,0.3); color:var(--success); }
.status-cancelled{ background:rgba(216,92,92,0.18); color:var(--danger); }

/* ===== Admin layout ===== */
.admin-wrap{ display:flex; min-height:100vh; }
.admin-sidebar{
    width:230px; background:var(--plum-light); padding:30px 18px; border-left:1px solid rgba(201,162,75,0.1);
    position:fixed; top:0; right:0; height:100vh;
}
.admin-sidebar .logo{ display:block; margin-bottom:36px; text-align:center; }
.admin-sidebar a{
    display:block; padding:12px 16px; border-radius:12px; color:var(--text-soft); text-decoration:none;
    margin-bottom:6px; font-size:0.92rem; transition:all .2s;
}
.admin-sidebar a:hover, .admin-sidebar a.active{ background:rgba(201,162,75,0.12); color:var(--gold); }
.admin-content{ margin-right:230px; padding:36px 5%; flex:1; }
.admin-header{ display:flex; justify-content:space-between; align-items:center; margin-bottom:30px; }
.stat-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:40px; }
.stat-card{ background:var(--plum-light); border-radius:16px; padding:24px; border:1px solid rgba(201,162,75,0.1); }
.stat-card .num{ font-family:'Playfair Display',serif; font-size:2rem; color:var(--gold); font-weight:700; }
.stat-card .label{ color:var(--text-soft); font-size:0.85rem; margin-top:4px; }

.admin-table{ width:100%; border-collapse:collapse; background:var(--plum-light); border-radius:16px; overflow:hidden; }
.admin-table th, .admin-table td{ padding:14px 18px; text-align:right; border-bottom:1px solid rgba(255,255,255,0.05); font-size:0.9rem; }
.admin-table th{ background:rgba(201,162,75,0.08); color:var(--gold); font-size:0.8rem; letter-spacing:1px; }
.admin-table img{ width:46px; height:46px; object-fit:cover; border-radius:8px; }
.icon-link{ color:var(--gold); text-decoration:none; margin-left:10px; font-size:0.85rem; }
.icon-link.danger{ color:var(--danger); }

/* ===== Footer ===== */
footer{ padding:50px 6% 26px; border-top:1px solid rgba(255,255,255,0.05); text-align:center; color:var(--text-soft); font-size:0.85rem; }

/* ===== Mobile ===== */
@media (max-width:980px){
    nav a{ display:none; }
    .products{ grid-template-columns:repeat(2,1fr); gap:10px; }
    .categories{ grid-template-columns:repeat(2,1fr); }
    .admin-sidebar{ display:none; }
    .admin-content{ margin-right:0; }
    .stat-cards{ grid-template-columns:repeat(2,1fr); }

    /* کارت‌های جمع‌و‌جور محصول در موبایل */
    .product-media{ height:100px; }
    .product-glyph{ font-size:1.8rem; }
    .badge{ top:6px; right:6px; font-size:0.6rem; padding:3px 8px; }
    .out-badge{ top:6px; left:6px; font-size:0.6rem; padding:3px 8px; }
    .product-info{ padding:10px; }
    .product-info .ptag{ font-size:0.6rem; margin-bottom:3px; }
    .product-info h3{
        font-size:0.82rem; margin-bottom:4px; line-height:1.4;
        display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
    }
    .product-info p{
        font-size:0.7rem; line-height:1.6; margin-bottom:8px;
        display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
    }
    .price{ font-size:0.92rem; }
    .price span{ font-size:0.6rem; }
    .add-btn{ width:28px; height:28px; font-size:0.95rem; }

    /* فاصله کمتر بین حروف برای متن‌های طلایی کوچک */
    .eyebrow{ letter-spacing:2px; font-size:0.72rem; }

    /* دسته‌بندی‌های جمع‌و‌جور */
    .cat-card{ padding:20px 10px; }
    .cat-icon{ font-size:1.6rem; margin-bottom:8px; }
    .cat-card h3{ font-size:0.82rem; line-height:1.4; }
}
@media (max-width:560px){
    .products{ grid-template-columns:repeat(2,1fr); }
    .categories{ grid-template-columns:repeat(2,1fr); }
    .stat-cards{ grid-template-columns:1fr; }
    .cart-table{ font-size:0.82rem; }
}
