/* ============ MyTailor — Luxury Tailor Shop Styles ============ */
:root{
  --navy:#0e1a2b;
  --navy-2:#15263d;
  --charcoal:#1c1c24;
  --gold:#c9a24a;
  --gold-2:#e7c97a;
  --cream:#f6efe1;
  --muted:#9aa3b2;
  --line:rgba(201,162,74,.25);
  --danger:#e2574c;
  --success:#28a745;
  --radius:12px;
  --shadow:0 12px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--navy);color:var(--cream);font-family:'DM Sans',sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Playfair Display',serif;color:var(--cream);letter-spacing:.3px;font-weight:600}
h1{font-size:clamp(2rem,4vw,3.4rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:1.3rem}
a{color:var(--gold-2);text-decoration:none}
a:hover{color:var(--gold)}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
section{padding:80px 0}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:.95rem;transition:transform .15s ease, background .2s ease, color .2s ease}
.btn-primary{background:var(--gold);color:var(--navy)}
.btn-primary:hover{background:var(--gold-2);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--gold-2);border:1.5px solid var(--gold)}
.btn-outline:hover{background:var(--gold);color:var(--navy)}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid rgba(255,255,255,.18)}
.btn-ghost:hover{border-color:var(--gold)}
.btn-block{width:100%}
.btn-danger{background:var(--danger);color:#fff}

/* ===== Navbar ===== */
.navbar{position:sticky;top:0;z-index:100;background:rgba(14,26,43,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;max-width:1200px;margin:0 auto}
.logo{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--gold-2);font-weight:700;letter-spacing:1px}
.logo span{color:var(--cream)}
.nav-links{display:flex;gap:28px;align-items:center;list-style:none}
.nav-links a{color:var(--cream);font-weight:500;transition:color .2s}
.nav-links a:hover, .nav-links a.active{color:var(--gold)}
.nav-actions{display:flex;align-items:center;gap:14px}
.cart-icon{position:relative;color:var(--cream);font-size:1.3rem;cursor:pointer}
.cart-count{position:absolute;top:-8px;right:-10px;background:var(--gold);color:var(--navy);font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}
.user-chip{display:flex;align-items:center;gap:8px;color:var(--gold-2);font-weight:500;font-size:.9rem}
.hamburger{display:none;background:none;border:none;color:var(--cream);font-size:1.6rem;cursor:pointer}

/* ===== Hero ===== */
.hero{position:relative;height:90vh;min-height:600px;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 70% 50%, rgba(201,162,74,.18) 0%, transparent 55%),
    radial-gradient(ellipse at 20% 80%, rgba(28,28,36,.6) 0%, transparent 60%),
    linear-gradient(135deg, #0a1422 0%, #15263d 50%, #1c1c24 100%);
}
.hero-bg::before{content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(45deg, rgba(201,162,74,.04) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(201,162,74,.04) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(201,162,74,.04) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(201,162,74,.04) 75%);
  background-size:14px 14px;background-position:0 0, 0 7px, 7px -7px, -7px 0;
  opacity:.55;
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(110deg, rgba(10,20,34,.85) 0%, rgba(14,26,43,.4) 50%, rgba(14,26,43,.15) 100%);z-index:2}

/* Hero video (when admin selects video mode) */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}

/* Tailor sewing animation stage */
.hero-stage{position:absolute;right:0;top:0;bottom:0;width:55%;z-index:2;display:flex;align-items:center;justify-content:center;pointer-events:none}
.sewing-svg{width:100%;max-width:640px;height:auto;filter:drop-shadow(0 20px 40px rgba(0,0,0,.5))}
@media (max-width:920px){
  .hero-stage{width:100%;opacity:.18}
}

/* Spool spinner */
@keyframes spinSpool { from{transform:rotate(0)} to{transform:rotate(360deg)} }
.spool-thread{transform-origin:center;animation:spinSpool 2.6s linear infinite}

/* Needle bobbing for stitch effect */
@keyframes needleBob {
  0%,100% { transform:translateY(0) rotate(-12deg) }
  25%     { transform:translateY(-30px) rotate(-10deg) }
  50%     { transform:translateY(20px) rotate(-12deg) }
  75%     { transform:translateY(-25px) rotate(-14deg) }
}
.needle-group{transform-origin:center;animation:needleBob 1.2s ease-in-out infinite}

/* Stitch line drawing */
@keyframes drawStitch {
  0%   { stroke-dashoffset:600 }
  60%  { stroke-dashoffset:0 }
  100% { stroke-dashoffset:0; opacity:.4 }
}
.stitch-line-anim{
  stroke-dasharray:14 8;stroke-dashoffset:600;
  animation:drawStitch 6s ease-in-out infinite;
}

/* Scissors slowly opening */
@keyframes scissorOpen {
  0%,100% { transform:rotate(-12deg) }
  50%     { transform:rotate(0deg) }
}
.scissor-blade-top{transform-origin:8px 18px;animation:scissorOpen 3.4s ease-in-out infinite}
.scissor-blade-bot{transform-origin:8px 18px;animation:scissorOpen 3.4s ease-in-out infinite reverse}

/* Sparkles */
@keyframes sparkle { 0%,100%{opacity:0;transform:scale(.3)} 50%{opacity:1;transform:scale(1.3)} }
.sparkle{animation:sparkle 2.4s ease-in-out infinite;transform-origin:center}

/* Floating thread loops */
@keyframes floatLoop {
  0%,100% { transform:translateY(0) translateX(0) rotate(0) }
  50%     { transform:translateY(-18px) translateX(8px) rotate(8deg) }
}
.thread-loop{animation:floatLoop 5s ease-in-out infinite;transform-origin:center}

/* ===== Right-side social media bar ===== */
.social-side{position:fixed;right:18px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px;z-index:95}
.social-side a{
  width:42px;height:42px;border-radius:50%;
  background:rgba(21,38,61,.92);backdrop-filter:blur(6px);
  border:1px solid var(--gold);color:var(--gold-2);
  display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:.95rem;text-decoration:none;
  transition:all .25s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 6px 18px rgba(0,0,0,.35);
  animation:slideInRight .6s ease both;
}
.social-side a:nth-child(1){animation-delay:.1s}
.social-side a:nth-child(2){animation-delay:.2s}
.social-side a:nth-child(3){animation-delay:.3s}
.social-side a:nth-child(4){animation-delay:.4s}
.social-side a:nth-child(5){animation-delay:.5s}
.social-side a:nth-child(6){animation-delay:.6s}
.social-side a:hover{background:var(--gold);color:var(--navy);transform:scale(1.15) translateX(-4px);border-color:var(--gold-2)}
@keyframes slideInRight {
  from{transform:translateX(70px);opacity:0}
  to{transform:translateX(0);opacity:1}
}
@media (max-width:760px){
  .social-side{display:none}
}
.hero-content{position:relative;z-index:3;max-width:680px;padding:0 20px}
.hero-tag{display:inline-block;color:var(--gold-2);font-weight:600;letter-spacing:3px;text-transform:uppercase;font-size:.85rem;margin-bottom:18px}
.hero h1{margin-bottom:18px;line-height:1.1}
.hero p{font-size:1.15rem;color:#e3e8ef;margin-bottom:32px;max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ===== Section heading ===== */
.section-head{text-align:center;margin-bottom:48px}
.section-head .eyebrow{color:var(--gold-2);letter-spacing:3px;text-transform:uppercase;font-size:.8rem;font-weight:600;margin-bottom:12px;display:block}
.section-head h2{margin-bottom:10px}
.section-head p{color:var(--muted);max-width:600px;margin:0 auto}

/* ===== Categories grid ===== */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:760px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.cat-grid{grid-template-columns:1fr}}

/* ===== Gallery grid ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery-item{aspect-ratio:3/4;overflow:hidden;border-radius:var(--radius);border:1px solid var(--line);background:var(--navy-2);position:relative;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item .gallery-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(14,26,43,.85) 100%);display:flex;align-items:flex-end;padding:14px;color:var(--gold-2);font-weight:600;opacity:0;transition:opacity .2s}
.gallery-item:hover .gallery-overlay{opacity:1}
@media (max-width:760px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.gallery-grid{grid-template-columns:1fr}}
.cat-card{background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);padding:32px 18px;text-align:center;transition:transform .2s ease, border-color .2s;cursor:pointer}
.cat-card:hover{transform:translateY(-4px);border-color:var(--gold)}
.cat-icon{font-size:2.5rem;margin-bottom:14px}
.cat-card h3{font-size:1.05rem;color:var(--cream)}

/* ===== Product grid / cards ===== */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}
.product-card{background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .2s, box-shadow .2s;display:flex;flex-direction:column}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.product-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:#0a1422}
.product-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.product-card:hover .product-img img{transform:scale(1.06)}
.popular-badge{position:absolute;top:12px;left:12px;background:var(--gold);color:var(--navy);font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:20px;letter-spacing:.5px}
.product-info{padding:18px;display:flex;flex-direction:column;gap:8px;flex:1}
.product-cat{color:var(--muted);font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase}
.product-info h3{font-size:1.1rem;color:var(--cream);margin:2px 0}
.product-price{color:var(--gold-2);font-size:1.15rem;font-weight:700;font-family:'Playfair Display',serif;margin-top:auto}
.product-price small{color:var(--muted);font-weight:400;font-size:.8rem}

/* ===== Filters ===== */
.shop-toolbar{display:flex;gap:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:32px;padding:18px;background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius)}
.search-box{flex:1;min-width:220px;display:flex;align-items:center;gap:10px;background:var(--navy);padding:10px 14px;border-radius:8px;border:1px solid var(--line)}
.search-box input{flex:1;background:none;border:none;color:var(--cream);outline:none;font-size:.95rem;font-family:inherit}
.cat-filter{display:flex;gap:8px;flex-wrap:wrap}
.cat-pill{padding:8px 16px;background:var(--navy);border:1px solid var(--line);color:var(--cream);border-radius:20px;cursor:pointer;font-size:.85rem;transition:all .2s}
.cat-pill:hover, .cat-pill.active{background:var(--gold);color:var(--navy);border-color:var(--gold)}

/* ===== Product detail ===== */
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-top:40px}
.pd-img{background:var(--navy-2);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.pd-img img{width:100%;height:auto;display:block}
.pd-info h1{font-size:2.2rem;margin-bottom:8px}
.pd-cat{color:var(--gold-2);text-transform:uppercase;letter-spacing:2px;font-size:.8rem;margin-bottom:14px}
.pd-price{font-size:2rem;color:var(--gold-2);font-family:'Playfair Display',serif;margin:18px 0}
.pd-desc{color:#cdd5e0;line-height:1.7;margin-bottom:24px}

/* ===== Size selector ===== */
.size-selector{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 24px}
.size-btn{min-width:54px;padding:11px 18px;background:transparent;border:1.5px solid var(--line);color:var(--cream);border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s;font-family:inherit}
.size-btn:hover{border-color:var(--gold)}
.size-btn.active{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.size-btn.custom{padding:11px 16px}
.size-label{display:block;color:var(--gold-2);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;font-weight:600}

/* ===== Color swatches ===== */
.color-row{display:flex;gap:10px;margin-bottom:18px}
.color-sw{width:32px;height:32px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:border .2s}
.color-sw.active{border-color:var(--gold)}

/* ===== Forms ===== */
.form{background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-group{margin-bottom:14px;display:flex;flex-direction:column}
.form-group label{font-size:.85rem;color:var(--gold-2);margin-bottom:6px;font-weight:500;letter-spacing:.5px}
.form-group input, .form-group select, .form-group textarea{padding:11px 14px;background:var(--navy);border:1px solid var(--line);border-radius:8px;color:var(--cream);font-family:inherit;font-size:.95rem;outline:none;transition:border .2s}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{resize:vertical;min-height:84px}
.form-help{color:var(--muted);font-size:.78rem;margin-top:4px}
.form-error{color:var(--danger);font-size:.82rem;margin-top:4px;display:none}
.form-error.show{display:block}

/* ===== Measurement form ===== */
.measure-card{margin-top:24px;background:var(--navy-2);padding:24px;border-radius:var(--radius);border:1px solid var(--gold)}
.measure-card h3{color:var(--gold-2);margin-bottom:6px}
.measure-card p.sub{color:var(--muted);font-size:.88rem;margin-bottom:18px}
.measure-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.upload-zone{border:2px dashed var(--line);padding:24px;border-radius:8px;text-align:center;color:var(--muted);cursor:pointer;transition:border .2s}
.upload-zone:hover{border-color:var(--gold)}
.upload-zone.has-file{border-color:var(--gold);color:var(--gold-2)}

/* ===== How it works ===== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
.step{text-align:center;padding:24px}
.step-num{width:60px;height:60px;border:2px solid var(--gold);color:var(--gold-2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700}
.step h3{margin-bottom:8px}
.step p{color:var(--muted);font-size:.92rem}

/* ===== Testimonials ===== */
.testimonials{background:var(--navy-2)}
.test-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.test-card{background:var(--navy);padding:28px;border:1px solid var(--line);border-radius:var(--radius)}
.stars{color:var(--gold);margin-bottom:12px;letter-spacing:2px}
.test-text{font-style:italic;color:#cdd5e0;margin-bottom:18px;line-height:1.7}
.test-name{color:var(--gold-2);font-weight:600}

/* ===== WhatsApp banner & float ===== */
.wa-banner{background:linear-gradient(120deg, var(--navy-2), var(--charcoal));border:1px solid var(--gold);border-radius:var(--radius);padding:36px;text-align:center;margin-top:30px}
.wa-banner h2{color:var(--gold-2);margin-bottom:12px}
.wa-banner p{color:#cdd5e0;margin-bottom:20px}
.whatsapp-float{position:fixed;bottom:24px;right:24px;background:#25D366;color:#fff;padding:12px 20px;border-radius:50px;font-weight:600;box-shadow:0 8px 24px rgba(37,211,102,.4);z-index:90;display:flex;align-items:center;gap:8px;transition:transform .2s}
.whatsapp-float:hover{transform:translateY(-2px);color:#fff}

/* ===== Footer ===== */
footer{background:#0a1422;border-top:1px solid var(--line);padding:50px 0 24px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;margin-bottom:32px}
.footer-col h4{color:var(--gold-2);margin-bottom:14px;font-size:1.05rem}
.footer-col a, .footer-col p{color:var(--muted);font-size:.9rem;display:block;margin-bottom:8px}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--line);padding-top:18px;text-align:center;color:var(--muted);font-size:.82rem}
.social{display:flex;gap:12px;margin-top:8px}
.social a{width:36px;height:36px;border-radius:50%;background:var(--navy-2);display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);transition:all .2s}
.social a:hover{border-color:var(--gold);color:var(--gold)}

/* ===== Cart ===== */
.cart-table{width:100%;background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;border-collapse:collapse}
.cart-table th, .cart-table td{padding:14px;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem}
.cart-table th{background:var(--charcoal);color:var(--gold-2);font-weight:600;text-transform:uppercase;font-size:.78rem;letter-spacing:1px}
.cart-table img{width:60px;height:60px;object-fit:cover;border-radius:8px}
.qty-controls{display:flex;align-items:center;gap:8px}
.qty-btn{width:28px;height:28px;background:var(--navy);border:1px solid var(--line);color:var(--cream);cursor:pointer;border-radius:6px}
.cart-summary{background:var(--navy-2);border:1px solid var(--gold);border-radius:var(--radius);padding:24px;margin-top:24px}
.cart-row{display:flex;justify-content:space-between;padding:8px 0;color:#cdd5e0}
.cart-total{font-size:1.4rem;color:var(--gold-2);font-weight:700;font-family:'Playfair Display',serif;border-top:1px solid var(--line);padding-top:14px;margin-top:14px}
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state .icon{font-size:4rem;margin-bottom:14px;opacity:.5}

/* ===== Auth pages ===== */
.auth-wrap{max-width:460px;margin:60px auto;padding:0 20px}
.auth-card{background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);padding:38px}
.auth-card h2{text-align:center;margin-bottom:8px}
.auth-card .sub{text-align:center;color:var(--muted);margin-bottom:24px;font-size:.92rem}
.auth-tabs{display:flex;gap:6px;margin-bottom:24px;background:var(--navy);padding:4px;border-radius:8px}
.auth-tab{flex:1;padding:10px;background:none;border:none;color:var(--muted);cursor:pointer;font-weight:600;border-radius:6px;font-family:inherit;font-size:.9rem;transition:all .2s}
.auth-tab.active{background:var(--gold);color:var(--navy)}
.divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:.82rem}
.divider::before, .divider::after{content:'';flex:1;height:1px;background:var(--line)}
.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;background:#fff;color:#3c4043;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-family:inherit;font-size:.9rem}
.google-btn:hover{background:#f1f3f4}

/* ===== Account / dashboard ===== */
.account-grid{display:grid;grid-template-columns:240px 1fr;gap:32px;padding-top:30px}
.side-nav{background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.side-nav a{display:block;padding:10px 14px;color:var(--cream);border-radius:6px;margin-bottom:4px;font-size:.92rem}
.side-nav a:hover, .side-nav a.active{background:var(--navy);color:var(--gold-2)}
.order-card{background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:14px}
.order-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.order-id{font-family:'Playfair Display',serif;color:var(--gold-2);font-weight:600}
.status-badge{padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.status-pending{background:rgba(226,87,76,.15);color:#f48a82}
.status-confirmed{background:rgba(201,162,74,.15);color:var(--gold-2)}
.status-cutting,.status-stitching{background:rgba(74,144,201,.15);color:#82bdf4}
.status-ready{background:rgba(40,167,69,.15);color:#5dd47b}
.status-delivered{background:rgba(40,167,69,.25);color:#5dd47b}

/* ===== Toast ===== */
.toast-host{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--navy-2);color:var(--cream);padding:14px 18px;border-radius:8px;border-left:4px solid var(--gold);box-shadow:var(--shadow);min-width:240px;animation:slideIn .25s ease}
.toast.success{border-left-color:var(--success)}
.toast.error{border-left-color:var(--danger)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ===== Modal ===== */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal.show{display:flex}
.modal-box{background:var(--navy-2);border:1px solid var(--gold);border-radius:var(--radius);max-width:480px;width:100%;padding:28px;position:relative}
.modal-close{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--cream);font-size:1.5rem;cursor:pointer}

/* ===== Admin layout ===== */
.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{background:var(--charcoal);padding:24px 0;border-right:1px solid var(--line)}
.admin-side .logo{display:block;text-align:center;margin-bottom:30px;padding:0 20px}
.admin-side a{display:block;padding:12px 24px;color:#cdd5e0;font-size:.92rem;border-left:3px solid transparent}
.admin-side a:hover, .admin-side a.active{background:var(--navy-2);color:var(--gold-2);border-left-color:var(--gold)}
.admin-main{padding:32px;overflow-x:auto}
.admin-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:14px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:30px}
.stat-card{background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.stat-card .label{color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.stat-card .value{font-family:'Playfair Display',serif;font-size:1.9rem;color:var(--gold-2);font-weight:700}

.data-table{width:100%;background:var(--navy-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;border-collapse:collapse;font-size:.88rem}
.data-table th, .data-table td{padding:12px;text-align:left;border-bottom:1px solid var(--line)}
.data-table th{background:var(--charcoal);color:var(--gold-2);font-weight:600;text-transform:uppercase;font-size:.74rem;letter-spacing:1px}
.data-table tr:hover{background:rgba(201,162,74,.04)}
.data-table img{width:48px;height:48px;border-radius:6px;object-fit:cover}
.actions{display:flex;gap:8px}
.icon-btn{padding:6px 10px;background:var(--navy);border:1px solid var(--line);color:var(--cream);border-radius:6px;cursor:pointer;font-size:.82rem}
.icon-btn:hover{border-color:var(--gold);color:var(--gold-2)}
.icon-btn.del:hover{border-color:var(--danger);color:var(--danger)}

/* ===== Responsive ===== */
@media (max-width: 860px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--navy);flex-direction:column;padding:18px;gap:12px;border-bottom:1px solid var(--line)}
  .nav-links.open{display:flex}
  .hamburger{display:block}
  .product-detail{grid-template-columns:1fr;gap:24px}
  .form-row{grid-template-columns:1fr}
  .account-grid, .admin-layout{grid-template-columns:1fr}
  .admin-side{display:none}
  .admin-side.open{display:block}
  .hero{height:auto;padding:90px 0 70px}
  section{padding:60px 0}
  .cart-table th:nth-child(1), .cart-table td:nth-child(1){display:none}
}
@media (max-width:520px){
  .cart-table{font-size:.82rem}
  .cart-table th, .cart-table td{padding:10px 6px}
  .whatsapp-float{padding:10px 14px;font-size:.85rem}
}

/* ============ Animations ============ */
html{scroll-behavior:smooth}

/* Hero — slow Ken Burns zoom */
@keyframes kenBurns { from{transform:scale(1.06)} to{transform:scale(1.18)} }
.hero-bg{animation:kenBurns 22s ease-in-out infinite alternate}

/* Hero overlay gradient pulse */
@keyframes overlayShift {
  0%,100% { background:linear-gradient(120deg, rgba(14,26,43,.85) 0%, rgba(14,26,43,.55) 60%, rgba(14,26,43,.3) 100%) }
  50%     { background:linear-gradient(140deg, rgba(14,26,43,.9) 0%, rgba(28,28,36,.55) 60%, rgba(201,162,74,.15) 100%) }
}
.hero-overlay{animation:overlayShift 16s ease-in-out infinite}

/* Fade-up entrance */
@keyframes fadeUp { from{opacity:0;transform:translateY(36px)} to{opacity:1;transform:translateY(0)} }
.fade-up{opacity:0;animation:fadeUp .9s cubic-bezier(.2,.7,.3,1) forwards}
.fade-up.d1{animation-delay:.15s}
.fade-up.d2{animation-delay:.35s}
.fade-up.d3{animation-delay:.55s}
.fade-up.d4{animation-delay:.75s}

/* Hero floating gold dots */
.hero-dots{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden}
.hero-dot{position:absolute;width:6px;height:6px;background:var(--gold);border-radius:50%;opacity:.35;filter:blur(.5px);animation:floatDot 9s ease-in-out infinite}
@keyframes floatDot {
  0%,100% { transform:translateY(0) scale(1); opacity:.3 }
  50%     { transform:translateY(-40px) scale(1.5); opacity:.85 }
}

/* Gold shimmer on accent words */
@keyframes shimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
.shimmer-gold{
  background:linear-gradient(90deg, var(--gold) 0%, var(--gold-2) 25%, #fff5d2 50%, var(--gold-2) 75%, var(--gold) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  animation:shimmer 5s linear infinite;
}

/* Brand marquee strip */
.marquee{overflow:hidden;background:var(--charcoal);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;position:relative}
.marquee::before, .marquee::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg, var(--charcoal), transparent)}
.marquee::after{right:0;background:linear-gradient(270deg, var(--charcoal), transparent)}
.marquee-track{display:inline-flex;gap:48px;align-items:center;animation:scrollX 28s linear infinite;white-space:nowrap}
.marquee-track span{color:var(--gold-2);font-family:'Playfair Display',serif;font-size:1rem;letter-spacing:4px;text-transform:uppercase}
.marquee-track i{color:var(--gold);font-style:normal;font-size:.6rem;opacity:.7}
@keyframes scrollX { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.3,1)}
.reveal.in-view{opacity:1;transform:translateY(0)}

/* Stagger children */
.stagger > *{opacity:0;transform:translateY(24px);transition:opacity .65s ease, transform .65s cubic-bezier(.2,.7,.3,1)}
.stagger.in-view > *{opacity:1;transform:translateY(0)}
.stagger.in-view > *:nth-child(1){transition-delay:.05s}
.stagger.in-view > *:nth-child(2){transition-delay:.15s}
.stagger.in-view > *:nth-child(3){transition-delay:.25s}
.stagger.in-view > *:nth-child(4){transition-delay:.35s}
.stagger.in-view > *:nth-child(5){transition-delay:.45s}
.stagger.in-view > *:nth-child(6){transition-delay:.55s}

/* Category card icon bounce on hover */
.cat-card .cat-icon{transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.cat-card:hover .cat-icon{transform:translateY(-6px) rotate(-6deg) scale(1.1)}

/* Step number pulse */
@keyframes pulseGold {
  0%,100% { box-shadow:0 0 0 0 rgba(201,162,74,.6) }
  50%     { box-shadow:0 0 0 14px rgba(201,162,74,0) }
}
.step:hover .step-num{animation:pulseGold 1.2s ease-out infinite;background:var(--gold);color:var(--navy)}

/* Stitched underline accent (decorative) */
.stitch-line{display:block;height:2px;width:80px;margin:14px auto 0;background:repeating-linear-gradient(90deg, var(--gold) 0 6px, transparent 6px 12px)}

/* WhatsApp float — gentle bounce */
@keyframes waBounce {
  0%,100% { transform:translateY(0) }
  50%     { transform:translateY(-6px) }
}
.whatsapp-float{animation:waBounce 2.6s ease-in-out infinite}
.whatsapp-float:hover{animation:none}

/* Button hover ripple */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{
  content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;
  background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .5s ease, height .5s ease;
}
.btn-primary:hover::after{width:300px;height:300px}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important; animation-iteration-count:1 !important;
    transition-duration:.01ms !important; scroll-behavior:auto !important;
  }
  .hero-bg{animation:none}
}

/* ===== Utility ===== */
.text-center{text-align:center}
.mt-2{margin-top:14px}.mt-3{margin-top:24px}.mt-4{margin-top:36px}
.mb-2{margin-bottom:14px}
.flex{display:flex}.gap-1{gap:8px}.gap-2{gap:14px}
.hidden{display:none}
.print-only{display:none}
@media print{
  .navbar, footer, .whatsapp-float, .no-print{display:none}
  .print-only{display:block}
  body{background:#fff;color:#000}
}
