/* =========================================================
   Shundor Shop - Main Stylesheet
   ========================================================= */
:root{
  --primary:#7c3aed;
  --primary-dark:#5b21b6;
  --primary-light:#ede9fe;
  --accent:#f59e0b;
  --dark:#1f2333;
  --gray:#6b7280;
  --light-bg:#f8f7fc;
  --border:#e7e4f5;
  --success:#16a34a;
  --danger:#dc2626;
  --radius:14px;
  --shadow:0 8px 24px rgba(124,58,237,0.08);
  --shadow-hover:0 16px 40px rgba(124,58,237,0.18);
  --trans:all .25s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;}
body{
  margin:0;
  font-family:'Poppins',-apple-system,'Segoe UI',sans-serif;
  background:var(--light-bg);
  color:var(--dark);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
.container{max-width:1240px;margin:0 auto;padding:0 20px;}

/* ---------- Loader ---------- */
#page-loader{
  position:fixed;inset:0;background:#fff;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .4s ease, visibility .4s ease;
}
#page-loader.hide{opacity:0;visibility:hidden;}
.loader-ring{
  width:52px;height:52px;border:4px solid var(--primary-light);
  border-top-color:var(--primary);border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ---------- Fade / animation utility ---------- */
.fade-up{opacity:0;transform:translateY(24px);transition:var(--trans);}
.fade-up.in{opacity:1;transform:translateY(0);}
.pop{transition:transform .25s ease;}
.pop:hover{transform:translateY(-6px);}

/* ---------- Top bar ---------- */
.topbar{background:var(--dark);color:#cbd5e1;font-size:13px;padding:6px 0;}
.topbar .container{display:flex;justify-content:space-between;align-items:center;}

/* ---------- Header ---------- */
header.site-header{
  background:#fff;position:sticky;top:0;z-index:500;
  box-shadow:0 2px 12px rgba(0,0,0,.04);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:20px;}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:22px;color:var(--primary-dark);}
.logo img{height:42px;width:auto;border-radius:8px;}
.search-box{flex:1;max-width:480px;position:relative;}
.search-box input{
  width:100%;padding:11px 44px 11px 16px;border-radius:30px;border:1.5px solid var(--border);
  outline:none;transition:var(--trans);font-size:14px;
}
.search-box input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light);}
.search-box button{
  position:absolute;right:4px;top:4px;bottom:4px;width:38px;border:none;border-radius:50%;
  background:var(--primary);color:#fff;cursor:pointer;transition:var(--trans);
}
.search-box button:hover{background:var(--primary-dark);transform:scale(1.06);}
.header-actions{display:flex;align-items:center;gap:22px;}
.header-actions a{display:flex;flex-direction:column;align-items:center;font-size:12px;color:var(--dark);gap:2px;position:relative;transition:var(--trans);}
.header-actions a:hover{color:var(--primary);transform:translateY(-2px);}
.header-actions svg{width:22px;height:22px;}
.cart-count{
  position:absolute;top:-6px;right:-10px;background:var(--accent);color:#fff;
  font-size:11px;width:19px;height:19px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  animation:pop-in .3s ease;
}
@keyframes pop-in{0%{transform:scale(0);}70%{transform:scale(1.3);}100%{transform:scale(1);}}

/* ---------- Nav / categories ---------- */
nav.main-nav{background:var(--primary);}
nav.main-nav .container{display:flex;gap:26px;overflow-x:auto;}
nav.main-nav a{color:#fff;padding:12px 0;font-size:14.5px;font-weight:500;white-space:nowrap;position:relative;transition:var(--trans);}
nav.main-nav a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:#fff;transition:var(--trans);}
nav.main-nav a:hover::after{width:100%;}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(120deg,var(--primary) 0%,var(--primary-dark) 100%);
  color:#fff;border-radius:0 0 40px 40px;padding:60px 0;margin-bottom:40px;overflow:hidden;position:relative;
}
.hero::before{
  content:'';position:absolute;width:400px;height:400px;background:rgba(255,255,255,.08);
  border-radius:50%;top:-150px;right:-100px;
}
.hero-inner{display:flex;align-items:center;gap:40px;position:relative;z-index:2;}
.hero-text{flex:1;}
.hero-text h1{font-size:40px;margin:0 0 14px;font-weight:700;animation:slideIn .7s ease;}
.hero-text p{font-size:16px;opacity:.9;margin-bottom:26px;max-width:460px;}
@keyframes slideIn{from{opacity:0;transform:translateX(-30px);}to{opacity:1;transform:translateX(0);}}
.btn{
  display:inline-block;padding:12px 26px;border-radius:30px;border:none;cursor:pointer;
  font-weight:600;font-size:14.5px;transition:var(--trans);
}
.btn-light{background:#fff;color:var(--primary-dark);}
.btn-light:hover{background:var(--accent);color:#fff;transform:translateY(-3px);box-shadow:0 10px 20px rgba(0,0,0,.15);}
.btn-primary{background:var(--primary);color:#fff;}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-3px);box-shadow:var(--shadow-hover);}
.btn-outline{background:transparent;border:1.5px solid var(--primary);color:var(--primary);}
.btn-outline:hover{background:var(--primary);color:#fff;}
.btn-block{width:100%;text-align:center;}
.btn-danger{background:var(--danger);color:#fff;}
.btn-sm{padding:7px 16px;font-size:13px;}

/* ---------- Section title ---------- */
.section-title{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:22px;}
.section-title h2{font-size:26px;margin:0;position:relative;padding-left:16px;}
.section-title h2::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:5px;background:var(--primary);border-radius:3px;}
.section-title a{color:var(--primary);font-weight:600;font-size:14px;}

/* ---------- Category grid ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:18px;margin-bottom:50px;}
.cat-card{
  background:#fff;border-radius:var(--radius);padding:22px 12px;text-align:center;box-shadow:var(--shadow);
  transition:var(--trans);
}
.cat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);}
.cat-icon{
  width:64px;height:64px;border-radius:50%;background:var(--primary-light);margin:0 auto 12px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.cat-icon img{width:100%;height:100%;object-fit:cover;}
.cat-card h4{margin:0;font-size:14.5px;font-weight:600;}

/* ---------- Product grid & cards ---------- */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:22px;margin-bottom:50px;}
.product-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  transition:var(--trans);position:relative;display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);}
.product-thumb{position:relative;height:200px;overflow:hidden;background:#f2f0fa;}
.product-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.product-card:hover .product-thumb img{transform:scale(1.08);}
.badge-discount{
  position:absolute;top:10px;left:10px;background:var(--accent);color:#fff;font-size:12px;
  padding:4px 10px;border-radius:20px;font-weight:600;
}
.quick-add{
  position:absolute;right:10px;bottom:-50px;background:var(--primary);color:#fff;border:none;
  width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--trans);
}
.product-card:hover .quick-add{bottom:10px;}
.quick-add:hover{background:var(--primary-dark);transform:scale(1.1);}
.product-info{padding:16px;flex:1;display:flex;flex-direction:column;}
.product-info .cat-tag{font-size:11.5px;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;}
.product-info h3{font-size:15.5px;margin:6px 0;font-weight:600;line-height:1.4;}
.product-info h3 a:hover{color:var(--primary);}
.price-row{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:8px;}
.price-now{font-weight:700;color:var(--primary-dark);font-size:16px;}
.price-old{text-decoration:line-through;color:var(--gray);font-size:13px;}

/* ---------- Breadcrumb ---------- */
.breadcrumb{padding:16px 0;font-size:13.5px;color:var(--gray);}
.breadcrumb a{color:var(--primary);}

/* ---------- Product details ---------- */
.pd-wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;background:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);margin-bottom:40px;}
.pd-gallery-main{border-radius:var(--radius);overflow:hidden;background:#f2f0fa;height:420px;margin-bottom:14px;}
.pd-gallery-main img{width:100%;height:100%;object-fit:contain;animation:fadeZoom .4s ease;}
@keyframes fadeZoom{from{opacity:0;transform:scale(.96);}to{opacity:1;transform:scale(1);}}
.pd-thumbs{display:flex;gap:10px;}
.pd-thumbs img{width:70px;height:70px;object-fit:cover;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:var(--trans);}
.pd-thumbs img:hover, .pd-thumbs img.active{border-color:var(--primary);}
.pd-info h1{font-size:26px;margin:0 0 10px;}
.pd-meta{color:var(--gray);font-size:13.5px;margin-bottom:14px;}
.pd-price{font-size:28px;font-weight:700;color:var(--primary-dark);margin:14px 0;display:flex;align-items:center;gap:12px;}
.pd-price .price-old{font-size:18px;}
.stock-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12.5px;font-weight:600;}
.stock-in{background:#dcfce7;color:var(--success);}
.stock-out{background:#fee2e2;color:var(--danger);}
.qty-box{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:30px;width:fit-content;margin:18px 0;overflow:hidden;}
.qty-box button{width:38px;height:38px;border:none;background:var(--light-bg);cursor:pointer;font-size:18px;transition:var(--trans);}
.qty-box button:hover{background:var(--primary-light);}
.qty-box input{width:50px;text-align:center;border:none;font-size:15px;}
.pd-actions{display:flex;gap:14px;margin-top:18px;}
.pd-desc{margin-top:24px;padding-top:20px;border-top:1px solid var(--border);color:var(--gray);font-size:14.5px;}

/* ---------- Cart page ---------- */
.cart-table{width:100%;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border-collapse:collapse;}
.cart-table th{background:var(--primary-light);color:var(--primary-dark);text-align:left;padding:14px;font-size:13.5px;}
.cart-table td{padding:14px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:14px;}
.cart-item-info{display:flex;align-items:center;gap:12px;}
.cart-item-info img{width:64px;height:64px;object-fit:cover;border-radius:10px;}
.remove-btn{color:var(--danger);cursor:pointer;font-size:13px;transition:var(--trans);}
.remove-btn:hover{text-decoration:underline;}
.cart-summary{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;}
.cart-summary .row{display:flex;justify-content:space-between;margin-bottom:12px;font-size:14.5px;}
.cart-summary .row.total{font-size:18px;font-weight:700;border-top:1px solid var(--border);padding-top:14px;margin-top:6px;}

/* ---------- Forms ---------- */
.form-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;max-width:520px;margin:30px auto;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:13.5px;font-weight:600;margin-bottom:6px;}
.form-group label .req{color:var(--danger);}
.form-group input, .form-group select, .form-group textarea{
  width:100%;padding:11px 14px;border-radius:10px;border:1.5px solid var(--border);outline:none;
  font-size:14px;font-family:inherit;transition:var(--trans);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{
  border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.alert{padding:13px 16px;border-radius:10px;font-size:14px;margin-bottom:18px;}
.alert-success{background:#dcfce7;color:#166534;}
.alert-error{background:#fee2e2;color:#991b1b;}

/* ---------- Account layout ---------- */
.account-wrap{display:grid;grid-template-columns:240px 1fr;gap:26px;margin:30px 0;}
.account-sidebar{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;height:fit-content;}
.account-sidebar a{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;font-size:14.5px;margin-bottom:4px;transition:var(--trans);color:var(--dark);}
.account-sidebar a:hover, .account-sidebar a.active{background:var(--primary-light);color:var(--primary-dark);}
.account-content{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;}

/* ---------- Badges ---------- */
.badge{padding:5px 13px;border-radius:20px;font-size:12px;font-weight:600;display:inline-block;}
.badge-new{background:#e0f2fe;color:#0369a1;}
.badge-pending{background:#fef3c7;color:#92400e;}
.badge-processing{background:#e0e7ff;color:#3730a3;}
.badge-delivered{background:#dcfce7;color:#166534;}
.badge-onhold{background:#fce7f3;color:#9d174d;}
.badge-cancelled{background:#fee2e2;color:#991b1b;}
.badge-refunded{background:#f3f4f6;color:#374151;}

/* ---------- Orders table ---------- */
.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.data-table th{background:var(--primary-light);color:var(--primary-dark);padding:13px;text-align:left;font-size:13px;}
.data-table td{padding:13px;border-bottom:1px solid var(--border);font-size:13.5px;}
.data-table tr:hover td{background:#faf9ff;}

/* ---------- Invoice ---------- */
.invoice-box{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:40px;max-width:800px;margin:30px auto;}
.invoice-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--primary);padding-bottom:20px;margin-bottom:20px;}
.invoice-head .shop-info img{height:50px;margin-bottom:8px;}
.invoice-head .shop-info h2{margin:0;color:var(--primary-dark);}
.invoice-head .shop-info p{margin:2px 0;font-size:13px;color:var(--gray);}
.invoice-head .invoice-meta{text-align:right;font-size:13.5px;}
.invoice-head .invoice-meta h3{margin:0 0 6px;color:var(--primary);}
.invoice-addr{display:flex;justify-content:space-between;margin-bottom:24px;}
.invoice-addr div{font-size:13.5px;}
.invoice-addr h4{margin:0 0 6px;font-size:14px;color:var(--dark);}
table.invoice-table{width:100%;border-collapse:collapse;margin-bottom:20px;}
table.invoice-table th{background:var(--primary-light);padding:10px;text-align:left;font-size:13px;color:var(--primary-dark);}
table.invoice-table td{padding:10px;border-bottom:1px solid var(--border);font-size:13.5px;}
table.invoice-table img{width:44px;height:44px;object-fit:cover;border-radius:6px;}
.invoice-totals{width:280px;margin-left:auto;font-size:14px;}
.invoice-totals .row{display:flex;justify-content:space-between;padding:6px 0;}
.invoice-totals .row.grand{font-weight:700;font-size:16px;border-top:2px solid var(--primary);padding-top:10px;color:var(--primary-dark);}
.invoice-footer{text-align:center;margin-top:30px;padding-top:16px;border-top:1px dashed var(--border);font-size:12.5px;color:var(--gray);}

@media print{
  header, nav, footer, .no-print{display:none !important;}
  .invoice-box{box-shadow:none;margin:0;max-width:100%;}
  body{background:#fff;}
}

/* ---------- Footer ---------- */
footer.site-footer{background:var(--dark);color:#cbd5e1;padding:50px 0 20px;margin-top:60px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:30px;}
.footer-grid h4{color:#fff;margin-bottom:14px;font-size:15px;}
.footer-grid p, .footer-grid a{color:#9ca3af;font-size:13.5px;line-height:2;display:block;transition:var(--trans);}
.footer-grid a:hover{color:#fff;padding-left:4px;}
.footer-bottom{text-align:center;border-top:1px solid #333a4d;padding-top:18px;font-size:13px;color:#8b93a7;}

/* ---------- Toast ---------- */
#toast{
  position:fixed;bottom:26px;right:26px;background:var(--dark);color:#fff;padding:14px 22px;border-radius:10px;
  font-size:14px;transform:translateY(100px);opacity:0;transition:var(--trans);z-index:9999;box-shadow:0 10px 30px rgba(0,0,0,.25);
}
#toast.show{transform:translateY(0);opacity:1;}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .pd-wrap{grid-template-columns:1fr;}
  .account-wrap{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:600px){
  .header-inner{flex-wrap:wrap;}
  .search-box{order:3;width:100%;}
  .hero-inner{flex-direction:column;text-align:center;}
  .hero-text h1{font-size:28px;}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
}
