* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --primary-red: #2c8b00ff;
    --dark-red: #005a11;
    --dark-bg: #1a1a1a;
    --darker-bg: #0d0d0d;
    --text-light: #e0e0e0;
    --text-gray: #999;
    --accent: #69ff44;
}

body {
    font-family: 'Cairo', sans-serif;
    background: linear-gradient(135deg, var(--darker-bg) 0%, var(--dark-bg) 100%);
    color: var(--text-light);
    line-height: 1.6;
    overflow-x: hidden;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Header */
.header {
    background: rgba(13, 13, 13, 0.95);
    backdrop-filter: blur(10px);
    position: sticky;
    top: 0;
    z-index: 1000;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
    border-bottom: 1px solid rgba(139, 0, 0, 0.3);
}

.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 2rem;
    max-width: 1200px;
    margin: 0 auto;
}

.logo-container {
    display: flex;
    align-items: center;
}

.logo {
    height: 60px;
    width: auto;
    filter: drop-shadow(0 0 10px rgba(66, 177, 14, 0.5));
}

.nav-menu {
    display: flex;
    list-style: none;
    gap: 2rem;
}

.nav-menu a {
    color: var(--text-light);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s;
    position: relative;
}

.nav-menu a::after {
    content: '';
    position: absolute;
    bottom: -5px;
    right: 0;
    width: 0;
    height: 2px;
    background: var(--accent);
    transition: width 0.3s;
}

.nav-menu a:hover {
    color: var(--accent);
}

.nav-menu a:hover::after {
    width: 100%;
}

.cart-icon {
    position: relative;
    cursor: pointer;
    color: var(--text-light);
    transition: color 0.3s;
}

.cart-icon:hover {
    color: var(--accent);
}

.cart-count {
    position: absolute;
    top: -8px;
    right: -8px;
    background: var(--accent);
    color: white;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: bold;
}

/* Hero Section */
.hero {
    min-height: 90vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)),
                url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 600"><rect fill="%231a1a1a" width="1200" height="600"/><path d="M0,300 Q300,200 600,300 T1200,300" stroke="%23333" stroke-width="2" fill="none"/></svg>');
    background-size: cover;
    background-position: center;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(circle at center, rgba(139, 0, 0, 0.1) 0%, transparent 70%);
}

.hero-content {
    position: relative;
    z-index: 1;
    animation: fadeInUp 1s ease-out;
}

.hero-title {
    font-size: 4.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
    background: linear-gradient(135deg, var(--accent), #82ff66);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: 0 0 30px rgba(115, 255, 68, 0.5);
}

.hero-subtitle {
    font-size: 1.5rem;
    color: var(--text-gray);
    margin-bottom: 2rem;
}

.cta-button {
    display: inline-block;
    padding: 1rem 2.5rem;
    background: linear-gradient(135deg, var(--accent), var(--primary-red));
    color: white;
    text-decoration: none;
    border-radius: 50px;
    font-weight: 600;
    transition: all 0.3s;
    box-shadow: 0 4px 15px rgba(68, 255, 102, 0.4);
}

.cta-button:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(77, 255, 68, 0.6);
}

/* Products Section */
.products-section {
    padding: 5rem 0;
    background: var(--dark-bg);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

/* Laws Section */
.laws-section, .things-section {
    padding: 5rem 0;
    background: var(--dark-bg);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.laws-content, .things-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2rem;
    margin-top: 2rem;
}

.law-item, .thing-item {
    background: rgba(30, 30, 30, 0.8);
    padding: 2rem;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s, box-shadow 0.3s;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.law-item:hover, .thing-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

.law-item h3, .thing-item h3 {
    color: var(--accent);
    margin-bottom: 1rem;
    font-size: 1.5rem;
}

.law-item p, .thing-item p {
    color: var(--text-gray);
    line-height: 1.6;
}

.section-title {
    text-align: center;
    font-size: 2.5rem;
    margin-bottom: 3rem;
    color: var(--text-light);
    position: relative;
    display: inline-block;
    width: 100%;
}

.section-title::after {
    content: '';
    position: absolute;
    bottom: -10px;
    right: 50%;
    transform: translateX(50%);
    width: 100px;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}

.product-card {
    background: rgba(30, 30, 30, 0.8);
    border-radius: 10px;
    overflow: hidden;
    transition: transform 0.3s, box-shadow 0.3s;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.product-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

.product-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 10px 30px rgba(30, 220, 13, 0.3);
    border-color: var(--accent);
}

.product-image {
    width: 100%;
    height: 220px;
    background: linear-gradient(135deg, #2a2a2a, #1a1a1a);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    color: var(--text-light);
    transition: transform 0.3s;
}

.product-card:hover .product-image {
    transform: scale(1.03);
}


/* Use real product images (keep layout, don't overlay emojis) */
.product-image::before {
    content: '';
}

.product-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 18px;
}

.product-info {
    padding: 1.5rem;
}

.product-name {
    font-size: 1.3rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: var(--text-light);
}

.product-description {
    color: var(--text-gray);
    font-size: 0.9rem;
    margin-bottom: 1rem;
    min-height: 40px;
}

.product-price {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--accent);
    margin-bottom: 1rem;
}

.add-to-cart {
    width: 100%;
    padding: 0.8rem;
    background: linear-gradient(135deg, var(--accent), var(--primary-red));
    color: white;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    font-family: 'Cairo', sans-serif;
}

.add-to-cart:hover {
    background: linear-gradient(135deg, var(--primary-red), var(--accent));
    transform: scale(1.05);
}

/* Modal */
.modal {
    display: none;
    position: fixed;
    z-index: 2000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(5px);
}

.modal-content {
    background: var(--dark-bg);
    margin: 5% auto;
    padding: 2rem;
    border: 1px solid rgba(51, 139, 0, 0.3);
    border-radius: 15px;
    width: 90%;
    max-width: 600px;
    max-height: 80vh;
    overflow-y: auto;
    position: relative;
}

.close {
    color: var(--text-gray);
    float: left;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    position: absolute;
    left: 20px;
    top: 20px;
}

.close:hover {
    color: var(--accent);
}

.cart-items {
    margin: 2rem 0;
}

.cart-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid rgba(0, 139, 21, 0.2);
    margin-bottom: 1rem;
}

.cart-item-info {
    flex: 1;
}

.cart-item-name {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.cart-item-price {
    color: var(--accent);
}

.cart-item-quantity {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.quantity-btn {
    background: var(--accent);
    color: white;
    border: none;
    width: 30px;
    height: 30px;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
}

.remove-btn {
    background: #52ff33;
    color: white;
    border: none;
    padding: 0.5rem 1rem;
    border-radius: 5px;
    cursor: pointer;
    font-family: 'Cairo', sans-serif;
}

.cart-total {
    text-align: center;
    font-size: 1.5rem;
    margin: 2rem 0;
    padding-top: 2rem;
    border-top: 2px solid rgba(60, 139, 0, 0.3);
}

.checkout-btn {
    width: 100%;
    padding: 1rem;
    background: linear-gradient(135deg, var(--accent), var(--primary-red));
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    font-family: 'Cairo', sans-serif;
}

.checkout-btn:hover {
    transform: scale(1.02);
    box-shadow: 0 4px 15px rgba(137, 255, 68, 0.4);
}

/* About Section */
.about-section {
    padding: 5rem 0;
    background: var(--darker-bg);
    text-align: center;
    animation: fadeIn 0.8s ease-out forwards;
}

.about-text {
    max-width: 800px;
    margin: 0 auto;
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--text-gray);
}

/* Contact Section */
.contact-section {
    padding: 5rem 0;
    background: var(--dark-bg);
    text-align: center;
}

.contact-info {
    max-width: 600px;
    margin: 0 auto;
}

.contact-info p {
    font-size: 1.2rem;
    margin: 1rem 0;
    color: var(--text-light);
}

/* Footer */
.footer {
    background: var(--darker-bg);
    padding: 2rem 0;
    text-align: center;
    border-top: 1px solid rgba(23, 139, 0, 0.3);
    color: var(--text-gray);
}

/* Login Modal Styles */
.login-modal-content {
    max-width: 400px;
    padding: 2rem;
}

.login-header {
    text-align: center;
    margin-bottom: 2rem;
}

.login-header h1 {
    color: var(--text-light);
    margin-bottom: 0.5rem;
}

.login-header p {
    color: var(--text-gray);
}

.login-form .form-group {
    margin-bottom: 1.5rem;
}

.login-form label {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--text-light);
    font-weight: 500;
}

.login-form input {
    width: 100%;
    padding: 0.75rem;
    background: rgba(26, 26, 26, 0.8);
    border: 1px solid rgba(37, 139, 0, 0.3);
    border-radius: 4px;
    font-size: 1rem;
    color: var(--text-light);
    transition: border-color 0.3s;
}

.login-form input::placeholder {
    color: var(--text-gray);
}

.login-form input:focus {
    outline: none;
    border-color: var(--primary-red);
    box-shadow: 0 0 0 2px rgba(67, 139, 0, 0.67);
}

.login-button {
    width: 100%;
    padding: 0.75rem;
    background: linear-gradient(135deg, var(--primary-red) 0%, var(--dark-red) 100%);
    color: var(--text-light);
    border: none;
    border-radius: 4px;
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0 4px 15px rgba(9, 139, 0, 0.3);
}

.login-button:hover {
    background: linear-gradient(135deg, var(--accent) 0%, var(--primary-red) 100%);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(60, 139, 0, 0.4);
}

.forgot-password {
    text-align: center;
    margin-top: 1rem;
}

.forgot-password a {
    color: var(--accent);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.3s;
}

.forgot-password a:hover {
    color: var(--primary-red);
    text-decoration: underline;
}

/* Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive */
@media (max-width: 768px) {
    .hero-title {
        font-size: 2.5rem;
    }
    
    .hero-subtitle {
        font-size: 1.2rem;
    }
    
    .nav-menu {
        display: none;
    }
    
    .products-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    }
    
    .laws-content, .things-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .nav-menu {
        flex-direction: column;
        gap: 1rem;
        display: none;
    }

    .navbar {
        padding: 1rem;
    }
}



/* -------------------------
   Pro Cart / Checkout / Auth
------------------------- */

.toast{
    position: fixed;
    top: 90px;
    left: 50%;
    transform: translateX(-50%) translateY(-10px);
    opacity: 0;
    padding: 12px 18px;
    border-radius: 999px;
    background: rgba(0,0,0,0.85);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.12);
    z-index: 4000;
    transition: all .25s ease;
    font-weight: 600;
}
.toast.show{
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.empty-cart{
    padding: 24px;
    text-align: center;
    color: var(--text-light);
}
.empty-cart p{ color: var(--text-gray); margin-top: 6px; }

.cart-item{
    display: flex;
    gap: 14px;
    padding: 14px;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    background: rgba(255,255,255,0.03);
    margin-bottom: 12px;
}
.cart-item-img{
    width: 60px;
    height: 60px;
    border-radius: 14px;
    object-fit: cover;
    background: #0b0b0b;
}
.cart-item-info{ flex: 1; }
.cart-item-title{
    font-weight: 700;
    color: var(--text-light);
}
.cart-item-meta{
    margin-top: 4px;
    font-size: 0.9rem;
    color: var(--text-gray);
}
.qty-row{
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 10px;
}
.qty-btn{
    width: 34px;
    height: 34px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(0,0,0,0.25);
    color: var(--text-light);
    font-size: 18px;
    cursor: pointer;
}
.qty-val{
    min-width: 22px;
    text-align: center;
    font-weight: 700;
}
.cart-item-actions{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-end;
    gap: 10px;
    min-width: 120px;
}
.cart-item-subtotal{
    font-weight: 800;
    color: var(--accent);
}
.remove-btn{
    background: transparent;
    border: 1px solid rgba(255,255,255,0.12);
    color: var(--text-light);
    border-radius: 12px;
    padding: 8px 10px;
    cursor: pointer;
}

.checkout-modal-content{
    max-width: 720px;
}
.checkout-tabs{
    display: flex;
    gap: 10px;
    margin: 10px 0 16px;
}
.tab-btn{
    flex: 1;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.04);
    color: var(--text-light);
    cursor: pointer;
    font-weight: 700;
}
.tab-btn.active{
    background: linear-gradient(135deg, var(--accent), var(--primary-red));
    border-color: transparent;
}

.checkout-summary{
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    padding: 14px;
    background: rgba(255,255,255,0.03);
}
.summary-list{ margin-top: 10px; display: grid; gap: 8px; }
.summary-item{
    display: flex;
    justify-content: space-between;
    gap: 10px;
    color: var(--text-light);
}
.summary-total{
    margin-top: 12px;
    display: flex;
    justify-content: space-between;
    font-weight: 900;
    color: var(--accent);
}

.checkout-tab-panel{ display: none; margin-top: 14px; }
.checkout-tab-panel.active{ display: block; }

.primary-btn, .secondary-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 10px;
    padding: 12px 14px;
    border-radius: 14px;
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
    width: 100%;
}
.primary-btn{
    background: linear-gradient(135deg, var(--accent), var(--primary-red));
    color: #fff;
    border: none;
}
.secondary-btn{
    background: rgba(255,255,255,0.04);
    color: var(--text-light);
    border: 1px solid rgba(255,255,255,0.12);
}

.checkout-form .form-group{ margin-bottom: 12px; }
.checkout-form input, .checkout-form textarea{
    width: 100%;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(0,0,0,0.2);
    color: var(--text-light);
}

.success-box{
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 16px;
    padding: 18px;
    background: rgba(255,255,255,0.03);
    color: var(--text-light);
}
.success-box p{ color: var(--text-gray); margin-top: 6px; }
.success-actions{ display: grid; gap: 10px; margin-top: 14px; }

.auth-modal-content{
    max-width: 520px;
}
.login-options{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin: 10px 0 14px;
}
.remember-me{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-light);
    font-size: 0.95rem;
}
.toggle-pass{
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.04);
    color: var(--text-light);
    cursor: pointer;
    font-weight: 700;
}
.login-note{
    margin-top: 14px;
    color: var(--text-gray);
    font-size: 0.9rem;
    text-align: center;
}
.login-note a{ color: var(--accent); text-decoration: none; font-weight: 800; }

.account-pill{
    display: inline-flex;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.04);
}

/* Terms page */
.terms-wrap{
    max-width: 900px;
    margin: 120px auto 60px;
    padding: 0 16px;
    color: var(--text-light);
}
.terms-card{
    border: 1px solid rgba(255,255,255,0.10);
    background: rgba(255,255,255,0.03);
    border-radius: 20px;
    padding: 22px;
}
.terms-card h1{ margin-bottom: 8px; }
.terms-card h2{ margin-top: 18px; margin-bottom: 8px; }
.terms-card p, .terms-card li{ color: var(--text-gray); line-height: 1.8; }
.terms-card ul{ margin-left: 18px; }


/* =========================================================
   PRO Upgrade: Account menu, Social checkout, Animations
   ========================================================= */

.account-menu { position: relative; display:flex; align-items:center; }
.account-trigger {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  color: inherit; cursor:pointer;
  transition: transform .15s ease, background .15s ease;
}
.account-trigger:hover { transform: translateY(-1px); background: rgba(255,255,255,0.10); }
.account-trigger .avatar{
  width:28px; height:28px; border-radius:999px;
  display:grid; place-items:center;
  background: rgba(255,255,255,0.14);
  font-weight:700;
}
.account-trigger .caret { opacity:.75; font-size:12px; }
.account-dropdown{
  position:absolute; right:0; top: calc(100% + 10px);
  min-width: 180px;
  padding:8px;
  border-radius:14px;
  background: rgba(20,20,20,0.96);
  border:1px solid rgba(255,255,255,0.12);
  box-shadow: 0 12px 30px rgba(0,0,0,0.35);
  display:none;
  z-index: 1000;
}
.account-menu.open .account-dropdown{ display:block; }
.account-dropdown a{
  display:block; padding:10px 12px; border-radius:10px;
  color: #fff; text-decoration:none;
  transition: background .15s ease;
}
.account-dropdown a:hover{ background: rgba(255,255,255,0.08); }

.checkout-actions{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
  margin-top:16px;
}
.social-btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  padding:14px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  cursor:pointer;
  color: inherit;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.social-btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.20); }
.social-btn .social-icon{ font-size:20px; width:34px; height:34px; display:grid; place-items:center; border-radius:12px; background: rgba(255,255,255,0.10); }
.social-btn span small{ display:block; opacity:.75; margin-top:2px; }

.helper-row{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap:10px;
  margin-top:8px;
  font-size: 12px;
}
.helper-row a{ color: inherit; opacity:.9; text-decoration: underline; }

.input-row{ display:flex; gap:10px; align-items:center; }
.input-row input{ flex:1; }

.otp-demo{ margin-top:8px; padding:10px 12px; border-radius:12px; background: rgba(255,255,255,0.06); border:1px dashed rgba(255,255,255,0.18); }

.page{ padding-top: 90px; }
.page-hero{ padding: 26px 0 10px; }
.page-hero-inner{ width:min(1040px, 92%); margin:0 auto; }
.page-content{ width:min(1040px, 92%); margin: 18px auto 60px; }
.account-card{
  border-radius: 22px;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  padding: 18px;
}
.account-card-head h2{ margin:0 0 6px; }
.form-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
.primary-btn, .secondary-btn{
  padding: 12px 14px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,0.14);
  cursor:pointer;
  background: rgba(255,255,255,0.06);
  color: inherit;
  transition: transform .15s ease, background .15s ease;
}
.primary-btn:hover, .secondary-btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,0.10); }

.reveal{ opacity:0; transform: translateY(14px); transition: opacity .45s ease, transform .45s ease; }
.reveal.visible{ opacity:1; transform:none; }


/* Auth Tabs (Sign in / Create account) */
.auth-tabs{display:flex;gap:10px;background:rgba(255,255,255,.06);padding:8px;border-radius:14px;margin:14px 0 18px}
.auth-tab{flex:1;border:0;background:transparent;color:inherit;padding:10px 12px;border-radius:12px;cursor:pointer;font-weight:600;opacity:.8;transition:transform .15s ease, background .15s ease, opacity .15s ease}
.auth-tab:hover{transform:translateY(-1px);opacity:1}
.auth-tab.active{background:rgba(255,255,255,.10);opacity:1}
.field-hint{display:block;margin-top:8px;opacity:.75;font-size:.85rem}


/* Fix: logo image sizing */
.logo-img{width:56px;height:56px;object-fit:contain;display:block;}
@media (max-width:768px){.logo-img{width:44px;height:44px;}}

/* Floating Contact Button */
.floating-contact{
  position:fixed;right:18px;bottom:18px;z-index:9999;
  width:54px;height:54px;border-radius:16px;border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.55);backdrop-filter:blur(8px);
  color:inherit;cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  display:flex;align-items:center;justify-content:center;
  transition:transform .15s ease, opacity .15s ease, background .15s ease;
}
.floating-contact:hover{transform:translateY(-2px);background:rgba(0,0,0,.65);}
.floating-contact:active{transform:translateY(0);}

/* Contact Buttons */
.contact-actions .contact-sub{opacity:.85;margin:8px 0 18px;}
.contact-buttons{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.contact-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 16px;border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:inherit;text-decoration:none;font-weight:700;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.contact-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22);}
.contact-btn .icon{font-size:1.05rem}
.contact-foot{margin-top:18px;opacity:.85}

/* Account Page */
.account-page{min-height:60vh;padding-bottom:40px}
.account-card{
  margin:22px auto 0;max-width:760px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(255,255,255,.05);
  padding:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.account-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:900px){.account-grid{grid-template-columns:1.1fr .9fr}}
.profile-row{display:flex;gap:14px;align-items:center}
.avatar{
  width:60px;height:60px;border-radius:18px;overflow:hidden;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.35);
  display:flex;align-items:center;justify-content:center;
}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar .avatar-letter{font-weight:900;font-size:1.1rem;opacity:.9}
.avatar-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:inherit;cursor:pointer;text-decoration:none;font-weight:700;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22);}
.btn.danger{background:rgba(255,0,0,.08);border-color:rgba(255,0,0,.20)}
.btn.danger:hover{background:rgba(255,0,0,.12)}
.muted{opacity:.75}

/* Account pill avatar */
.account-avatar{
  width:28px;height:28px;border-radius:10px;overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.35);
  display:inline-flex;align-items:center;justify-content:center;
  margin-right:8px;
}
.account-avatar img{width:100%;height:100%;object-fit:cover}
.account-letter{font-weight:900;font-size:.85rem;opacity:.9}

/* Mobile Nav Toggle */
.nav-toggle{
  display:none;
  margin-left:auto;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:inherit;
  width:44px;height:44px;
  border-radius:14px;
  cursor:pointer;
  font-size:18px;
  align-items:center;
  justify-content:center;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.nav-toggle:hover{transform:translateY(-1px);background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22);}

@media (max-width: 768px){
  .navbar{padding:12px 14px;gap:10px}
  .nav-toggle{display:inline-flex}
  .nav-menu{
    position:absolute;
    top:68px; left:12px; right:12px;
    display:none;
    flex-direction:column;
    gap:0;
    padding:10px;
    border-radius:18px;
    background:rgba(13,13,13,.96);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 18px 50px rgba(0,0,0,.45);
  }
  .nav-menu.open{display:flex}
  .nav-menu li{width:100%}
  .nav-menu a{display:block;padding:12px 12px;border-radius:14px}
  .nav-menu a:hover{background:rgba(255,255,255,.06)}
}

/* Logo responsive sizing */
.logo, .logo-img{max-height:42px;width:auto;display:block}
@media (max-width: 768px){.logo, .logo-img{max-height:34px}}

/* Mobile menu open */
@media (max-width: 768px){
  .navbar{padding:12px 14px;gap:10px;position:relative}
  .nav-toggle{display:inline-flex}
  .nav-menu{
    position:absolute;
    top:68px; left:12px; right:12px;
    display:none;
    flex-direction:column;
    gap:0;
    padding:10px;
    border-radius:18px;
    background:rgba(13,13,13,.96);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 18px 50px rgba(0,0,0,.45);
  }
  .nav-menu.open{display:flex}
  .nav-menu li{width:100%}
  .nav-menu a{display:block;padding:12px 12px;border-radius:14px}
  .nav-menu a:hover{background:rgba(255,255,255,.06)}
}


/* Auth tabs */
.auth-tabs{
  display:flex;
  gap:10px;
  background: rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  padding:6px;
  border-radius:14px;
  margin: 16px 0 18px;
}
.auth-tab{
  flex:1;
  border:0;
  background: transparent;
  color: var(--text, #fff);
  padding:10px 12px;
  border-radius:12px;
  cursor:pointer;
  font-weight:600;
  opacity:.85;
}
.auth-tab.active{
  background: rgba(255,255,255,0.12);
  opacity:1;
}
.link-btn{
  border:0;
  background: transparent;
  color: inherit;
  cursor:pointer;
  text-decoration: underline;
  padding:0;
}
.password-wrapper{
  display:flex;
  align-items:center;
  gap:8px;
}
.toggle-pass{
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.22);
  color: inherit;
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
  white-space:nowrap;
}
.field-hint{display:block;margin-top:8px;opacity:.75;font-size:.85rem}

/* Checkout notes */
.checkout-notes{
  margin: 14px 0 16px;
}
.checkout-notes label{
  display:block;
  margin-bottom:8px;
  font-weight:600;
}
.checkout-notes textarea{
  width:100%;
  min-height: 84px;
  resize: vertical;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.18);
  color: inherit;
  outline:none;
}
.checkout-notes textarea:focus{
  border-color: rgba(255,255,255,0.28);
}

/* Free nav highlight */
.nav-link.nav-free{font-weight:700}


/* Discount UI */
.cart-totals { margin-top: 12px; border-top: 1px solid rgba(255,255,255,0.10); padding-top: 12px; }
.cart-line { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:6px 0; }
.cart-discount-line strong { opacity: 0.95; }
.discount-box { margin-top: 14px; padding: 12px; border-radius: 14px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.10); }
.discount-box label { display:block; font-size: 0.9rem; opacity: 0.9; margin-bottom: 8px; }
.discount-row { display:flex; gap:10px; }
.discount-row input { flex:1; padding: 10px 12px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.14); background: rgba(0,0,0,0.25); color: inherit; }
.discount-apply { padding: 10px 14px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.10); cursor:pointer; }
.discount-apply:hover { transform: translateY(-1px); }
.discount-message { margin-top: 8px; font-size: 0.9rem; opacity: 0.9; }
.discount-message.ok { opacity: 1; }
.discount-message.err { opacity: 1; }

.summary-subtotals { margin-top: 8px; }


/* Payment method picker */
.payment-methods { display:flex; flex-direction:column; gap:12px; margin-bottom:14px; }
.pm-title { margin:0 0 6px; font-size:14px; font-weight:700; color:#e8e8e8; opacity:.9; }
.pm-card { display:flex; align-items:center; gap:12px; padding:12px 14px; border:1px solid rgba(255,255,255,.10); border-radius:14px; background:rgba(255,255,255,.04); cursor:pointer; transition:transform .15s ease, border-color .15s ease, background .15s ease; }
.pm-card:hover { transform: translateY(-1px); border-color: rgba(127,255,0,.35); background:rgba(255,255,255,.06); }
.pm-card input { accent-color:#7fff00; transform:scale(1.1); }
.pm-icon { font-size:20px; width:28px; display:flex; justify-content:center; }
.pm-text { display:flex; flex-direction:column; line-height:1.2; }
.pm-text strong { font-size:14px; color:#fff; }
.pm-text small { font-size:12px; color:rgba(255,255,255,.75); }

.place-order-btn { width:100%; padding:12px 14px; border-radius:14px; font-weight:800; letter-spacing:.2px; }

.btn-primary { background:linear-gradient(135deg, rgba(127,255,0,.9), rgba(127,255,0,.55)); border:none; color:#0b0f07; }
.btn-secondary { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); color:#fff; }

.confirm-modal-content { max-width:520px; }
.confirm-actions { display:flex; gap:10px; margin-top:14px; }
.confirm-actions button { flex:1; padding:12px 14px; border-radius:14px; font-weight:800; }

.product-badge{display:inline-block;margin-top:6px;padding:4px 10px;border-radius:999px;font-size:12px;background:#7a0000;color:#fff;border:1px solid rgba(255,255,255,.15)}
.add-to-cart-btn:disabled{opacity:.55;cursor:not-allowed}


.lang-toggle{margin:0 10px;padding:6px 10px;border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff;border-radius:10px;cursor:pointer;}
.lang-toggle:hover{border-color:rgba(0,255,0,.5)}


/* OTP controls */
.otp-row { margin-top: 10px; }
.otp-controls { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.otp-controls input { flex:1; min-width: 160px; }
.btn.secondary { background: transparent; border: 1px solid rgba(255,255,255,0.25); color: #fff; }
.btn.secondary:hover { border-color: rgba(0,255,0,0.55); }
.help.small { font-size: 12px; opacity: .85; margin-top: 6px; }


/* =========================
   Micro-interactions / Effects
   ========================= */
.reveal-on-scroll {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .5s ease, transform .5s ease;
}
.reveal-on-scroll.visible {
  opacity: 1;
  transform: translateY(0);
}

.product-card {
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.product-card:hover {
  transform: translateY(-4px) scale(1.01);
  box-shadow: 0 12px 30px rgba(0,0,0,.45);
  border-color: rgba(57, 255, 20, .35);
}

.btn, button, .btn-primary, .add-to-cart-btn {
  transition: transform .15s ease, filter .15s ease;
}
.btn:hover, button:hover, .btn-primary:hover, .add-to-cart-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}
.btn:active, button:active, .btn-primary:active, .add-to-cart-btn:active {
  transform: translateY(0px) scale(.98);
}

.nav-toggle {
  z-index: 9999;
  touch-action: manipulation;
}
.nav-menu.open {
  display: flex !important;
}
