/* css/style.css — fixed, unified */

/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&display=swap');

/* =========================================
   1) THEME + GLOBAL
========================================= */
:root{
  --primary-color:#7B61FF;
  --primary-600:#6a4df8;
  --primary-700:#5a3ff2;
  --primary-light:#EFEAFF;

  --bg:#ffffff;
  --bg-soft:#F7F8FA;
  --text:#1B2124;
  --muted:#6d6d7a;

  --card:#ffffff;
  --border:#EAEBF0;
  --shadow:0 10px 28px rgba(18,18,18,.07);

  --danger:#E53E3E;
  --success:#38A169;

  --ring: rgba(123,97,255,.28);

  /* secondary header injected by JS */
  --sec-top: 72px;
  --sec-height: 0px;
}

body.dark-mode{
  --bg:#11131a;
  --bg-soft:#171a23;
  --text:#E6E8EC;
  --muted:#97A0AD;

  --card:#191D27;
  --border:#2C3242;
  --shadow:0 12px 30px rgba(0,0,0,.35);

  --primary-color:#927BFF;
  --primary-600:#886dfa;
  --primary-700:#7a5ef6;
  --primary-light:#262140;

  --ring: rgba(146,123,255,.36);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at -10% -20%, #ffe8f3 0%, transparent 40%),
    radial-gradient(1000px 600px at 110% 10%, #f1edff 0%, transparent 40%),
    var(--bg);
  line-height:1.6;
}
body.dark-mode{
  background:
    radial-gradient(900px 600px at -15% -20%, rgba(124,99,255,.14) 0%, transparent 50%),
    radial-gradient(1000px 600px at 120% 20%, rgba(124,99,255,.12) 0%, transparent 55%),
    var(--bg);
}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.hidden{display:none !important}
.center{text-align:center}
.muted{color:var(--muted)}
.tiny{font-size:12px}
.text-primary{color:var(--primary-color)}
.badge{display:inline-block;padding:2px 10px;border-radius:999px;background:var(--primary-light);color:var(--primary-color);font-weight:700;font-size:12px}
.chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:10px;border:1px solid var(--border);background:var(--bg-soft)}

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

.spinner{width:48px;height:48px;border-radius:50%;border:5px solid var(--bg-soft);border-top-color:var(--primary-color);margin:36px auto;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* =========================================
   2) HEADER + NAV
========================================= */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(130%) blur(8px);
  border-bottom:1px solid var(--border);
}
body.dark-mode .site-header{background:rgba(17,19,26,.7)}
.header-inner{display:flex;align-items:center;gap:14px;min-height:64px}

.brand{display:flex;align-items:center;gap:10px;color:var(--text);font-weight:800}
.brand img{width:32px;height:32px;object-fit:contain}

.desk-nav{display:flex;gap:18px;margin-left:10px;flex:1}
.desk-nav a{color:var(--muted);font-weight:700}
.desk-nav a:hover,.desk-nav a.active{color:var(--primary-color)}

.icon-btn{
  background:transparent;border:1px solid var(--border);color:var(--text);
  padding:8px 10px;border-radius:10px;cursor:pointer;
}
.icon-btn.small{padding:6px 8px;font-size:14px}
.icon-btn:focus{outline:none;box-shadow:0 0 0 3px var(--ring)}

.btn{
  padding:10px 16px;border-radius:12px;border:1px solid transparent;
  font-weight:800;cursor:pointer;transition:.2s ease;background:transparent;color:var(--text)
}
.btn.small{padding:8px 12px;border-radius:10px}
.btn:focus{outline:none;box-shadow:0 0 0 3px var(--ring)}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--primary-color);color:#fff;box-shadow:0 12px 28px rgba(123,97,255,.28)}
.btn-primary:hover{background:var(--primary-600)}
.btn-secondary{background:transparent;color:var(--primary-color);border-color:var(--primary-color)}
.btn-secondary:hover{background:var(--primary-color);color:#fff}

.user-prof{position:relative}
.user-btn{display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text);cursor:pointer}
.user-btn img{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}

.dropdown-menu{
  position:absolute;right:0;top:44px;background:var(--card);border:1px solid var(--border);
  border-radius:12px;box-shadow:var(--shadow);min-width:220px;padding:8px;display:none;z-index:1200;
}
.dropdown-menu.is-open{display:block}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--text)}
.dropdown-item:hover{background:var(--bg-soft)}

@media (max-width:980px){ .desk-nav{display:none} }

/* =========================================
   3) MOBILE MENU
========================================= */
#mobile-menu{
  position:fixed;inset:0 0 0 auto;width:min(86%,360px);background:var(--card);
  transform:translateX(100%);transition:transform .25s ease;z-index:1050;border-left:1px solid var(--border);
  display:flex;flex-direction:column;
}
#mobile-menu.is-open{transform:none}
.mobile-head{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid var(--border)}
.mobile-body{padding:14px;display:flex;flex-direction:column;gap:12px;height:100%;overflow:auto}
.user-mini{display:flex;gap:10px;align-items:center}
.user-mini img{width:40px;height:40px;border-radius:50%;object-fit:cover}
.mobile-nav-links{display:grid;gap:8px}
.mobile-nav-links a{padding:10px;border-radius:10px;color:var(--text)}
.mobile-nav-links a:hover{background:var(--bg-soft)}

/* =========================================
   4) HOME HERO (new layout)
========================================= */
.home-hero-wrap{display:grid;gap:0}
.banner-fallback{
  background: radial-gradient(800px 200px at 40% 50%, #fff1a7 0%, #ffe164 60%, #ffd74a 100%);
  min-height: 220px; display:grid; align-items:center;
  padding: 22px; position: relative;
}
.banner-fallback .banner-text h1{font-size: clamp(22px, 3.4vw, 40px); font-weight:800; line-height:1.2}
.banner-fallback .banner-text p{color:#333}
.banner-fallback .banner-person{
  position:absolute; right: clamp(8px,4vw,42px); bottom:-6px;
  width: clamp(120px,16vw,220px); height:auto; object-fit: contain;
}

.hero-slab{
  background: var(--primary-light);
  margin-top: -10px; padding: 24px 18px 40px;
  text-align:center; border-bottom: 1px solid var(--border);
}
.dot-row{display:flex;gap:6px;justify-content:center;margin:-6px 0 10px}
.dot-row span{width:8px;height:8px;border-radius:10px;background:#2223;display:inline-block}
.dot-row span:nth-child(4){background: var(--primary-color)}
.hero-slab h2{font-size: clamp(20px, 3.4vw, 32px); margin: 6px 0 10px; font-weight:800}
.hero-slab h2 .highlight{color: var(--primary-color)}
.hero-slab p{margin:0 0 12px;color:var(--muted)}
.hero-slab .btn{display:inline-flex;align-items:center;gap:10px}
.hero-person{margin: 18px auto 0; width:min(360px,86%); max-height: 320px; object-fit: contain; display:block}

/* Free callout + phone float */
#free-callout{
  position:fixed;left:14px;bottom:80px;z-index:40;background:#fff;color:#111;border:1px solid var(--border);
  width:240px;border-radius:16px;padding:12px;box-shadow:0 16px 40px rgba(0,0,0,.15)
}
#free-callout .icon-btn.small{position:absolute;right:8px;top:8px}
.phone-float{
  position:fixed;left:14px;bottom:18px;z-index:39;width:52px;height:52px;border-radius:50%;
  background:var(--primary-color);color:#fff;display:grid;place-items:center;box-shadow:0 14px 30px rgba(123,97,255,.35)
}

/* =========================================
   5) CAROUSEL
========================================= */
.carousel-container{position:relative;overflow:hidden;border-radius:12px;box-shadow:var(--shadow)}
.carousel-slide{display:none;opacity:0;transition:opacity .8s ease}
.carousel-slide.active{display:block;opacity:1}
.carousel-slide img{width:100%;height:auto;display:block}
.carousel-dots{position:absolute;left:50%;transform:translateX(-50%);bottom:12px;display:flex;gap:8px}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.6);border:1px solid rgba(0,0,0,.15);cursor:pointer}
.dot.active{background:rgba(255,255,255,.95)}

/* =========================================
   6) SECTIONS (Explore / Stats / Testimonials / Platforms)
========================================= */
.section{padding:22px 0}
.title{font-size:clamp(18px,3.2vw,28px);font-weight:800;margin-bottom:8px;text-align:center}
.subtitle{color:var(--muted);text-align:center;margin-bottom:16px}

.explore-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:900px){ .explore-grid{grid-template-columns:1fr 1fr} }
@media (max-width:620px){ .explore-grid{grid-template-columns:1fr} }
.explore-card{
  background:#ffe1ef;border:1px solid var(--border);border-radius:18px;padding:16px;display:flex;flex-direction:column;justify-content:space-between;transition:.2s ease;min-height:160px
}
.explore-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.explore-card h4{font-size:20px;margin-bottom:6px}
.explore-card .links a{margin-right:10px;text-decoration:underline}
.explore-card .icon{font-size:36px;opacity:.25}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:900px){ .stats-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:540px){ .stats-grid{grid-template-columns:1fr} }
.stat-card{border:1px solid var(--border);border-radius:22px;padding:22px;text-align:center;background:#fff;box-shadow:var(--shadow)}
body.dark-mode .stat-card{background:#151a23}
.stat-yellow{background:#fff6bf}
.stat-blue{background:#cfeaff}
.stat-pink{background:#ffe3e8}
.stat-green{background:#ccffd6}
.stat-card .big{font-weight:800;font-size:26px}
.stat-card .small{color:var(--muted)}

.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:900px){ .testi-grid{grid-template-columns:1fr} }
.testimonial-card{background:#efeaff;border:1px solid var(--border);border-radius:18px;padding:16px}

.platforms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:900px){ .platforms-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:540px){ .platforms-grid{grid-template-columns:1fr} }
.platform-card{
  display:block;text-align:center;padding:20px;border-radius:16px;background:var(--primary-color);color:#fff;font-weight:800;
  box-shadow:0 12px 28px rgba(123,97,255,.32);transition:.2s ease;text-transform:capitalize
}
.platform-card:hover{transform:translateY(-3px)}
.love-strip{background:var(--primary-light);color:var(--text);text-align:center;padding:12px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-weight:800}

/* =========================================
   7) CARDS + GRIDS + COMMON
========================================= */
.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:980px){ .content-grid{grid-template-columns:1fr} }
.content-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);
  padding:16px;display:flex;flex-direction:column;gap:8px
}
.product-image{width:100%;background-size:cover;background-position:center;border-radius:12px}

/* Batches list */
.batch-tag{background:var(--primary-light);color:var(--primary-color);padding:4px 10px;border-radius:999px;font-weight:700;font-size:12px}
.batch-tag.premium{background:#e9e6ff;color:#7b61ff}

/* Store */
.store-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.search-wrap{position:relative}
.search-wrap input{padding:10px 34px 10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--bg-soft);color:var(--text)}
.search-wrap i{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--muted)}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.product-card{background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:12px;display:flex;flex-direction:column;gap:10px}
.product-info h3{font-size:16px}
.product-price{font-weight:800}

/* My Batches */
.my-batches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;min-height:300px}
.batch-card-pro{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.batch-card-pro-banner{height:170px;background-size:cover;background-position:center}
.batch-card-pro-content{padding:18px;display:flex;flex-direction:column;gap:8px}

/* =========================================
   8) AUTH MODAL (login/signup + QR modals reuse)
========================================= */
.auth-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:.25s ease;z-index:1990
}
.auth-overlay.is-visible{opacity:1;visibility:visible}
.auth-modal{
  position:fixed;left:50%;top:50%;transform:translate(-50%,-50%) scale(.96);opacity:0;visibility:hidden;
  width:92%;max-width:460px;background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);z-index:2000;
  transition:.25s ease;
}
.auth-modal.is-visible{transform:translate(-50%,-50%) scale(1);opacity:1;visibility:visible}
.close-modal{position:absolute;right:12px;top:10px;background:transparent;border:none;color:var(--muted);font-size:24px;cursor:pointer}
.modal-content{padding:20px;max-height:85vh;overflow:auto}
.tabs{display:flex;gap:16px;margin-bottom:14px;border-bottom:1px solid var(--border)}
.tab-link{padding:8px 0;border:none;background:transparent;font-weight:800;color:var(--muted);border-bottom:3px solid transparent;cursor:pointer}
.tab-link.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}
.form-group{display:grid;gap:6px;margin-bottom:12px}
.form-group input,.form-group select, .toolbar input{
  padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--bg-soft);color:var(--text)
}
.form-group input:focus,.form-group select:focus,.toolbar input:focus{outline:none;box-shadow:0 0 0 3px var(--ring)}

/* =========================================
   9) SECONDARY HEADER (JS-injected ribbon)
========================================= */
.sec-header{
  position:fixed;left:0;right:0;top:var(--sec-top);z-index:900;pointer-events:none;
  background:
    radial-gradient(60% 180% at 50% 0%, rgba(255,255,255,.7), rgba(255,255,255,.5) 60%, transparent 85%),
    linear-gradient(90deg, rgba(255,99,156,.18), rgba(255,210,92,.25), rgba(255,147,44,.18));
  border-bottom:1px solid rgba(0,0,0,.06);
}
.sec-header .inner{pointer-events:none;display:flex;justify-content:center;gap:10px;padding:8px 14px;font-weight:800}
.sec-header-spacer{height:var(--sec-height,0px)}

/* =========================================
   10) LEARNING PAGES (Classroom / Mentor / Resources / Tracker)
========================================= */
#classroom-root{max-width:1100px;margin:20px auto 60px;padding:0 24px}
#classroom-banner{width:100%;height:200px;object-fit:cover;border-radius:16px;background:var(--bg-soft);box-shadow:var(--shadow)}
#classroom-title{text-align:center;margin:14px 0 4px;font-size:28px;font-weight:800}
#classroom-desc{text-align:center;color:var(--muted);margin-bottom:14px}
#module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.module-card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:14px;display:flex;gap:12px;align-items:center}
.module-icon{width:46px;height:46px;border-radius:10px;background:var(--bg-soft);display:grid;place-items:center;color:var(--primary-color)}
.module-title{font-weight:800}
.module-desc{color:var(--muted);font-size:14px}

#mentor-root .mentor-wrap{max-width:1100px;margin:20px auto 60px;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:16px}
#mentor-root .mentor-card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:14px}
.mentor-head{display:grid;grid-template-columns:110px 1fr;gap:12px;align-items:center}
.mentor-photo{width:110px;height:110px;border-radius:10px;object-fit:cover;background:var(--bg-soft)}
.mentor-chip{background:var(--bg-soft);border:1px solid var(--border);padding:8px;border-radius:10px;display:inline-block}
.mentor-list{display:grid;gap:8px;margin-top:10px}
@media (max-width:900px){ #mentor-root .mentor-wrap{grid-template-columns:1fr} }

#resources-root .resources-wrap{max-width:1100px;margin:20px auto 60px;padding:0 24px}
.res-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.res-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow)}
.res-title{font-weight:800}

#tracker-root .tracker-wrap{max-width:1100px;margin:20px auto 60px;padding:0 24px}
.tracker-title{font-weight:800;margin-bottom:10px}
.tracker-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tracker-table{width:100%;min-width:700px;border:1px solid var(--border);border-radius:12px;border-collapse:separate;border-spacing:0;background:var(--card);box-shadow:var(--shadow)}
.tracker-table thead th{background:var(--bg-soft);text-align:left;padding:10px;border-bottom:1px solid var(--border)}
.tracker-table td{padding:10px;border-top:1px solid var(--border)}
.cell-counter{font-weight:800;cursor:pointer;user-select:none}
.cell-counter.small{font-weight:700}
.cell-check{width:22px;height:22px;border-radius:50%;border:2px solid #9aa5b1;display:inline-block;vertical-align:middle;cursor:pointer}
.cell-check.done{background:var(--success);border-color:var(--success);box-shadow:0 0 0 2px rgba(56,161,105,.15)}
.tracker-foot{text-align:center;margin-top:12px;font-weight:800}
@media (max-width:700px){ .tracker-table{min-width:680px} }

/* =========================================
   11) ADMIN DASHBOARD
========================================= */
.admin-body{min-height:100vh;position:relative}
.ambient-bg{
  position:fixed;inset:-20% -10% -10% -10%;z-index:-1;pointer-events:none;filter:blur(40px) saturate(1.05);
  background:
    radial-gradient(600px 600px at 10% 10%, rgba(123,97,255,.25), transparent 60%),
    radial-gradient(500px 500px at 90% 20%, rgba(255,92,92,.18), transparent 60%),
    radial-gradient(700px 700px at 50% 100%, rgba(255,210,92,.18), transparent 60%);
  animation:floatBG 16s ease-in-out infinite alternate;
}
@keyframes floatBG{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(0,-30px,0) scale(1.02)}
}

.admin-gate{display:grid;place-items:center;min-height:70vh;padding:22px}
.gate-card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:22px;max-width:560px;width:100%;text-align:center}
.gate-icon{font-size:36px;color:var(--primary-color);margin-bottom:10px}

.admin-bar{
  position:sticky;top:64px;z-index:5;background:var(--card);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:10px 24px
}
.admin-layout{display:grid;grid-template-columns:260px 1fr;gap:16px;max-width:1200px;margin:14px auto 60px;padding:0 16px}
.admin-sidebar{
  position:sticky;top:108px;align-self:start;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:12px;display:grid;gap:4px
}
.sb-title{font-weight:800;margin:4px 8px}
.sb-sep{height:1px;background:var(--border);margin:8px 0}
.sb-link{display:flex;gap:10px;align-items:center;padding:10px;border-radius:10px;color:var(--text)}
.sb-link:hover{background:var(--bg-soft)}

.admin-content{display:grid;gap:16px}
.content-card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:16px}
.content-card h3{display:flex;gap:10px;align-items:center;margin-bottom:8px}
.content-subcard{background:var(--bg-soft);border:1px solid var(--border);border-radius:12px;padding:12px}

.manage-list{display:grid;gap:10px;margin-top:10px}
.manage-item{display:grid;grid-template-columns:60px 1fr auto;gap:12px;align-items:center;border:1px solid var(--border);border-radius:10px;background:var(--card);padding:10px}
.manage-item img{width:60px;height:60px;border-radius:8px;object-fit:cover;background:var(--bg-soft)}
.manage-item .info .title{font-weight:800}
.manage-item .info .sub{margin-top:2px}
.manage-item .text{margin-top:4px}
.acts{display:flex;gap:6px}
.acts .sm{background:transparent;border:1px solid var(--border);color:var(--text);padding:6px 8px;border-radius:8px;cursor:pointer}
.acts .sm:hover{background:var(--bg-soft)}
.red{color:var(--danger)}

.toolbar{display:flex;gap:10px;margin-bottom:8px}

.code-area{
  width:100%;min-height:280px;border:1px solid var(--border);border-radius:12px;background:var(--bg-soft);color:var(--text);
  padding:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace
}
.qr-preview img,.qr-preview{width:180px;height:180px;border-radius:10px;object-fit:cover;border:1px solid var(--border)}

.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:10px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.w-2{grid-column:span 2}
.w-3{grid-column:span 3}
.end{justify-self:end}
.form-inline{display:flex;align-items:center;gap:8px}
.sep{border-top:1px dashed var(--border);padding-top:8px;margin-top:4px}

.admin-footer{border-top:1px solid var(--border);padding:14px;color:var(--muted)}

/* =========================================
   12) RESPONSIVE OVERRIDES
========================================= */
@media (max-width:992px){
  .explore-grid{grid-template-columns:1fr 1fr}
  .content-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .admin-layout{grid-template-columns:1fr}
  .my-batches-grid{grid-template-columns:1fr}
}
@media (max-width:768px){
  .search-wrap{width:100%}
  .hero-person{width:90%}
}
@media (prefers-reduced-motion: reduce){
  *{transition:none!important;animation:none!important}
  .reveal{opacity:1;transform:none}
}
/* === Store v2 (aesthetic) === */
.store-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.store-title{font-size:clamp(18px,3vw,28px);font-weight:800;margin:0}
.pill-row{display:flex;flex-wrap:wrap;gap:8px}
.pill{
  border:1px solid var(--border); background:var(--bg); color:var(--text); padding:8px 12px; border-radius:999px; cursor:pointer;
}
.pill.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 8px 18px rgba(123,97,255,.28)}

.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.product-card-pro{
  background:var(--card); border:1px solid var(--border); border-radius:16px; overflow:hidden; box-shadow:var(--shadow);
  display:flex; flex-direction:column; transition:.18s ease;
}
.product-card-pro:hover{transform:translateY(-2px)}

.pc-thumb{
  height: 200px; background-size:cover; background-position:center;
  position:relative;
}
.pc-badge{
  position:absolute; left:10px; top:10px; background:rgba(0,0,0,.6); color:#fff; border-radius:999px; padding:4px 10px; font-size:12px; font-weight:800;
}
.pc-body{display:grid;gap:6px;padding:12px}
.pc-title{font-weight:800}
.pc-stars{color:#f5b90a}
.pc-price{display:flex;gap:8px;align-items:baseline}
.pc-price .cur{font-weight:800}
.pc-price .old{text-decoration:line-through;color:var(--muted)}
.pc-cat{color:var(--muted);font-size:12px}
.pc-actions{margin-top:6px;display:flex;gap:8px}

/* skeletons */
.card-skel{
  background:var(--card);border:1px solid var(--border);border-radius:16px;padding:12px;display:grid;gap:10px
}
.skel-img{height:180px;border-radius:12px;background:linear-gradient(90deg, #e9e9ef 0%, #f3f3f8 40%, #e9e9ef 100%);background-size:200% 100%;animation:sh 1.2s linear infinite}
.skel-line{height:14px;border-radius:8px;background:linear-gradient(90deg, #e9e9ef 0%, #f3f3f8 40%, #e9e9ef 100%);background-size:200% 100%;animation:sh 1.2s linear infinite}
.skel-btn{height:36px;border-radius:10px;background:linear-gradient(90deg, #e9e9ef 0%, #f3f3f8 40%, #e9e9ef 100%);background-size:200% 100%;animation:sh 1.2s linear infinite}
@keyframes sh { to { background-position:-200% 0 } }

/* search input compatible */
.search-wrap{position:relative}
.search-wrap input{padding:10px 34px 10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--bg-soft);color:var(--text)}
.search-wrap i{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--muted)}