/* Inter font loaded non-blocking via seo_helper.php preconnect injection */

:root{
  /* ─────────────────────────────────────────────────────────────────
     REFINED DESIGN - Modern platform feel matching splash aesthetic
     Clean, bold, premium
     ───────────────────────────────────────────────────────────────── */

  /* Core Palette - Vibrant, matching splash */
  --bg:#ffffff;
  --card:#ffffff;
  --text:#0F172A;
  --muted:#64748B;
  --line:#E2E8F0;
  --accent:#5340FF;
  --btn:var(--accent);
  --btnText:#fff;

  /* Semantic Colors */
  --success:#00a884;
  --success-bg:#e7f8f3;
  --warning:#f7b928;
  --warning-bg:#fff9e6;
  --error:#e74c3c;
  --error-bg:#fef0ef;
  --info:#5340FF;
  --info-bg:#EEF2FF;

  /* Typography - Slightly larger, bolder */
  --text-xs: 10px;
  --text-sm: 12px;
  --text-base: 13px;
  --text-lg: 15px;
  --text-xl: 18px;
  --text-2xl: 21px;
  --text-3xl: 26px;

  /* Spacing */
  --s1: 4px; --s2: 6px; --s3: 10px; --s4: 14px; --s5: 18px; --s6: 24px; --s8: 32px;

  /* Shadows - More depth, closer to splash */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.05);
  --shadow: 0 2px 6px rgba(0,0,0,0.07);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.09);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.11);
  --shadow-xl: 0 12px 36px rgba(0,0,0,0.14);

  /* Border Radius - Rounder, friendlier */
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 18px;
  --radius-xl: 24px;
  --radius-full: 9999px;

  /* Transitions - Snappy */
  --transition-fast: 120ms ease;
  --transition: 180ms ease;
  --transition-slow: 250ms ease;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{background:transparent;scroll-behavior:smooth;overflow-x:hidden;}
html,body{max-width:100vw;overflow-x:hidden;overscroll-behavior-x:none;}
/* PWA safe-area: bottom padding for home-indicator on iOS standalone */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  body{padding-bottom:env(safe-area-inset-bottom);}
}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-text-size-adjust:100%;
  -webkit-tap-highlight-color:transparent;
  font-size:var(--text-base);
  line-height:1.45;
  position:relative;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
/* Prevent iOS zoom on input focus */
input,select,textarea{font-size:16px;}
/* PWA standalone mode — full native feel */
@media all and (display-mode:standalone){
  html{-webkit-user-select:none;user-select:none;}
  input,textarea,select,[contenteditable]{-webkit-user-select:text;user-select:text;}
  body{overscroll-behavior-y:contain;}
  .pwa-install-link{display:none !important;}
}
/* Bottom navigation bar — Instagram-style, iOS-safe */
:root{--bottom-nav-h:48px;}
.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:var(--bottom-nav-h);padding-bottom:env(safe-area-inset-bottom);border-top:.5px solid rgba(0,0,0,.15);z-index:9999;display:flex;justify-content:space-around;align-items:center;max-width:100vw;background:#fff;}
.bnav-item{display:flex;align-items:center;justify-content:center;min-width:0;flex:1;height:100%;text-decoration:none;color:#262626;-webkit-tap-highlight-color:transparent;transition:opacity .15s;position:relative;}
.bnav-item:active{opacity:.5;}
.bnav-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;position:relative;}
.bnav-icon svg{width:24px;height:24px;}
.bnav-o,.bnav-f{display:flex;align-items:center;justify-content:center;position:absolute;inset:0;}
.bnav-f{opacity:0;}
.bnav-item.is-active .bnav-o{opacity:0;}
.bnav-item.is-active .bnav-f{opacity:1;}
body.has-bottom-nav{padding-bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom));}
@media(min-width:768px){
  .bottom-nav{display:none !important;}
  body.has-bottom-nav{padding-bottom:0 !important;}
  .pwa-install-link{display:none !important;}
}
@media(prefers-color-scheme:dark){
  .bottom-nav{background:#000;border-top:.5px solid rgba(255,255,255,.15);}
  .bnav-item{color:#f5f5f5;}
}
/* Lock body scroll when modal/drawer is open */
body.modal-open{overflow:hidden;position:fixed;width:100%;height:100%;touch-action:none;}
/* Settings tabs */
.settings-tabs{display:flex;gap:0;border-bottom:2px solid var(--line);margin-bottom:var(--s6,24px);overflow-x:auto;-webkit-overflow-scrolling:touch;}
.settings-tab{padding:12px 20px;font-weight:700;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all 0.2s;}
.settings-tab:hover{color:var(--text);background:var(--bg-alt);}
.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent);}
@media(max-width:768px){.settings-tab{padding:10px 14px;font-size:14px;}}
/* Settings note text */
.settings-note{font-size:13px;color:var(--muted);margin-top:4px;word-wrap:break-word;overflow-wrap:break-word;max-width:100%;}

/* Typography - Refined, compact */
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.15;color:var(--text);margin:0 0 4px;letter-spacing:-0.01em;}
h1{font-size:var(--text-3xl);}
h2{font-size:var(--text-2xl);}
h3{font-size:var(--text-xl);}
h4{font-size:var(--text-lg);}
h5{font-size:var(--text-base);}
h6{font-size:var(--text-sm);}
p{margin:0 0 8px;}
a{color:var(--accent);text-decoration:none;transition:opacity var(--transition-fast);}
a:hover{opacity:0.8;}
body.landing-shell{min-height:100vh;background:#ffffff;position:relative;overflow-x:hidden;}
.landing-backdrop{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
/* Landing background - white by default, image only when explicitly set */
.landing-bg{position:absolute;inset:0;background-color:#ffffff;}
/* Overlay for contrast when background image is present */
.landing-overlay{position:absolute;inset:0;background:transparent;z-index:1;transition:background 0.3s;}
/* Override with custom image if set via inline style */
body.landing-shell-has-image .landing-bg{background-size:cover;background-position:center top;background-repeat:no-repeat;opacity:0.95;}
/* Only apply dark styling if we actually have an image (using [style*="background-image"] check as a proxy for the inline style set in PHP) */
body.landing-shell-has-image[style*="background-image"] .landing-overlay{background:rgba(2,6,23,0.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}

.landing-container{position:relative;z-index:100;padding:0 var(--s4);}
body.landing-shell .card{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);}
body.landing-shell .topbar{background:transparent;color:var(--text);padding:10px 0;padding-top:calc(10px + env(safe-area-inset-top));position:sticky;top:0;z-index:1000;}
body.landing-shell .topbar .brand{color:var(--text);font-size:16px;}
body.landing-shell .topbar .btn{font-size:11px;padding:6px 10px;border-radius:6px;}
body.landing-shell .topbar .btn.secondary{background:var(--card);color:var(--text);border:1px solid var(--line);}
body.landing-shell .topbar .btn.secondary:hover{background:var(--bg);border-color:var(--accent);color:var(--accent);}
/* When a background image IS set, use translucent cards and light text for topbar */
body.landing-shell-has-image[style*="background-image"]{background:#020617;}
body.landing-shell-has-image[style*="background-image"] .topbar{background:rgba(2,6,23,0.4);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;}
body.landing-shell-has-image[style*="background-image"] .topbar .brand{color:#fff;}
body.landing-shell-has-image[style*="background-image"] .topbar .topbar-menu a{color:rgba(255,255,255,0.8);}
body.landing-shell-has-image[style*="background-image"] .topbar .topbar-menu a:hover{color:#fff;}
body.landing-shell-has-image[style*="background-image"] .card{background:rgba(255,255,255,0.97);border:none;box-shadow:0 2px 8px rgba(2,6,23,0.12);backdrop-filter:blur(6px);}
body.landing-shell-has-image[style*="background-image"] .topbar .btn.secondary{background:rgba(15,23,42,0.85);color:#fff;border:none;}
body.landing-shell-has-image[style*="background-image"] .topbar .btn.secondary:hover{background:#0b1220;}
body.landing-shell-has-image[style*="background-image"] .landing-feed-head h3{color:#f8fafc;}
/* Landing hero card - simplified mobile-first */
.landing-hero-card{text-align:center;padding:16px 14px !important;max-width:400px;margin:0 auto;}
.landing-hero-title{font-size:18px;font-weight:800;margin:0 0 4px !important;color:var(--text);letter-spacing:-0.02em;}
.landing-hero-sub{font-size:12px;color:var(--muted);margin:0 0 12px;line-height:1.4;}
.landing-hero-search{display:flex;gap:6px;align-items:stretch;}
.landing-hero-search input{flex:1;min-width:0;font-size:13px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;}
.landing-hero-search input:focus{outline:none;border-color:var(--accent);}
.landing-hero-search .btn{padding:10px 16px;font-size:13px;font-weight:700;border-radius:var(--radius-sm);flex-shrink:0;}
.landing-hero-hint{font-size:10px;color:var(--muted);margin-top:8px;}
.landing-hero-hint strong{color:var(--text);}
.landing-stories-wrap{position:relative;z-index:25;width:100%;max-width:1600px;margin:var(--s5) auto 0;padding:0 var(--s4);box-sizing:border-box;}
@media(min-width:900px){.landing-stories-wrap{padding:0 calc(var(--s4) * 2);}}
.landing-stories-shell{position:relative;z-index:4;padding:var(--s4) 0;}
.landing-stories-fixed{position:sticky;top:clamp(12px,4vw,48px);padding:var(--s4);border-radius:var(--radius-xl);background:transparent;box-shadow:none;border:none;backdrop-filter:none;margin:0 auto var(--s4);z-index:30;}
.landing-stories-fixed .landing-stories{max-width:100%;padding:0;}
.landing-stories-fixed .landing-stories-head{color:var(--text);}
.landing-stories{position:relative;z-index:4;max-width:900px;margin:0 auto;padding:0 var(--s4);color:var(--text);}
.landing-stories-head{font-weight:700;font-size:12px;margin-bottom:var(--s3);color:var(--text);letter-spacing:0.01em;}
.landing-stories-strip{display:flex;gap:var(--s3);overflow-x:auto;padding-bottom:var(--s1);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.landing-stories-strip::-webkit-scrollbar{display:none;}
.landing-stories-empty{display:flex;align-items:center;justify-content:center;min-height:72px;flex:1;font-size:12px;color:var(--text);text-align:center;padding:0 var(--s4);}
.landing-story{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text);scroll-snap-align:start;min-width:77px;}
.landing-story-link{display:inline-flex;text-decoration:none;border-radius:50%;line-height:0;}
.landing-story-ring{width:70px;height:70px;border-radius:50%;padding:3px;background:linear-gradient(135deg,#667eea,#764ba2);display:inline-flex;align-items:center;justify-content:center;}
.landing-story-ring.story-ring-boost,.landing-story-ring.story-ring-deal{background:linear-gradient(135deg,#f59e0b,#ef4444,#ec4899);animation:pulse-ring 2s ease-in-out infinite;}
.landing-story-ring.story-ring-new{background:linear-gradient(135deg,#16a34a,#86efac);animation:pulse-ring-green 2s ease-in-out infinite;}
.landing-story-ring.story-ring-video{background:linear-gradient(135deg,#6366f1,#a855f7,#ec4899);animation:pulse-ring-video 2s ease-in-out infinite;}
.landing-story-ring.story-ring-live{background:linear-gradient(135deg,#ff0000,#ff4d4d,#ff0000);animation:pulse-ring-live 1.5s ease-in-out infinite;border: 1px solid rgba(255,0,0,0.5);}
@keyframes pulse-ring{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,0.4);}50%{box-shadow:0 0 0 6px rgba(245,158,11,0);}}
@keyframes pulse-ring-green{0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,0.35);}50%{box-shadow:0 0 0 6px rgba(22,163,74,0);}}
@keyframes pulse-ring-video{0%,100%{box-shadow:0 0 0 0 rgba(99,102,241,0.4);}50%{box-shadow:0 0 0 6px rgba(99,102,241,0);}}
@keyframes pulse-ring-live{0%,100%{box-shadow:0 0 0 0 rgba(255,0,0,0.6);}50%{box-shadow:0 0 0 8px rgba(255,0,0,0);}}
.landing-story-ring img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid #fff;background:#fff;display:block;image-rendering:auto;}
.landing-story-name{font-size:11px;text-align:center;color:var(--text);max-width:77px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.landing-story-sentinel{width:20px;min-width:20px;height:100%;min-height:60px;display:block;flex-shrink:0;}

.story-video-modal{position:fixed;inset:0;background:rgba(0,0,0,0.95);display:flex;align-items:center;justify-content:center;z-index:1200;opacity:0;pointer-events:none;transition:opacity .2s ease;}
.story-video-modal.is-open{opacity:1;pointer-events:auto;}
.story-video-backdrop{position:absolute;inset:0;}
.story-video-content{position:relative;background:transparent;width:100vw;height:100vh;max-width:500px;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;border-radius:16px;}
.story-video-content video{width:100%;height:100%;object-fit:cover;display:block;border-radius:16px;}
.story-video-close{position:absolute;top:calc(20px + env(safe-area-inset-top));right:calc(20px + env(safe-area-inset-right));width:40px;height:40px;border:none;border-radius:50%;background:rgba(0,0,0,0.3);color:#fff;font-size:24px;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);}
.story-video-shop{position:absolute;bottom:calc(40px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);display:inline-flex;align-items:center;justify-content:center;padding:12px 32px;border-radius:999px;background:#fff;color:#000;font-weight:700;text-decoration:none;min-width:180px;z-index:10;box-shadow:0 10px 30px rgba(0,0,0,0.3);font-size:14px;}
.story-video-shop:hover{background:#f0f0f0;transform:translateX(-50%) scale(1.05);}

.landing-feed{
  display:block;
  position:relative;
  z-index:2;
  width:100%;
  max-width:900px;
  margin:12px auto 0;
  padding:0 var(--s4) 16px;
  box-sizing:border-box;
}
@media(min-width:900px){
  .landing-feed{
    max-width:1200px;
    margin:12px auto 0;
    padding:0 calc(var(--s4) * 2) 20px;
  }
}
@media(min-width:1300px){
  .landing-feed{max-width:1400px;}
}
@media(min-width:1600px){
  .landing-feed{max-width:1600px;}
}
.landing-feed-head h3{margin:0 0 6px 0;font-size:13px;font-weight:600;color:var(--text);}
body.landing-shell-has-image .landing-feed-head h3{color:#f8fafc;}
.landing-feed-list{display:flex;flex-direction:column;gap:var(--s3);}
.landing-feed-item.discovery-cluster{padding:var(--s3);display:flex;flex-direction:column;gap:var(--s2);border:1px solid rgba(15,23,42,0.08);background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);position:relative;}
.cluster-pill{position:absolute;top:var(--s2);right:var(--s2);font-size:10px;font-weight:600;background:rgba(15,23,42,0.9);color:#fff;padding:2px 8px;border-radius:999px;letter-spacing:0.05em;text-transform:uppercase;}
.cluster-head{display:flex;justify-content:space-between;align-items:center;gap:var(--s2);padding-left:7px;}
.cluster-title{font-size:var(--text-base);font-weight:700;color:var(--text);}
.cluster-subtitle{font-size:var(--text-xs);color:var(--muted);text-transform:uppercase;letter-spacing:0.04em;}
.cluster-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:120px;gap:4px;}
.cluster-tile{display:flex;flex-direction:column;border-radius:12px;text-decoration:none;color:inherit;min-width:0;min-height:0;height:100%;position:relative;overflow:hidden;}
.cluster-tile{transform:translateZ(0);}
.cluster-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.cluster-thumb{flex:1;min-height:0;border-radius:12px;overflow:hidden;background:#e2e8f0;position:relative;display:flex;align-items:center;justify-content:center;}
.cluster-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center center;display:block;}
.cluster-thumb-fallback{font-size:18px;font-weight:600;color:#475569;z-index:1;}
.cluster-thumb-badge{position:absolute;top:4px;left:4px;background:rgba(15,23,42,0.9);color:#fff;font-size:8px;font-weight:700;padding:2px 5px;border-radius:999px;text-transform:uppercase;letter-spacing:0.06em;}
.cluster-thumb-badge.live{background:#dc2626;}
.cluster-thumb-meta{position:absolute;bottom:4px;right:4px;background:rgba(15,23,42,0.95);color:#fff;font-size:9px;font-weight:600;padding:2px 5px;border-radius:6px;letter-spacing:0.03em;}
.landing-feed-item{display:block;padding:0;text-decoration:none;color:inherit;border-radius:var(--radius);overflow:hidden;break-inside:avoid;}
.feed-card-head{display:flex;align-items:center;gap:var(--s3);padding:6px 8px 4px;}
.feed-card-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#cfd9df,#e2ebf0);display:inline-flex;align-items:center;justify-content:center;font-weight:600;color:#475569;flex-shrink:0;}
.feed-card-avatar img{width:100%;height:100%;object-fit:cover;display:block;}
.feed-card-avatar-fallback{font-size:11px;text-transform:uppercase;color:var(--text);}
.feed-card-tenant{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0;}
.feed-card-tenant-name{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.feed-card-tenant-sub{font-size:10px;color:rgba(15,23,42,0.6);}
.feed-card-media{margin:0;}
.feed-card-media .feed-img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#f8fafc;}
.feed-img-placeholder{background:linear-gradient(135deg,#e2e8f0,#cbd5f5);color:#475569;font-size:18px;font-weight:600;display:flex;align-items:center;justify-content:center;text-transform:uppercase;}
.feed-card-body{padding:4px 8px 6px;border-top:none;display:flex;flex-direction:column;gap:2px;}
/* Follow button in card header */
.feed-follow-btn{display:inline-flex;align-items:center;gap:2px;padding:3px 8px;font-size:10px;font-weight:600;background:transparent;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;color:#64748b;transition:all .15s;flex-shrink:0;margin-left:auto;}
.feed-follow-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#334155;}
.feed-follow-btn:active{transform:scale(0.96);}
.feed-follow-btn.following{background:var(--accent);border-color:var(--accent);color:#fff;}
.feed-follow-btn.following:hover{background:#16a34a;border-color:#16a34a;}
.feed-follow-btn svg{width:10px;height:10px;flex-shrink:0;}

/* Feed card: full-bleed media */
.card.landing-feed-item{padding:0;border:none;overflow:hidden;border-radius:var(--radius);}
.card.landing-feed-item.discovery-cluster{padding:var(--s3);}
.card.landing-feed-item .feed-card-media{margin:0;}
.card.landing-feed-item .feed-card-media .feed-img{display:block;width:100%;}

/* Masonry feed container */

.feed-card-row{display:flex;align-items:center;gap:6px;margin-top:4px;}
.feed-card-title{flex:1;min-width:0;font-size:13px;font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.feed-card-price{display:flex;flex-direction:column;align-items:flex-end;gap:2px;white-space:nowrap;flex-shrink:0;}
.feed-price-sale{color:#fb6304;font-size:15px;font-weight:700;}
.feed-price-original{color:var(--muted);font-size:12px;text-decoration:line-through;}
.feed-price-regular{color:var(--accent);font-size:15px;font-weight:700;}
.feed-card-badge{display:inline-block;font-size:9px;padding:2px 5px;margin-bottom:2px;}
.landing-feed-sentinel{display:block;width:1px;height:1px;}
.boost-ring{box-shadow:0 0 0 3px #f59e0b, 0 0 20px rgba(245,158,11,0.7);animation:boost-ring-glow 2s ease-in-out infinite;}
@keyframes boost-ring-glow{0%,100%{box-shadow:0 0 0 3px #f59e0b, 0 0 15px rgba(245,158,11,0.6);}50%{box-shadow:0 0 0 5px #f59e0b, 0 0 30px rgba(245,158,11,0.9);}}
.landing-feed-item.boosted-card{box-shadow:none;animation:none;}

/* Feed card link and actions */
.feed-card-link{display:block;text-decoration:none;color:inherit;}
.feed-card-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;}
.feed-action-btn{display:inline-flex;align-items:center;gap:3px;background:none;border:none;padding:2px;cursor:pointer;color:var(--muted);transition:color .15s,transform .1s;font-size:11px;font-weight:500;}
.feed-action-btn:hover{color:var(--text);}
.feed-action-btn:active{transform:scale(0.95);}
.feed-action-icon{width:16px;height:16px;flex-shrink:0;}
.feed-like-btn{color:#ef4444;}
.feed-like-btn .feed-action-icon{stroke:#ef4444;fill:none;}
.feed-like-btn.liked .feed-action-icon{fill:#ef4444;}
.feed-like-count{min-width:10px;}
@keyframes like-pop{0%{transform:scale(1);}50%{transform:scale(1.2);}100%{transform:scale(1);}}
.feed-like-btn.animate .feed-action-icon{animation:like-pop .3s ease-out;}
.product-enhanced-body .sp-row{color:var(--text);}
.product-enhanced-body .sp-badge{color:inherit;opacity:0.95;}
.product-enhanced-body .sp-avi{border-color:var(--card);background:var(--line);}
.landing-feed-item .sp-row{color:var(--text);}
.landing-feed-item .sp-badge{color:inherit;opacity:0.95;}
.landing-feed-item .sp-avi{border-color:var(--card);background:var(--line);}
.df-card .sp-row{color:var(--text);}
.df-card .sp-badge{color:inherit;opacity:0.95;}
.df-card .sp-avi{border-color:var(--card);background:var(--line);}

/* Live Stream Card - TikTok style vertical (9:16 aspect ratio) */
.live-card{position:relative;border:2px solid #dc2626 !important;overflow:hidden;padding:0 !important;}
.live-card .live-video-link{display:block;text-decoration:none;color:inherit;}
/* Live media - TikTok vertical aspect ratio */
.live-media{position:relative;aspect-ratio:9/16;background:#000;overflow:hidden;}
/* Live thumbnail image - static image on home feed cards (no live video) */
.live-thumbnail-img{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;}
.live-thumbnail-img .feed-img,.live-thumbnail-img img{width:100%;height:100%;object-fit:cover;display:block;}
/* Live video preview container - fills the media area (used on live viewer page, not home feed) */
.live-video-preview{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;}
.live-video-preview video,.live-video-preview div[id*="agora"]{width:100% !important;height:100% !important;object-fit:cover;}
/* Fallback image - shown until video loads */
.live-fallback-img{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;}
.live-fallback-img .feed-img,.live-fallback-img img{width:100%;height:100%;object-fit:cover;display:block;}
.live-stream-img{width:100%;height:100%;object-fit:cover;display:block;}
.live-placeholder{background:linear-gradient(135deg,#1a1a1a,#333);color:#fff;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;}
/* Transparent overlay header at top of video */
.live-overlay-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:8px;padding:10px 12px;background:linear-gradient(to bottom,rgba(0,0,0,0.7) 0%,transparent 100%);z-index:2;}
.live-overlay-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#333;}
.live-overlay-avatar img{width:100%;height:100%;object-fit:cover;}
.live-overlay-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;background:#555;}
.live-overlay-name{flex:1;font-size:13px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,0.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.live-overlay-follow{background:transparent;border:1px solid #fff;color:#fff;font-size:11px;font-weight:600;padding:4px 12px;border-radius:4px;cursor:pointer;transition:all .15s;flex-shrink:0;}
.live-overlay-follow:hover{background:rgba(255,255,255,0.2);}
.live-overlay-follow.following{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.5);}
.live-viewers{position:absolute;bottom:44px;right:8px;background:rgba(0,0,0,0.7);color:#fff;font-size:10px;font-weight:500;padding:3px 8px;border-radius:4px;z-index:3;}
/* Bottom action bar - transparent overlay at bottom of video */
.live-action-bar{position:absolute;bottom:0;left:0;right:0;display:flex !important;flex-direction:row !important;align-items:center;gap:12px;padding:10px 12px;background:linear-gradient(to top,rgba(0,0,0,0.7) 0%,transparent 100%);z-index:2;}
.live-badge-inline{background:#dc2626;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px;animation:live-pulse 2s infinite;flex-shrink:0;}
@keyframes live-pulse{0%,100%{opacity:1;}50%{opacity:0.8;}}
@keyframes pulse-live{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,0.6);}50%{box-shadow:0 0 0 6px rgba(220,38,38,0);}}
.live-action-btn{background:transparent;border:none;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;gap:4px;padding:4px;color:#fff;transition:transform .15s;flex-shrink:0;text-shadow:0 1px 2px rgba(0,0,0,0.5);}
.live-action-btn:hover{transform:scale(1.1);}
.live-action-btn svg{stroke:#fff;}
.live-action-bar .live-heart-count{font-size:12px;color:#fff;}
.live-shop-link{margin-left:auto;color:#fff;font-size:13px;font-weight:700;text-decoration:none;transition:opacity .15s;flex-shrink:0;text-shadow:0 1px 2px rgba(0,0,0,0.5);}
.live-shop-link:hover{opacity:0.8;}
/* Legacy styles for compatibility */
.live-title{color:#dc2626;font-weight:700;}
.feed-card-shop-btn{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:5px 14px;border-radius:var(--radius-sm);text-decoration:none;flex-shrink:0;transition:all .15s;}
.feed-card-shop-btn:hover{opacity:0.9;transform:translateY(-1px);}
.feed-live-heart-btn{color:#f87171;transition:transform .15s;}
.feed-live-heart-btn .feed-action-icon{stroke:#ef4444;fill:none;transition:fill .15s,transform .15s;}
.feed-live-heart-btn:hover .feed-action-icon{fill:#fca5a5;}
.feed-live-heart-btn:active .feed-action-icon{fill:#ef4444;transform:scale(1.3);}
.live-heart-count{min-width:10px;font-size:11px;}
@keyframes heart-float{0%{opacity:1;transform:translateY(0) scale(1);}100%{opacity:0;transform:translateY(-40px) scale(0.6);}}
.live-heart-anim{position:absolute;bottom:40px;right:20px;font-size:20px;pointer-events:none;animation:heart-float 1.2s ease-out forwards;}

/* Scheduled Stream Card - TikTok style vertical (9:16 aspect ratio) */
.scheduled-card{position:relative;border:2px solid #6366f1 !important;overflow:hidden;padding:0 !important;}
.scheduled-card .live-video-link{display:block;text-decoration:none;color:inherit;}
/* Scheduled media - TikTok vertical aspect ratio */
.scheduled-media{position:relative;aspect-ratio:9/16;background:#1a1a2e;overflow:hidden;}
.scheduled-thumbnail{position:absolute;top:0;left:0;right:0;bottom:0;}
.scheduled-thumbnail .feed-img,.scheduled-thumbnail img{width:100%;height:100%;object-fit:cover;display:block;}
.scheduled-img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(0.85);}
.scheduled-placeholder{background:linear-gradient(135deg,#1a1a2e,#4338ca);color:#fff;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;}
.scheduled-action-bar{background:linear-gradient(to top,rgba(99,102,241,0.9) 0%,rgba(99,102,241,0.6) 50%,transparent 100%) !important;}
.scheduled-badge{background:#6366f1;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px;flex-shrink:0;white-space:nowrap;}

/* Wishlist grid - horizontal scrollable with small items */
.wishlist-grid{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.wishlist-grid::-webkit-scrollbar{height:4px;}
.wishlist-grid::-webkit-scrollbar-track{background:#f1f5f9;border-radius:2px;}
.wishlist-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px;}
.wishlist-item{display:flex;flex-direction:column;text-decoration:none;color:inherit;border-radius:6px;overflow:hidden;background:var(--card);border:1px solid var(--line);transition:box-shadow .15s;flex-shrink:0;width:90px;scroll-snap-align:start;}
.wishlist-item:hover{box-shadow:0 2px 8px rgba(0,0,0,.08);}
.wishlist-img-wrap{aspect-ratio:1;background:#f1f5f9;overflow:hidden;display:flex;align-items:center;justify-content:center;width:90px;height:90px;}
.wishlist-img-wrap img{width:100%;height:100%;object-fit:cover;}
.wishlist-placeholder{font-size:18px;font-weight:600;color:#94a3b8;}
.wishlist-info{padding:4px 6px;}
.wishlist-name{font-size:10px;font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wishlist-meta{display:flex;align-items:center;gap:4px;margin-top:2px;font-size:9px;color:#64748b;}
.wishlist-price{font-weight:600;color:var(--accent);}
.wishlist-store{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ─────────────────────────────────────────────────────────────────
   OPTION CARDS - Compact selection
   ───────────────────────────────────────────────────────────────── */
.option-list{display:grid;grid-template-columns:1fr;gap:6px;}
.option-card{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--card);
  cursor:pointer;
  transition:border-color 0.1s ease;
}
.option-card:hover{border-color:var(--muted);}
.option-card:has(input:checked),
.option-card.is-selected{
  border-color:var(--accent);
  background:rgba(0,132,255,0.02);
}
.option-card input[type="radio"],.option-card input[type="checkbox"]{
  flex-shrink:0;
  width:16px;height:16px;
  accent-color:var(--accent);
}
.option-card > div{flex:1;min-width:0;}
.option-title{
  font-size:13px;
  font-weight:500;
  color:var(--text);
  line-height:1.3;
  display:flex;
  align-items:baseline;
  gap:6px;
}
.option-title .small{font-weight:500;color:var(--success);font-size:11px;}
.option-card > div > .small{font-size:11px;color:var(--muted);margin-top:1px;}
.option-card.option-disabled{opacity:0.5;cursor:not-allowed;}
.delivery-extra{margin-top:8px;}

@media(max-width:640px){
  .option-card{padding:8px 10px;gap:8px;}
  .option-card input[type="radio"],.option-card input[type="checkbox"]{width:14px;height:14px;}
  .option-title{font-size:12px;gap:4px;}
  .option-card .option-title .small{font-size:10px;}
  .option-card > div > .small{font-size:10px;}
  .landing-feed{max-width:none;width:100vw;padding-left:0;padding-right:0;margin-left:0;margin-right:0;padding-bottom:16px;}
  .landing-feed-head h3{padding-left:var(--s4);padding-right:var(--s4);}
  .landing-feed-item{border-radius:0;}
  .feed-card-head{padding:4px 8px 2px;}
  .feed-card-body{padding:2px 8px 4px;}
}
.brand{font-size:16px;}
/* ─────────────────────────────────────────────────────────────────
   ORDER PAGE - Compact, sleek
   ───────────────────────────────────────────────────────────────── */
.order-topbar-actions{display:flex;gap:4px;flex-wrap:wrap;align-items:center;}
.order-topbar-actions .btn{font-size:11px;padding:6px 10px;border-radius:6px;}
.order-topbar-actions .btn.secondary{background:rgba(0,0,0,0.04);border:none;color:var(--text);}
.order-topbar-actions .btn.secondary:hover{background:rgba(0,0,0,0.07);}
.order-store-links{display:flex;align-items:center;gap:8px;margin-right:6px;flex-wrap:wrap;}
.order-store-link{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s cubic-bezier(0.4, 0, 0.2, 1);box-shadow:0 2px 5px rgba(0,0,0,0.1);background:#666;border:none;}
.order-store-link svg{width:14px;height:14px;fill:currentColor;display:block;}
.order-store-link img{width:14px;height:14px;object-fit:contain;display:block;}
.order-store-link:hover{transform:translateY(-2px) scale(1.1);box-shadow:0 5px 12px rgba(0,0,0,0.15);}

/* Brand Colors (Default State) */
.order-store-link[data-brand="instagram"]{background:linear-gradient(45deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);}
.order-store-link[data-brand="facebook"]{background:#1877f2;}
.order-store-link[data-brand="tiktok"]{background:#000;}
.order-store-link[data-brand="youtube"]{background:#ff0000;}
.order-store-link[data-brand="twitter"]{background:#1da1f2;}
.order-store-link[data-brand="whatsapp"]{background:#25d366;}
.order-store-link[data-brand="threads"]{background:#000;}
.order-store-link[data-brand="pinterest"]{background:#e60023;}
.order-store-link[data-brand="snapchat"]{background:#fffc00; color:#000;}
.order-store-link[data-brand="linktree"]{background:#43e660; color:#000;}
.order-store-link[data-brand="etsy"]{background:#f37121;}
.order-store-link[data-brand="website"]{background:var(--accent);}
.order-store-link[data-brand="link"]{background:#6366f1;}
.order-icon-cluster{display:flex;gap:6px;align-items:center;margin-left:4px;}
.order-icon-circle{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(15,23,42,0.15);background:var(--card-bg,#fff);color:var(--text,#0f172a);box-shadow:0 4px 10px rgba(15,23,42,0.08);text-decoration:none;transition:background .2s ease,transform .2s ease,color .2s ease;}
.order-icon-circle:hover{background:rgba(15,23,42,0.05);transform:translateY(-1px);}
.order-icon-circle svg{width:12px;height:12px;display:block;}
.order-icon-circle-call{width:29px;height:29px;background:var(--card-bg,#fff);color:var(--text,#0f172a);border-color:rgba(15,23,42,0.15);box-shadow:0 4px 10px rgba(15,23,42,0.08);}
.order-icon-circle-call:hover{background:rgba(15,23,42,0.05);color:var(--text,#0f172a);}
.order-icon-circle-map{width:29px;height:29px;}
.order-icon-circle-map svg{width:15px;height:15px;}

/* Store profile header */
.store-meta-row{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
  margin:4px auto 10px;
  flex-wrap:wrap;
  text-align:center;
}
.store-name-row{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:8px;
  flex-wrap:wrap;
  margin:8px auto 6px;
}
.store-name-heading{
  font-size:20px;
  font-weight:700;
  color:var(--text);
}
.store-followers{
  display:flex;
  flex-direction:column;
  gap:0;
  align-items:center;
  padding:4px 10px;
  background:rgba(0,0,0,0.03);
  border-radius:6px;
}
.store-followers-count{font-size:14px;font-weight:600;color:var(--text);}
.store-followers .small{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:0.3px;}
.store-meta-row .sp-row{color:var(--text);}
.store-meta-row .sp-badge{color:inherit;opacity:0.95;}
.store-meta-row .sp-avi{border-color:var(--card);background:var(--line);}
.store-verified{
  display:inline-flex;
  align-items:center;
  gap:3px;
  padding:3px 8px;
  background:#e8f8f3;
  border-radius:4px;
  font-size:10px;
  font-weight:500;
  color:#059669;
}
.verified-badge{width:12px;height:12px;display:inline-flex;align-items:center;justify-content:center;}
.verified-badge img,.verified-badge svg{width:12px;height:12px;display:block;}

.profile-card{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start;}
.profile-avatar-wrap{display:flex;flex-direction:column;gap:10px;align-items:center;min-width:200px;}
.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid rgba(0,0,0,0.08);box-shadow:0 10px 24px rgba(15,23,42,0.2);}
.profile-avatar-placeholder{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 12px 28px rgba(79,70,229,0.35);}
.profile-avatar-form{width:100%;text-align:center;font-size:14px;}
.profile-avatar-form input[type=file]{width:100%;}
.profile-details{flex:1;min-width:240px;}
.profile-accordion{border:1px solid rgba(15,23,42,0.08);border-radius:10px;background:rgba(248,250,252,0.8);overflow:hidden;display:block;}
.profile-accordion summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;cursor:pointer;user-select:none;}
.profile-accordion summary::-webkit-details-marker{display:none;}
.profile-accordion-head{display:flex;flex-direction:column;gap:2px;min-width:0;}
.profile-accordion-title{font-size:13px;font-weight:600;color:var(--text);}
.profile-accordion-sub{font-size:11px;color:rgba(15,23,42,0.65);}
.profile-accordion-icon{display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:999px;background:rgba(15,23,42,0.08);opacity:0.7;transition:transform .2s ease,opacity .2s ease;}
.profile-accordion[open] .profile-accordion-icon{transform:rotate(180deg);opacity:1;}
.profile-accordion-body{padding:12px 14px 16px;}

.profile-form .field{margin-bottom:10px;}
/* Follow grid - horizontal scrollable 2-column layout */
.follow-grid{display:grid;grid-template-rows:repeat(2,auto);grid-auto-flow:column;grid-auto-columns:140px;gap:8px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;margin-top:8px;}
.follow-grid::-webkit-scrollbar{height:4px;}
.follow-grid::-webkit-scrollbar-track{background:#f1f5f9;border-radius:2px;}
.follow-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px;}
.follow-card-item{border:1px solid rgba(0,0,0,0.08);border-radius:8px;padding:8px;background:rgba(255,255,255,0.95);box-shadow:0 2px 8px rgba(15,23,42,0.06);scroll-snap-align:start;display:flex;flex-direction:column;gap:6px;}
.follow-card-item .follow-card-header{display:flex;gap:8px;align-items:center;}
.follow-card-item .landing-story-ring{width:36px !important;height:36px !important;flex-shrink:0;}
.follow-card-item .landing-story-ring img{border-width:1px !important;}
.follow-card-item .follow-card-name{font-size:11px;font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.follow-card-item .follow-card-slug{font-size:9px;opacity:0.6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.follow-card-item .actions{display:flex;gap:4px;flex-wrap:nowrap;margin-top:auto;}
.follow-card-item .actions .btn{font-size:10px;padding:4px 8px;}
/* Order page topbar */
.order-topbar{align-items:center;position:static;background:transparent;box-shadow:none;padding:8px 0;}
.order-back-btn{position:fixed;top:calc(14px + env(safe-area-inset-top));left:calc(14px + env(safe-area-inset-left));z-index:1000;width:38px;height:38px;border-radius:50%;background:rgba(15,23,42,0.55);display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;opacity:0.5;box-shadow:0 6px 18px rgba(15,23,42,0.3);backdrop-filter:blur(6px);transition:opacity .2s ease,transform .2s ease;}
.order-back-btn:hover{opacity:0.85;transform:translateY(-1px);}
.order-back-btn svg{width:18px;height:18px;stroke:#fff;}

.order-topbar-spacer{flex:1;}

/* Store hero - compact */
.order-tenant-hero{
  display:flex;
  flex-direction:column;
  align-items:center;
  margin:0 auto 4px;
  padding-top:calc(14px + env(safe-area-inset-top));
  position:relative;
  z-index:2;
}
.order-tenant-photo{
  width:70px;height:70px;
  border-radius:50%;
  padding:3px;
  background:linear-gradient(135deg,#667eea,#764ba2);
  display:flex;
  align-items:center;
  justify-content:center;
}
.order-tenant-photo img{
  width:100%;height:100%;
  border-radius:50%;
  object-fit:cover;
  border:2px solid #fff;
}
body.order-has-logo .topbar{flex-direction:column;align-items:center;gap:4px;text-align:center;}
body.order-has-logo .topbar .brand{font-size:15px;font-weight:600;}

/* Free tier promo button */
/* Product search - compact */
#productSearch{
  background:var(--bg);
  border:none;
  border-radius:8px;
  padding:9px 12px 9px 34px;
  font-size:13px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:10px center;
}
#productSearch:focus{
  background-color:#fff;
  box-shadow:0 1px 4px rgba(0,0,0,0.06);
}

/* Form fields - tighter */
#orderForm .field{padding:4px 0;}
#orderForm .field + .field{margin-top:4px;}

/* Order confirmation hint */
#orderForm > .small:last-child{
  text-align:center;
  color:var(--muted);
  font-size:11px;
  padding:6px 0;
}

/* ─────────────────────────────────────────────────────────────────
   LAYOUT - Compact, chat-app density
   ───────────────────────────────────────────────────────────────── */
.small{color:var(--muted);font-size:var(--text-xs);}
.container{
  max-width:900px;
  margin:0 auto;
  padding:10px;
  padding-left:calc(10px + env(safe-area-inset-left));
  padding-right:calc(10px + env(safe-area-inset-right));
}
@media(min-width:640px){.container{padding:14px;padding-left:calc(14px + env(safe-area-inset-left));padding-right:calc(14px + env(safe-area-inset-right));}}

/* ─────────────────────────────────────────────────────────────────
   TOPBAR & NAVIGATION - Clean, refined
   ───────────────────────────────────────────────────────────────── */
.topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 0;
  padding-top:calc(12px + env(safe-area-inset-top));
  gap:10px;
  position:sticky;
  top:0;
  background:var(--bg);
  z-index:200;
}
.topbar.order-topbar{position:static;z-index:1;background:transparent;box-shadow:none;}
.topbar .brand{flex:1 1 auto;}
.brand{font-weight:800;font-size:16px;letter-spacing:-0.02em;color:var(--text);}
.brand-inline{display:flex;align-items:center;gap:6px;}
.brand-logo{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--line);background:#fff;}
.brand-name{display:inline-block;vertical-align:middle;}
.brand-link{display:inline-flex;align-items:center;text-decoration:none;color:inherit;}
.brand-link .brand{margin:0;}

/* Navigation container */
.topbar-nav{display:flex;align-items:center;gap:6px;margin-left:auto;position:relative;z-index:210;}

/* Hamburger toggle - hidden on desktop, shown on mobile */
.topbar-menu-toggle{
  display:none !important;
  align-items:center;
  justify-content:center;
  width:40px;height:40px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--card);
  color:var(--text);
  cursor:pointer;
  transition:background var(--transition-fast),border-color var(--transition-fast);
  padding:0;
}
.topbar-menu-toggle:hover{background:var(--bg);border-color:var(--muted);}
.topbar-menu-toggle:focus{outline:none;border-color:var(--accent);}

/* Hamburger icon lines */
.topbar-menu-toggle .menu-icon{
  display:block;
  width:18px;height:2px;
  background:var(--text);
  position:relative;
  border-radius:1px;
  transition:background var(--transition-fast);
}
.topbar-menu-toggle .menu-icon::before,
.topbar-menu-toggle .menu-icon::after{
  content:'';position:absolute;left:0;
  width:18px;height:2px;
  background:var(--text);
  border-radius:1px;
  transition:transform var(--transition);
}
.topbar-menu-toggle .menu-icon::before{top:-6px;}
.topbar-menu-toggle .menu-icon::after{top:6px;}

/* Hide "Menu" text - only show icon */
.topbar-menu-toggle .menu-text{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

/* X animation when open */
.topbar-nav.is-open .topbar-menu-toggle .menu-icon{background:transparent;}
.topbar-nav.is-open .topbar-menu-toggle .menu-icon::before{transform:rotate(45deg) translate(4px,4px);}
.topbar-nav.is-open .topbar-menu-toggle .menu-icon::after{transform:rotate(-45deg) translate(4px,-4px);}

/* Desktop menu - horizontal pills */
.topbar-menu{
  display:flex;
  gap:4px;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center;
  position:relative;
  z-index:220;
}
.topbar-menu a,.topbar-menu .btn{
  display:inline-flex;
  align-items:center;
  padding:7px 12px;
  font-size:12px;
  font-weight:500;
  color:var(--muted);
  background:transparent;
  border:1px solid transparent;
  border-radius:8px;
  white-space:nowrap;
  text-decoration:none;
  transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast);
}
.topbar-menu a:hover,.topbar-menu a.active,
.topbar-menu .btn:hover,.topbar-menu .btn.active{
  color:var(--text);
  background:var(--card);
  border-color:var(--line);
}
/* Override .btn.secondary styles in menu */
.topbar-menu .btn.secondary{
  background:transparent;
  border-color:transparent;
  color:var(--muted);
  box-shadow:none;
}
.topbar-menu .btn.secondary:hover{
  background:var(--card);
  border-color:var(--line);
  color:var(--text);
}

/* Mobile: show hamburger, hide menu until open */
@media(max-width:900px){
  .topbar-menu-toggle{display:flex !important;}
  .topbar-menu{
    display:none;
    flex-direction:column;
    position:absolute;
    right:0;top:calc(100% + 8px);
    background:var(--card);
    padding:8px;
    border:1px solid var(--line);
    border-radius:12px;
    box-shadow:0 8px 24px rgba(0,0,0,0.12);
    min-width:200px;
    max-height:70vh;
    overflow-y:auto;
    z-index:10001;
  }
  .topbar-nav{z-index:10001;}
  .topbar-menu a,.topbar-menu .btn,.topbar-menu .btn.secondary{
    padding:12px 14px;
    font-size:13px;
    border-radius:8px;
    width:100%;
    justify-content:flex-start;
    border:none;
    background:transparent;
    color:var(--text);
  }
  .topbar-menu a:hover,.topbar-menu .btn:hover,.topbar-menu .btn.secondary:hover{
    background:rgba(0,0,0,0.04);
  }
  .topbar-nav.is-open .topbar-menu{
    display:flex;
    animation:menuSlideIn var(--transition) ease-out;
  }
}
@keyframes menuSlideIn{
  from{opacity:0;transform:translateY(-8px) scale(0.96);}
  to{opacity:1;transform:translateY(0) scale(1);}
}

/* Submenu dropdown - for grouped nav items */
.topbar-submenu{position:relative;display:inline-flex;}
.topbar-submenu-toggle{
  display:inline-flex;align-items:center;gap:4px;
  padding:7px 12px;font-size:12px;font-weight:500;
  color:var(--muted);background:transparent;
  border:1px solid transparent;border-radius:8px;
  cursor:pointer;white-space:nowrap;
  transition:color var(--transition-fast),background var(--transition-fast);
}
.topbar-submenu-toggle:hover,.topbar-submenu.is-open .topbar-submenu-toggle{
  color:var(--text);background:var(--card);border-color:var(--line);
}
.submenu-arrow{font-size:10px;transition:transform var(--transition-fast);}
.topbar-submenu.is-open .submenu-arrow{transform:rotate(180deg);}
.topbar-submenu-items{
  display:none;position:absolute;top:100%;left:0;margin-top:4px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);min-width:160px;z-index:200;
  padding:6px;overflow:hidden;
}
.topbar-submenu.is-open .topbar-submenu-items{display:block;animation:menuSlideIn var(--transition) ease-out;}
.topbar-submenu-items a{
  display:block;padding:10px 14px;font-size:13px;font-weight:500;
  color:var(--text);text-decoration:none;border-radius:6px;
  transition:background var(--transition-fast);
}
.topbar-submenu-items a:hover{background:rgba(0,0,0,0.04);}

/* Mobile submenu adjustments */
@media(max-width:900px){
  .topbar-submenu{display:flex;flex-direction:column;width:100%;}
  .topbar-submenu-toggle{
    width:100%;justify-content:space-between;
    padding:12px 14px;font-size:13px;border:none;background:transparent;color:var(--text);
  }
  .topbar-submenu-toggle:hover{background:rgba(0,0,0,0.04);}
  .topbar-submenu-items{
    position:static;margin-top:0;box-shadow:none;border:none;
    border-radius:0;padding:0 0 0 16px;background:transparent;
  }
  .topbar-submenu-items a{padding:10px 14px;font-size:13px;}
}

.filter-controls{display:flex;justify-content:flex-end;margin:6px 0;}
.filter-toggle,.filters-toggle{font-size:12px;font-weight:500;}
.filter-panel{display:none;animation:fadeIn var(--transition) ease-out;}
.filter-panel.is-open{display:block;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

/* ─────────────────────────────────────────────────────────────────
   CARDS - Compact, clean
   ───────────────────────────────────────────────────────────────── */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
  margin:8px 0;
  box-shadow:var(--shadow);
  transition:box-shadow var(--transition),border-color var(--transition);
}
@media(min-width:640px){.card{padding:16px;}}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:6px;flex-wrap:wrap;}
.card-title{font-size:14px;font-weight:700;margin:0;color:var(--text);letter-spacing:-0.01em;}
.card-subtitle{font-size:11px;color:var(--muted);margin-top:1px;}

/* Order form card */
#orderForm.card{padding:14px;}
@media(min-width:640px){#orderForm.card{padding:18px;}}

.landing-admin-card{margin-top:var(--s4);}
.landing-signin-form{display:flex;flex-direction:column;gap:var(--s3);}
.landing-signin-row{display:flex;gap:var(--s3);flex-wrap:wrap;}
.landing-signin-row input{flex:1 1 200px;min-width:180px;}
.landing-admin-hint{margin-top:calc(-1 * var(--s2));font-size:var(--text-sm);}
.landing-signin-error{color:var(--error);font-size:var(--text-sm);margin-top:calc(-1 * var(--s1));}

/* ─────────────────────────────────────────────────────────────────
   GRID & LAYOUT - Tight
   ───────────────────────────────────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;}
@media(min-width:480px){.grid{gap:8px;}}
@media(min-width:640px){.grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media(min-width:900px){.grid{grid-template-columns:repeat(4,minmax(0,1fr));}}
.row{display:flex;gap:6px;flex-wrap:wrap;}
.stack{display:grid;grid-template-columns:1fr;gap:4px;}

/* ─────────────────────────────────────────────────────────────────
   PRODUCTS - Compact, sleek cards
   ───────────────────────────────────────────────────────────────── */
.product-scroll{
  max-height:55vh;
  overflow:auto;
  overscroll-behavior:contain;
  scroll-behavior:smooth;
  margin:0 -2px;
  padding:2px;
}
@media(min-width:768px){.product-scroll{max-height:400px;}}

.product{
  position:relative;
  border:none;
  border-radius:8px;
  padding:0;
  cursor:pointer;
  background:var(--card);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,0.04);
  transition:box-shadow 0.1s ease;
}
.product:hover{box-shadow:0 2px 6px rgba(0,0,0,0.08);}
.product:active{opacity:0.9;}
.product.selected{box-shadow:0 0 0 2px var(--accent);}
.product.boosted{
  box-shadow:0 0 0 3px #f59e0b, 0 0 20px rgba(245,158,11,0.7);
  animation:product-glow 2s ease-in-out infinite;
}
@keyframes product-glow{
  0%,100%{box-shadow:0 0 0 3px #f59e0b, 0 0 15px rgba(245,158,11,0.6);}
  50%{box-shadow:0 0 0 5px #f59e0b, 0 0 30px rgba(245,158,11,0.9);}
}

/* Product image */
.product img{width:100%;aspect-ratio:1/1;object-fit:cover;background:#f5f5f5;display:block;}

/* Product info */
.product > div{padding:4px 6px;}
.product > div:last-child{padding-top:0;padding-bottom:6px;}
.product strong{
  display:block;
  font-size:11px;
  font-weight:500;
  line-height:1.2;
  color:var(--text);
  margin-bottom:1px;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.product .small{font-size:11px;font-weight:600;color:var(--accent);}
.product .badge{margin-top:2px;font-size:8px;padding:1px 4px;background:rgba(0,0,0,0.04);border:none;color:var(--muted);}

/* Sale price */
.product .small span[style*="line-through"]{color:var(--muted);font-weight:400;font-size:9px;}

.product-name{font-weight:500;font-size:11px;line-height:1.2;color:var(--text);}
.product-price{font-weight:600;font-size:11px;color:var(--accent);}

/* ─────────────────────────────────────────────────────────────────
   FORMS - Compact, clean inputs
   ───────────────────────────────────────────────────────────────── */
.field{width:100%;margin:0 0 8px;}
.field label{
  display:block;
  font-size:11px;
  font-weight:500;
  color:var(--muted);
  margin-bottom:4px;
}
/* Prevent checkboxes/radios from stretching to full width inside labels */
label input[type="checkbox"],label input[type="radio"]{width:auto;flex-shrink:0;}

/* Order-view label checkboxes */
.label-checkbox{
  display:inline-flex;
  gap:6px;
  align-items:center;
  padding:5px 10px;
  border:1px solid var(--line);
  border-radius:8px;
  font-size:13px;
  font-weight:500;
  color:var(--fg);
  cursor:pointer;
  transition:border-color .15s,background .15s;
  user-select:none;
}
.label-checkbox:hover{background:var(--hover);}
.label-checkbox input[type="checkbox"]{
  width:14px;height:14px;margin:0;cursor:pointer;accent-color:var(--accent);
}
.label-checkbox .badge-swatch{
  display:inline-block;
  width:14px;height:14px;min-width:14px;min-height:14px;
  border-radius:4px;
  border:1px solid rgba(0,0,0,.12);
}
input,select,textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:10px 12px;
  background:#fff;
  font-size:14px;
  color:var(--text);
  transition:border-color 0.15s ease,box-shadow 0.15s ease;
}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(83,64,255,0.08);
}
input::placeholder,textarea::placeholder{color:var(--muted);opacity:0.5;}
input:disabled,select:disabled,textarea:disabled{background:var(--bg);color:var(--muted);cursor:not-allowed;}
select{max-width:100%;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;}
textarea{min-height:70px;resize:vertical;line-height:1.4;}
.hint{font-size:10px;color:var(--muted);margin-top:3px;}
.field-error input,.field-error select,.field-error textarea{border-color:#d32f2f!important;box-shadow:0 0 0 1px rgba(211,47,47,0.2);}
.field-error .hint{color:#d32f2f;}

/* ─────────────────────────────────────────────────────────────────
   BUTTONS - Compact, refined
   ───────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  background:var(--accent);
  color:#fff;
  border:none;
  padding:10px 18px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
  text-align:center;
  touch-action:manipulation;
  transition:all 0.15s ease;
}
.btn:hover{opacity:0.9;transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn:active{transform:scale(0.97);box-shadow:none;}
.btn:disabled{opacity:0.4;cursor:not-allowed;transform:none;box-shadow:none;}

.btn.secondary{background:var(--card);color:var(--text);border:1px solid var(--line);}
.btn.secondary:hover{background:var(--bg);opacity:1;border-color:var(--accent);color:var(--accent);}

.btn.ghost{background:transparent;color:var(--text);border:1px solid transparent;}
.btn.ghost:hover{background:rgba(0,0,0,0.03);}

.btn.success{background:var(--success);color:#fff;}
.btn.success:hover{opacity:0.9;}

.btn.danger{background:var(--error);color:#fff;}
.btn.danger:hover{opacity:0.9;}

.btn.warning{background:var(--warning);color:#fff;}
.btn.warning:hover{opacity:0.9;}

.btn.sm{padding:5px 9px;font-size:11px;}
.btn.lg,.btn.big{padding:10px 18px;font-size:14px;}
.btn.full{width:100%;}
.btn.icon-only{padding:6px;min-width:32px;}

/* ─────────────────────────────────────────────────────────────────
   NOTICES - Clean, modern alerts
   ───────────────────────────────────────────────────────────────── */
.notice{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:var(--radius-sm);
  font-size:12px;
  font-weight:500;
  line-height:1.4;
  background:#f5f7f9;
  border:none;
  color:var(--text);
}
.notice::before{content:'ℹ';flex-shrink:0;font-size:12px;opacity:0.7;}
.notice.success{background:#ecfdf5;color:#065f46;}
.notice.success::before{content:'✓';}
.notice.warning{background:#fffbeb;color:#92400e;}
.notice.warning::before{content:'!';}
.notice.error{background:#fef2f2;color:#991b1b;}
.notice.error::before{content:'✕';}
.notice.info{background:#eff6ff;color:#1e40af;}

/* ─────────────────────────────────────────────────────────────────
   CART / ORDER SUMMARY - Compact
   ───────────────────────────────────────────────────────────────── */
#cartArea{
  background:#f8f9fa;
  border-radius:10px;
  padding:10px 12px;
  margin:10px 0;
}
#cartArea label{
  font-size:12px;
  font-weight:600;
  color:var(--text);
  margin-bottom:6px;
}
#cartList{display:flex;flex-direction:column;gap:4px;}
#cartList > div{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:6px 8px;
  background:#fff;
  border-radius:6px;
  font-size:12px;
}
#cartList > div strong{flex:1;font-weight:500;}
#cartList > div span{font-weight:600;color:var(--accent);}

/* Order total */
#orderTotal{
  font-size:14px !important;
  font-weight:600 !important;
  color:var(--text);
  text-align:right;
  padding:8px 0;
  margin-top:6px;
  border-top:1px solid var(--line);
}
#orderTotal strong{color:var(--accent);}

/* Submit button */
.btn.big{
  width:100%;
  padding:12px 20px;
  font-size:14px;
  font-weight:600;
  border-radius:10px;
  background:var(--accent);
}
.btn.big:hover{opacity:0.9;}
.btn.big:active{transform:scale(0.98);}

/* ─────────────────────────────────────────────────────────────────
   BADGES - Minimal pills
   ───────────────────────────────────────────────────────────────── */
.badge{
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border-radius:999px;
  border:none;
  background:rgba(0,0,0,0.05);
  font-size:10px;
  font-weight:500;
  color:var(--muted);
}
.badge.success{background:var(--success-bg);color:var(--success);}
.badge.warning{background:var(--warning-bg);color:var(--warning);}
.badge.error{background:var(--error-bg);color:var(--error);}
.badge.info{background:var(--info-bg);color:var(--info);}

/* ─────────────────────────────────────────────────────────────────
   TABLES - Compact, clean
   ───────────────────────────────────────────────────────────────── */
.table{width:100%;border-collapse:collapse;}
.table th,.table td{
  padding:6px 8px;
  text-align:left;
  font-size:12px;
  border-bottom:1px solid var(--line);
}
.table th{
  font-size:10px;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.table tbody tr:hover{background:rgba(0,0,0,0.02);}
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.table-responsive .table{margin:0;}

.actions{display:flex;gap:4px;flex-wrap:wrap;align-items:center;}
.actions-cell{white-space:nowrap;}

/* ─────────────────────────────────────────────────────────────────
   MOBILE RESPONSIVE
   ───────────────────────────────────────────────────────────────── */
@media (max-width: 640px){
  .field{min-width:100% !important;}
  .actions{gap:4px;}
  .table th,.table td{padding:5px 6px;font-size:11px;}
  .hide-mobile{display:none !important;}
}

@media (max-width: 480px){
  body{font-size:12px;}
  .brand{font-size:14px;}
  .card{padding:8px;margin:6px 0;}
  .btn{font-size:11px;padding:6px 10px;}
  .btn.lg,.btn.big{font-size:13px;padding:9px 14px;}
}

/* iPhone SE and very small screens */
@media (max-width: 360px){
  .container{padding:8px;padding-left:calc(8px + env(safe-area-inset-left));padding-right:calc(8px + env(safe-area-inset-right));}
  .topbar{padding:6px 0;padding-top:calc(6px + env(safe-area-inset-top));}
  .grid{gap:6px;}
  .product{padding:6px;}
  .table th,.table td{padding:4px 5px;font-size:10px;}
}

/* ─────────────────────────────────────────────────────────────────
   TOGGLE & ACCORDION
   ───────────────────────────────────────────────────────────────── */
.toggle-details{
  font-size:12px;
  font-weight:500;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:4px;
}
.toggle-details::after{content:'▾';display:inline-block;font-size:10px;transition:transform var(--transition);}
.toggle-details[aria-expanded="true"]::after{transform:rotate(180deg);}
.filters-toggle{font-size:12px;font-weight:500;}

/* ─────────────────────────────────────────────────────────────────
   BACKGROUND - White by default, no auto-loading of images
   ───────────────────────────────────────────────────────────────── */

/* ─────────────────────────────────────────────────────────────────
   DARK MODE - Refined
   ───────────────────────────────────────────────────────────────── */
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0a0f14;
    --card:#151b23;
    --text:#e8eaed;
    --muted:#8899a6;
    --line:#2a3542;
    --accent:#7c6fff;
    --success:#00ba7c;
    --success-bg:rgba(0,186,124,0.12);
    --warning:#ffad1f;
    --warning-bg:rgba(255,173,31,0.12);
    --error:#f4212e;
    --error-bg:rgba(244,33,46,0.12);
    --info:#7c6fff;
    --info-bg:rgba(83,64,255,0.12);
  }
  input,select,textarea{background:var(--card);color:var(--text);border-color:var(--line);}
  .btn.secondary{background:var(--card);color:var(--text);border-color:var(--line);}
  .btn.secondary:hover{background:var(--bg);}
  .product{background:var(--card);}
  .product img{background:var(--line);}
  .notice{background:var(--card);color:var(--text);}
  .notice.success{background:var(--success-bg);color:var(--success);}
  .notice.warning{background:var(--warning-bg);color:var(--warning);}
  .notice.error{background:var(--error-bg);color:var(--error);}
  .notice.info{background:var(--info-bg);color:var(--info);}
  .admin-kpi{background:var(--card);border-color:var(--line);}
  .option-card{background:var(--card);border-color:var(--line);}
  .option-card:has(input:checked){background:rgba(83,64,255,0.08);border-color:var(--accent);}
  #cartArea{background:var(--card);}
  #cartList > div{background:var(--bg);}
  #productSearch{background:var(--card);}
  .store-followers{background:rgba(255,255,255,0.05);}
  .store-verified{background:rgba(0,186,124,0.15);color:var(--success);}
  .card{color:var(--text);}
  .small{color:#a0aec0;}
  .landing-hero-sub{color:#a0aec0;}
  .landing-hero-hint{color:#a0aec0;}
  .landing-hero-hint strong{color:var(--text);}
  .landing-stories-head{color:var(--text);}
  .landing-story-name{color:var(--text);}
  .landing-stories-fixed{background:transparent;}
  .feed-card-head .feed-card-meta span{color:#a0aec0;}
  .update-card .feed-card-body p{color:var(--text);}
  body.landing-shell .topbar{color:var(--text);}
  body.landing-shell .card{background:var(--card);border-color:var(--line);}
  body.landing-shell-has-image .card{background:var(--card);border-color:var(--line);}
  .auth-modal{background:var(--card);color:var(--text);}
  body.landing-shell{background:var(--bg);}
  .landing-bg{background-color:var(--bg);}
  .landing-hero-search input{background:var(--card);border-color:var(--line);}
  .landing-hero-title{color:var(--text);}
  .landing-promo{color:var(--muted);}
  .landing-promo a{color:var(--accent);}
  .thread-header{background:var(--card);border-color:var(--line);}
  .chat-bubble.in{background:var(--card);}
  .thread-composer{background:var(--card);border-color:var(--line);}
  .drawer{background:var(--card);}
  .website-modal{background:var(--card);}
  .website-modal-header{background:var(--card);border-color:var(--line);}
  .chat-widget-panel{background:var(--card);}
  .chat-widget-composer{background:var(--card);border-color:var(--line);}
  .studio-composer{background:var(--card);border-color:var(--line);}
}

/* ─────────────────────────────────────────────────────────────────
   ADMIN KPI - Compact dashboard cards
   ───────────────────────────────────────────────────────────────── */
.admin-kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.admin-kpi{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px;
  transition:box-shadow var(--transition),transform var(--transition);
}
.admin-kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);}
.admin-kpi-label{
  font-size:10px;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.admin-kpi-value{
  font-size:22px;
  font-weight:800;
  line-height:1.1;
  margin-top:4px;
  color:var(--text);
}
.admin-kpi-sub{
  font-size:10px;
  color:var(--muted);
  margin-top:3px;
}
@media (max-width: 900px){.admin-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 480px){.admin-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;}.admin-kpi{padding:8px;}.admin-kpi-value{font-size:18px;}}

/* ─────────────────────────────────────────────────────────────────
   STATUS BADGES - Minimal pills
   ───────────────────────────────────────────────────────────────── */
.status-new,.status-confirmed{background:var(--info-bg);color:var(--info);}
.status-packed{background:var(--warning-bg);color:var(--warning);}
.status-out_for_delivery{background:rgba(168,85,247,0.1);color:#a855f7;}
.status-delivered{background:var(--success-bg);color:var(--success);}
.status-failed,.status-cancelled{background:var(--error-bg);color:var(--error);}

/* ─────────────────────────────────────────────────────────────────
   LOADING STATES - Subtle
   ───────────────────────────────────────────────────────────────── */
.loading{position:relative;pointer-events:none;opacity:0.6;}
.loading::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.4);}
.spinner{
  width:16px;height:16px;
  border:1.5px solid var(--line);
  border-top-color:var(--accent);
  border-radius:50%;
  animation:spin 0.6s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}
.btn.loading .spinner{width:14px;height:14px;}

/* ─────────────────────────────────────────────────────────────────
   EMPTY STATES - Clean
   ───────────────────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:24px 12px;color:var(--muted);}
.empty-state-icon{font-size:32px;margin-bottom:8px;opacity:0.4;}
.empty-state-title{font-size:14px;font-weight:700;margin-bottom:4px;color:var(--text);}
.empty-state-desc{font-size:12px;margin-bottom:10px;}

/* ─────────────────────────────────────────────────────────────────
   UTILITY CLASSES
   ───────────────────────────────────────────────────────────────── */
.text-center{text-align:center;}
.text-right{text-align:right;}
.text-muted{color:var(--muted);}
.text-success{color:var(--success);}
.text-warning{color:var(--warning);}
.text-error{color:var(--error);}
.font-bold{font-weight:700;}
.font-semibold{font-weight:600;}
.mb-0{margin-bottom:0;}
.mb-1{margin-bottom:4px;}
.mb-2{margin-bottom:6px;}
.mb-3{margin-bottom:10px;}
.mb-4{margin-bottom:12px;}
.mt-0{margin-top:0;}
.mt-2{margin-top:6px;}
.mt-3{margin-top:10px;}
.mt-4{margin-top:12px;}
.gap-1{gap:4px;}
.gap-2{gap:6px;}
.gap-3{gap:10px;}
.flex{display:flex;}
.flex-col{flex-direction:column;}
.items-center{align-items:center;}
.justify-between{justify-content:space-between;}
.justify-end{justify-content:flex-end;}
.flex-wrap{flex-wrap:wrap;}
.flex-1{flex:1;}
.w-full{width:100%;}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}

/* ─────────────────────────────────────────────────────────────────
   PASSWORD TOGGLE SYSTEM
   ───────────────────────────────────────────────────────────────── */
.password-wrap {
  position: relative;
  width: 100%;
}
.password-wrap input[type="password"],
.password-wrap input[type="text"] {
  padding-right: 40px !important;
}
.password-toggle {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  padding: 5px;
  cursor: pointer;
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--transition-fast);
  z-index: 5;
  -webkit-tap-highlight-color: transparent;
}
.password-toggle:hover { color: var(--text); }
.password-toggle svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }


/* ─────────────────────────────────────────────────────────────────
   AUTH MODAL - Login/Signup overlay for engagement actions
   ───────────────────────────────────────────────────────────────── */
.auth-modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.5);
  backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
  z-index:9999;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.25s ease;
}
.auth-modal-overlay.active{opacity:1;pointer-events:auto;}
.auth-modal{
  background:var(--card);
  border-radius:16px 16px 0 0;
  box-shadow:0 -8px 40px rgba(0,0,0,0.15);
  width:100%;
  max-width:420px;
  padding:20px;
  padding-bottom:calc(20px + var(--bottom-nav-h, 0px) + env(safe-area-inset-bottom));
  transform:translateY(100%);
  transition:transform 0.3s cubic-bezier(0.32,0.72,0,1);
}
.auth-modal::before{
  content:'';display:block;width:36px;height:4px;
  background:#d1d5db;border-radius:2px;
  margin:0 auto 14px;
}
.auth-modal-overlay.active .auth-modal{transform:translateY(0);}
.auth-modal-close{
  position:absolute;
  top:16px;
  right:16px;
  width:30px;
  height:30px;
  border:none;
  background:#f1f5f9;
  cursor:pointer;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#64748b;
  transition:background 0.15s ease;
  -webkit-tap-highlight-color:transparent;
}
.auth-modal-close:hover{background:#e2e8f0;}
.auth-modal-header{position:relative;text-align:center;margin-bottom:16px;}
.auth-modal-title{font-size:18px;font-weight:800;margin:0 0 4px 0;letter-spacing:-0.02em;}
.auth-modal-subtitle{font-size:13px;color:var(--muted);margin:0;}
.auth-modal-form .field{margin-bottom:12px;}
.auth-modal-form .field label{font-size:12px;font-weight:700;margin-bottom:4px;display:block;}
.auth-modal-form .field input{width:100%;padding:11px 12px;font-size:15px;border-radius:var(--radius-sm);}
.auth-modal-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px;}
.auth-modal-actions .btn{width:100%;justify-content:center;}
.auth-modal-switch{text-align:center;margin-top:14px;font-size:12px;color:var(--muted);}
.auth-modal-switch a{color:var(--accent);font-weight:600;text-decoration:none;}
.auth-modal-switch a:hover{text-decoration:underline;}
.auth-modal-error{background:var(--error-bg);color:var(--error);padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;margin-bottom:12px;display:none;}
.auth-modal-error.show{display:block;}
@media (prefers-color-scheme: dark){
  .auth-modal-overlay{background:rgba(0,0,0,0.7);}
  .auth-modal{background:var(--card);border-top:1px solid var(--line);}
  .auth-modal::before{background:#475569;}
  .auth-modal-close{background:#1e293b;color:#94a3b8;}
}

/* ─────────────────────────────────────────────────────────────────
   INFO BUTTON SYSTEM - Minimalistic, Mobile-First Help Tooltips
   ───────────────────────────────────────────────────────────────── */
.info-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;
  background:var(--line);color:var(--muted);
  font-size:11px;font-weight:700;cursor:pointer;
  border:none;padding:0;margin-left:6px;
  transition:var(--transition-fast);
  flex-shrink:0;vertical-align:middle;
}
.info-btn:hover{background:var(--accent);color:#fff;}
.info-btn:focus{outline:2px solid var(--accent);outline-offset:2px;}

/* Info Popup Overlay */
.info-popup-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,0.4);
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity 200ms ease, visibility 200ms ease;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
.info-popup-overlay.show{opacity:1;visibility:visible;}

/* Info Popup Card - Mobile-first bottom sheet */
.info-popup{
  background:var(--card);
  width:100%;max-width:400px;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  padding:0;
  transform:translateY(100%);
  transition:transform 250ms cubic-bezier(0.32,0.72,0,1);
  max-height:80vh;overflow:hidden;
  display:flex;flex-direction:column;
}
.info-popup-overlay.show .info-popup{transform:translateY(0);}

/* Popup Handle (mobile drag indicator) */
.info-popup-handle{
  width:36px;height:4px;
  background:var(--line);border-radius:2px;
  margin:10px auto 0;flex-shrink:0;
}

/* Popup Header */
.info-popup-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px 8px;border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.info-popup-title{font-size:15px;font-weight:600;color:var(--text);}
.info-popup-close{
  width:28px;height:28px;border-radius:50%;
  background:var(--line);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--muted);
  transition:var(--transition-fast);
}
.info-popup-close:hover{background:var(--error-bg);color:var(--error);}

/* Popup Body */
.info-popup-body{
  padding:16px;padding-bottom:calc(16px + var(--bottom-nav-h, 0px) + env(safe-area-inset-bottom));overflow-y:auto;flex:1;
  font-size:13px;line-height:1.6;color:var(--text);
}
.info-popup-body p{margin:0 0 12px;}
.info-popup-body p:last-child{margin-bottom:0;}
.info-popup-body ul,.info-popup-body ol{margin:0 0 12px;padding-left:20px;}
.info-popup-body li{margin-bottom:6px;}
.info-popup-body strong{font-weight:600;}
.info-popup-body code{
  background:var(--line);padding:2px 6px;border-radius:4px;
  font-size:11px;font-family:monospace;
}

/* Popup Footer (optional action) */
.info-popup-footer{
  padding:12px 16px;border-top:1px solid var(--line);
  flex-shrink:0;
}
.info-popup-footer .btn{width:100%;justify-content:center;}

/* Desktop: Center popup instead of bottom sheet */
@media(min-width:600px){
  .info-popup-overlay{align-items:center;}
  .info-popup{
    border-radius:var(--radius-lg);
    max-height:70vh;
    transform:translateY(20px) scale(0.95);
    opacity:0;
  }
  .info-popup-overlay.show .info-popup{
    transform:translateY(0) scale(1);
    opacity:1;
  }
  .info-popup-handle{display:none;}
  .info-popup-body{padding-bottom:16px;}
}

/* Section headers with info buttons */
.section-header{
  display:flex;align-items:center;gap:4px;
  margin-bottom:8px;
}
.section-header h3,.section-header h4{margin:0;}

/* Inline info button next to labels */
.field-with-info{display:flex;align-items:center;gap:4px;}
.field-with-info label{margin:0;}

/* ─────────────────────────────────────────────────────────────────
   ORDER FORM IMPROVEMENTS - Progress, Accordion, Sticky Cart
   ───────────────────────────────────────────────────────────────── */

/* Progress Indicator */
.order-progress{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 16px;
  background:var(--card);
  border-radius:var(--radius);
  margin-bottom:12px;
  gap:4px;
  overflow-x:auto;
}
.order-progress-step{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  flex:1;
  min-width:60px;
  position:relative;
}
.order-progress-step::after{
  content:'';
  position:absolute;
  top:12px;
  left:calc(50% + 14px);
  width:calc(100% - 28px);
  height:2px;
  background:var(--line);
}
.order-progress-step:last-child::after{display:none;}
.order-progress-step.active::after,.order-progress-step.completed::after{background:var(--accent);}
.order-progress-num{
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--line);
  color:var(--muted);
  font-size:11px;
  font-weight:600;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  z-index:1;
}
.order-progress-step.active .order-progress-num{background:var(--accent);color:#fff;}
.order-progress-step.completed .order-progress-num{background:var(--success);color:#fff;}
.order-progress-step.completed .order-progress-num::after{content:'✓';}
.order-progress-step.completed .order-progress-num span{display:none;}
.order-progress-label{font-size:10px;color:var(--muted);text-align:center;line-height:1.2;}
.order-progress-step.active .order-progress-label{color:var(--text);font-weight:500;}
.order-progress-step.completed .order-progress-label{color:var(--success);}

/* Accordion Sections */
.order-section{
  background:var(--card);
  border-radius:var(--radius);
  margin-bottom:10px;
  overflow:hidden;
}
.order-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  cursor:pointer;
  user-select:none;
  border-bottom:1px solid transparent;
  transition:background 0.15s ease;
}
.order-section-header:hover{background:rgba(0,0,0,0.02);}
.order-section.open .order-section-header{border-bottom-color:var(--line);}
.order-section-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:600;
  font-size:14px;
  color:var(--text);
}
.order-section-icon{
  width:28px;
  height:28px;
  border-radius:8px;
  background:var(--accent);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
}
.order-section.completed .order-section-icon{background:var(--success);}
.order-section-status{
  display:flex;
  align-items:center;
  gap:8px;
}
.order-section-badge{
  font-size:10px;
  padding:3px 8px;
  border-radius:12px;
  background:var(--line);
  color:var(--muted);
}
.order-section.completed .order-section-badge{background:rgba(16,185,129,0.1);color:var(--success);}
.order-section-arrow{
  width:20px;
  height:20px;
  color:var(--muted);
  transition:transform 0.2s ease;
}
.order-section.open .order-section-arrow{transform:rotate(180deg);}
.order-section-content{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.3s ease;
}
.order-section.open .order-section-content{max-height:2000px;}
.order-section-body{padding:16px;}

/* Sticky Cart Summary */
.sticky-cart{
  position:sticky;
  bottom:0;
  left:0;
  right:0;
  background:var(--card);
  border-top:1px solid var(--line);
  padding:12px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  z-index:100;
  box-shadow:0 -4px 12px rgba(0,0,0,0.08);
  margin:0 -10px -10px;
  width:calc(100% + 20px);
}
.sticky-cart.hidden{display:none;}
.sticky-cart-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;}
.sticky-cart-items{font-size:12px;color:var(--muted);}
.sticky-cart-total{font-size:16px;font-weight:700;color:var(--text);}
.sticky-cart-btn{
  flex-shrink:0;
  padding:12px 20px;
  font-size:14px;
  font-weight:600;
}
@media(min-width:640px){
  .sticky-cart{
    margin:0;
    width:100%;
    border-radius:var(--radius);
    position:relative;
    box-shadow:none;
    border:1px solid var(--line);
    margin-top:12px;
  }
}

/* Improved Product Grid */
.product-grid-enhanced{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
@media(min-width:480px){.product-grid-enhanced{gap:12px;}}
@media(min-width:640px){.product-grid-enhanced{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media(min-width:900px){.product-grid-enhanced{grid-template-columns:repeat(4,minmax(0,1fr));}}

.product-enhanced{
  position:relative;
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;
  border:2px solid transparent;
  transition:border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
  cursor:pointer;
}
.product-enhanced:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.product-enhanced.selected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(83,64,255,0.15);}
.product-enhanced-img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  background:#f5f5f5;
  display:block;
}
.product-enhanced-body{padding:8px 10px 10px;}
.product-enhanced-name{
  font-size:12px;
  font-weight:700;
  color:var(--text);
  line-height:1.3;
  margin-bottom:4px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.product-enhanced-price{
  font-size:13px;
  font-weight:700;
  color:var(--accent);
}
.product-enhanced-price-old{
  font-size:11px;
  color:var(--muted);
  text-decoration:line-through;
  margin-right:6px;
}
.product-enhanced-stock{
  font-size:9px;
  color:var(--muted);
  margin-top:4px;
}
.product-enhanced-check{
  position:absolute;
  top:8px;
  right:8px;
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  opacity:0;
  transform:scale(0.5);
  transition:opacity 0.15s ease, transform 0.15s ease;
}
.product-enhanced.selected .product-enhanced-check{opacity:1;transform:scale(1);}
.product-enhanced-qty{
  position:absolute;
  bottom:8px;
  right:8px;
  display:flex;
  align-items:center;
  gap:4px;
  background:var(--card);
  border-radius:20px;
  padding:4px;
  opacity:0;
  transform:translateY(8px);
  transition:opacity 0.15s ease, transform 0.15s ease;
}
.product-enhanced.selected .product-enhanced-qty{opacity:1;transform:translateY(0);}
.product-qty-btn{
  width:28px;
  height:28px;
  border-radius:50%;
  border:none;
  background:var(--line);
  color:var(--text);
  font-size:16px;
  font-weight:600;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.product-qty-btn:hover{background:var(--accent);color:#fff;}
.product-qty-val{
  min-width:24px;
  text-align:center;
  font-size:14px;
  font-weight:600;
}

/* Inline Validation */
.field.validated input:valid,.field.validated select:valid,.field.validated textarea:valid{
  border-color:var(--success);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2310b981' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 10px center;
  padding-right:36px;
}
.field.validated input:invalid:not(:placeholder-shown),.field.validated select:invalid,.field.validated textarea:invalid:not(:placeholder-shown){
  border-color:var(--error);
}

/* Mobile Sticky Submit */
@media(max-width:639px){
  .order-submit-sticky{
    position:fixed;
    bottom:0;
    left:0;
    right:0;
    background:var(--card);
    padding:12px 16px;
    padding-bottom:calc(12px + env(safe-area-inset-bottom));
    box-shadow:0 -4px 20px rgba(0,0,0,0.12);
    z-index:99;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
  }
  .order-submit-sticky .btn{flex:1;}
  .order-submit-total{font-size:14px;font-weight:600;color:var(--text);}
  .order-form-container{padding-bottom:80px;}
}

/* Larger Touch Targets */
.option-card{min-height:52px;}
.option-card input[type="radio"]{
  width:20px;
  height:20px;
  margin:0;
}
select,input[type="text"],input[type="email"],input[type="tel"],input[type="date"],textarea{
  min-height:44px;
}

/* Show/Hide on Mobile */
.show-on-mobile{display:none;}
.hide-on-mobile{display:block;}
@media(max-width:639px){
  .show-on-mobile{display:flex;}
  .hide-on-mobile{display:none !important;}
}

/* ===== TRACK ORDER PAGES ===== */

/* Track Lookup Page */
.track-hero{
  text-align:center;
  padding:32px 16px;
  background:linear-gradient(135deg, rgba(0,132,255,0.08) 0%, rgba(0,132,255,0.02) 100%);
  border-radius:16px;
  margin-bottom:24px;
}
.track-hero-icon{
  width:64px;
  height:64px;
  background:var(--accent);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 16px;
  font-size:28px;
}
.track-hero-title{
  font-size:24px;
  font-weight:700;
  margin-bottom:8px;
  color:var(--text);
}
.track-hero-subtitle{
  font-size:14px;
  color:var(--muted);
  max-width:280px;
  margin:0 auto;
}
.track-form{
  background:var(--card);
  border-radius:16px;
  padding:24px;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}
.track-form .field{margin-bottom:20px;}
.track-form input{
  font-size:18px;
  text-align:center;
  letter-spacing:2px;
  font-weight:600;
}
.track-form .btn{width:100%;padding:14px 24px;font-size:16px;}
.track-tips{
  margin-top:24px;
  padding:16px;
  background:rgba(0,132,255,0.05);
  border-radius:12px;
}
.track-tips-title{
  font-size:13px;
  font-weight:600;
  color:var(--accent);
  margin-bottom:8px;
}
.track-tips-list{
  font-size:13px;
  color:var(--muted);
  padding-left:20px;
  margin:0;
}
.track-tips-list li{margin-bottom:4px;}

/* Order Status Timeline */
.order-timeline{
  display:flex;
  justify-content:space-between;
  position:relative;
  padding:0 8px;
  margin:24px 0;
}
.order-timeline::before{
  content:'';
  position:absolute;
  top:16px;
  left:24px;
  right:24px;
  height:3px;
  background:var(--line);
  z-index:0;
}
.order-timeline-step{
  display:flex;
  flex-direction:column;
  align-items:center;
  position:relative;
  z-index:1;
  flex:1;
}
.order-timeline-dot{
  width:32px;
  height:32px;
  border-radius:50%;
  background:var(--card);
  border:3px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  margin-bottom:8px;
  transition:all 0.2s ease;
}
.order-timeline-step.completed .order-timeline-dot{
  background:var(--success);
  border-color:var(--success);
  color:#fff;
}
.order-timeline-step.current .order-timeline-dot{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
  box-shadow:0 0 0 4px rgba(0,132,255,0.2);
}
.order-timeline-step.failed .order-timeline-dot{
  background:var(--error);
  border-color:var(--error);
  color:#fff;
}
.order-timeline-label{
  font-size:11px;
  color:var(--muted);
  text-align:center;
  max-width:60px;
}
.order-timeline-step.completed .order-timeline-label,
.order-timeline-step.current .order-timeline-label{
  color:var(--text);
  font-weight:600;
}

/* Order Status Card */
.order-status-card{
  background:var(--card);
  border-radius:16px;
  padding:20px;
  margin-bottom:16px;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}
.order-status-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:16px;
}
.order-status-id{
  font-size:20px;
  font-weight:700;
}
.order-status-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:20px;
  font-size:13px;
  font-weight:600;
}
.order-status-badge.new{background:rgba(59,130,246,0.1);color:#3b82f6;}
.order-status-badge.confirmed{background:rgba(16,185,129,0.1);color:#10b981;}
.order-status-badge.packed{background:rgba(139,92,246,0.1);color:#8b5cf6;}
.order-status-badge.out_for_delivery{background:rgba(245,158,11,0.1);color:#f59e0b;}
.order-status-badge.delivered{background:rgba(16,185,129,0.15);color:#059669;}
.order-status-badge.failed{background:rgba(239,68,68,0.1);color:#ef4444;}

/* Order Detail Section */
.order-detail-section{
  background:var(--card);
  border-radius:16px;
  margin-bottom:16px;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,0.04);
}
.order-detail-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 20px;
  cursor:pointer;
  user-select:none;
}
.order-detail-header:hover{background:rgba(0,0,0,0.02);}
.order-detail-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:600;
  font-size:15px;
}
.order-detail-icon{
  width:32px;
  height:32px;
  border-radius:8px;
  background:rgba(0,132,255,0.1);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
}
.order-detail-arrow{
  width:20px;
  height:20px;
  color:var(--muted);
  transition:transform 0.2s ease;
}
.order-detail-section.open .order-detail-arrow{transform:rotate(180deg);}
.order-detail-content{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.3s ease;
}
.order-detail-section.open .order-detail-content{max-height:600px;}
.order-detail-body{
  padding:0 20px 20px;
  border-top:1px solid var(--line);
}

/* Order Items List */
.order-items-list{margin:0;padding:0;list-style:none;}
.order-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 0;
  border-bottom:1px solid var(--line);
}
.order-item:last-child{border-bottom:none;}
.order-item-name{font-weight:500;}
.order-item-qty{
  font-size:13px;
  color:var(--muted);
  margin-left:8px;
}
.order-item-price{font-weight:600;color:var(--accent);}

/* Order Totals */
.order-totals{
  background:rgba(0,132,255,0.05);
  border-radius:12px;
  padding:16px;
  margin-top:16px;
}
.order-totals-row{
  display:flex;
  justify-content:space-between;
  padding:6px 0;
  font-size:14px;
}
.order-totals-row.total{
  font-size:18px;
  font-weight:700;
  border-top:1px solid var(--line);
  padding-top:12px;
  margin-top:8px;
}

/* Upload Section */
.upload-section{
  background:var(--card);
  border-radius:16px;
  padding:20px;
  margin-bottom:16px;
  box-shadow:0 2px 8px rgba(0,0,0,0.04);
}
.upload-section-title{
  font-size:15px;
  font-weight:600;
  margin-bottom:16px;
  display:flex;
  align-items:center;
  gap:10px;
}
.upload-dropzone{
  border:2px dashed var(--line);
  border-radius:12px;
  padding:24px;
  text-align:center;
  cursor:pointer;
  transition:all 0.2s ease;
}
.upload-dropzone:hover{
  border-color:var(--accent);
  background:rgba(0,132,255,0.02);
}
.upload-dropzone-icon{font-size:32px;margin-bottom:8px;}
.upload-dropzone-text{font-size:14px;color:var(--muted);}
.uploaded-files{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}
.uploaded-file{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 12px;
  background:rgba(16,185,129,0.1);
  border-radius:8px;
  font-size:13px;
  color:#059669;
}

/* Quick Actions */
.order-quick-actions{
  display:flex;
  gap:12px;
  margin-bottom:16px;
}
.order-quick-actions .btn{flex:1;justify-content:center;}
.plan-status-column{min-width:260px;}
.plan-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:var(--bg-alt);font-weight:600;color:var(--accent);margin-bottom:8px;}
.trial-countdown{font-size:13px;color:var(--muted);display:flex;gap:8px;align-items:center;}
.trial-countdown strong{font-size:15px;color:var(--text);}
.trial-progress-bar{width:100%;height:4px;background:var(--line);border-radius:999px;margin:8px 0 4px;overflow:hidden;}
.trial-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,#fb923c,#f97316);}
.plan-cta-row{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap;}
.plan-upsell-grid{margin-top:18px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;}
.plan-upsell-card{background:var(--bg-alt);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:10px;}
.plan-upsell-card.highlight{border:1px solid rgba(249,115,22,0.35);box-shadow:0 8px 24px rgba(249,115,22,0.12);}
.plan-upsell-title{font-weight:600;font-size:15px;}
.plan-upsell-price{font-size:22px;color:var(--accent);font-weight:700;}
.plan-upsell-price span{font-size:13px;color:var(--muted);margin-left:4px;font-weight:400;}
.plan-upsell-desc{font-size:13px;color:var(--muted);margin:0;}
.plan-upsell-actions{display:flex;gap:8px;flex-wrap:wrap;}
.stats-range-form{margin-left:auto;}
.stats-range-form select{padding:6px 10px;border:1px solid var(--line);border-radius:6px;background:#fff;font-size:13px;}
.order-section-error{border-color:#d32f2f!important;}
.order-section-error .order-section-header{border-color:#d32f2f;}


.masonry-grid{
  --masonry-columns:1;
  display:grid;
  grid-template-columns:repeat(var(--masonry-columns), minmax(0,1fr));
  gap:var(--s3);
  width:100%;
}
@media(max-width:640px){.masonry-grid{gap:var(--s2);}}
.masonry-column{
  display:flex;
  flex-direction:column;
  gap:var(--s3);
}
.masonry-column > .landing-feed-item{margin:0;}


/* Product Variations */
.variation-pill {
  padding: 4px 10px;
  background: var(--line);
  color: var(--text);
  border: none;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
  border: 1px solid transparent;
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.variation-pill:hover { background: var(--bg); border-color: var(--accent); }
.variation-pill.selected {
  background: rgba(0,132,255,0.1);
  color: var(--accent);
  border-color: var(--accent);
}

.variation-overlay {
  position: fixed !important;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.4);
  z-index: 10000 !important;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.variation-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

.variation-container {
  background: var(--card);
  width: 100%;
  max-width: 500px;
  border-radius: 20px 20px 0 0;
  padding: 20px;
  padding-bottom: calc(20px + var(--bottom-nav-h, 0px) + env(safe-area-inset-bottom));
  transform: translateY(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 -10px 40px rgba(0,0,0,0.2);
}
.variation-overlay.active .variation-container {
  transform: translateY(0);
}

.variation-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.variation-header h4 { margin: 0; font-size: 17px; font-weight: 700; }
.variation-close {
  background: var(--line);
  border: none;
  width: 32px; height: 32px;
  border-radius: 50%;
  font-size: 20px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}

.variation-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 60vh;
  overflow-y: auto;
  padding-bottom: 20px;
}

.variation-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 12px;
  cursor: pointer;
  font-size: 15px;
  font-weight: 500;
  text-align: left;
  transition: all 0.2s;
}
.variation-option:hover { border-color: var(--accent); }
.variation-option.active {
  background: rgba(0,132,255,0.05);
  border-color: var(--accent);
  color: var(--accent);
}

.variation-radio {
  width: 20px; height: 20px;
  border: 2px solid var(--line);
  border-radius: 50%;
  position: relative;
}
.variation-option.active .variation-radio {
  border-color: var(--accent);
}
.variation-option.active .variation-radio::after {
  content: '';
  position: absolute;
  top: 4px; left: 4px; right: 4px; bottom: 4px;
  background: var(--accent);
  border-radius: 50%;
}

@media (min-width: 640px) {
  .variation-overlay {
    align-items: center;
  }
  .variation-container {
    border-radius: 16px;
    transform: scale(0.9) translateY(20px);
  }
  .variation-overlay.active .variation-container {
    transform: scale(1) translateY(0);
  }
}


/* Discovery Clusters Styling Override for New Features */
.cluster-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.cluster-tile { display: block; text-decoration: none; }
.cluster-thumb { position: relative; aspect-ratio: 1; border-radius: 8px; overflow: hidden; background: var(--bg); display:flex;align-items:center;justify-content:center; }
.cluster-thumb img { position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center center;display:block; }
.cluster-thumb-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 24px; font-weight: 700; color: var(--muted); background: var(--line); }
.cluster-thumb-badge { position: absolute; top: 4px; left: 4px; padding: 2px 6px; border-radius: 4px; font-size: 8px; font-weight: 800; color: #fff; background: rgba(0,0,0,0.6); z-index: 1; }
.cluster-thumb-badge.live { background: #dc2626; }
.cluster-thumb-meta { position: absolute; bottom: 0; left: 0; right: 0; padding: 10px 4px 4px; background: linear-gradient(to top, rgba(0,0,0,0.6), transparent); color: #fff; font-size: 9px; font-weight: 600; text-align: center; }

/* ---- Seller Update Cards ---- */
.update-card .feed-card-body { padding: 8px 10px 10px; }
.update-card-caption { font-size: 13px; line-height: 1.4; color: var(--text); margin: 4px 0 6px; word-break: break-word; }
.update-card-tags { display: flex; gap: 6px; margin-bottom: 4px; flex-wrap: wrap; }
.update-tag { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px; }
.update-tag-available { background: #dcfce7; color: #16a34a; }
.update-tag-live { background: #fee2e2; color: #dc2626; animation: pulse-tag 1.5s ease-in-out infinite; }
@keyframes pulse-tag { 0%,100% { opacity: 1; } 50% { opacity: 0.7; } }
.update-card-cta { display: inline-block; padding: 5px 14px; border-radius: 8px; background: var(--accent); color: #fff; font-size: 12px; font-weight: 600; text-decoration: none; margin-left: auto; transition: background 0.15s; }
.update-card-cta:hover { background: #16a34a; }
.update-card .feed-card-row { display: flex; align-items: center; gap: 6px; }
.update-card .feed-card-actions { display: flex; gap: 6px; }
.update-comment-btn { cursor: pointer; }
.update-comment-count { font-size: 11px; margin-left: 2px; }
.update-video { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; background: #000; min-height: 200px; }

/* =====================================================================
   CHAT LIST (outreach.php inbox — WhatsApp-style conversation list)
   ===================================================================== */
.chat-list{display:flex;flex-direction:column;}
.chat-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line,#eee);text-decoration:none;color:inherit;transition:background .15s;}
.chat-item:hover{background:rgba(0,0,0,0.03);}
.chat-item:active{background:rgba(0,0,0,0.06);}
.chat-item.unread{background:rgba(99,102,241,0.06);}
.chat-item.unread .chat-name{font-weight:700;}
.chat-item.unread .chat-preview{color:var(--text,#111);}
.chat-avatar{width:44px;height:44px;border-radius:50%;background:var(--accent,#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0;text-transform:uppercase;}
.chat-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.chat-header{display:flex;justify-content:space-between;align-items:baseline;gap:8px;}
.chat-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chat-time{font-size:11px;color:var(--muted,#888);flex-shrink:0;}
.chat-footer{display:flex;justify-content:space-between;align-items:center;gap:8px;}
.chat-preview{font-size:13px;color:var(--muted,#888);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;}
.chat-meta{display:flex;align-items:center;gap:6px;flex-shrink:0;}
.chat-unread-badge{background:var(--accent,#6366f1);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 5px;}
.chat-status-dot{width:8px;height:8px;border-radius:50%;background:#ccc;}
.chat-status-dot.open{background:#22c55e;}

/* =====================================================================
   THREAD VIEW (thread.php — WhatsApp-style chat bubbles)
   ===================================================================== */
.thread-container{display:flex;flex-direction:column;height:calc(100vh - 56px);height:calc(100dvh - 56px);overflow:hidden;background:#f0f2f5;}
.thread-header{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#fff;border-bottom:1px solid var(--line,#eee);flex-shrink:0;z-index:2;}
.thread-header-info{flex:1;min-width:0;}
.thread-header-name{font-weight:600;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.thread-header-meta{font-size:12px;color:var(--muted,#888);}
.thread-controls-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted,#888);flex-shrink:0;}
.thread-controls-btn:hover{background:rgba(0,0,0,0.06);}
.thread-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:2px;-webkit-overflow-scrolling:touch;}
.chat-bubble{max-width:78%;padding:6px 10px 4px;border-radius:8px;position:relative;word-wrap:break-word;line-height:1.4;}
.chat-bubble.in{background:#fff;align-self:flex-start;border-bottom-left-radius:2px;box-shadow:0 1px 1px rgba(0,0,0,0.06);}
.chat-bubble.out{background:#dcf8c6;align-self:flex-end;border-bottom-right-radius:2px;box-shadow:0 1px 1px rgba(0,0,0,0.06);}
.bubble-content{font-size:14px;}
.bubble-meta{display:flex;justify-content:flex-end;align-items:center;gap:6px;margin-top:2px;}
.bubble-meta span{font-size:11px;color:rgba(0,0,0,0.4);}
.bubble-source{font-size:10px !important;opacity:0.6;}
.empty-state{text-align:center;padding:40px 16px;color:var(--muted,#888);font-size:14px;}

/* Composer bar */
.thread-composer{display:flex;align-items:flex-end;gap:8px;padding:8px 12px;background:#fff;border-top:1px solid var(--line,#eee);flex-shrink:0;padding-bottom:calc(8px + env(safe-area-inset-bottom));}
.composer-input-wrap{flex:1;min-width:0;}
.composer-input-wrap textarea{width:100%;border:1px solid var(--line,#ddd);border-radius:20px;padding:8px 16px;font-size:14px;resize:none;max-height:120px;line-height:1.4;outline:none;font-family:inherit;box-sizing:border-box;}
.composer-input-wrap textarea:focus{border-color:var(--accent,#6366f1);}
.btn-send{width:40px;height:40px;border-radius:50%;border:none;background:var(--accent,#6366f1);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;}
.btn-send:hover{background:#4f46e5;}
.btn-send:active{transform:scale(0.95);}

/* =====================================================================
   CRM DRAWER (thread.php — slide-over panel)
   ===================================================================== */
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.35);z-index:9998;transition:opacity .2s;}
.drawer-overlay.open{display:block;}
.drawer{position:fixed;top:0;right:0;height:100%;width:320px;max-width:85vw;background:#fff;z-index:9999;transform:translateX(100%);transition:transform .25s ease;box-shadow:-4px 0 16px rgba(0,0,0,0.12);display:flex;flex-direction:column;overflow:hidden;}
.drawer.open{transform:translateX(0);}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line,#eee);flex-shrink:0;}
.drawer-body{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch;}

/* =====================================================================
   TENANT WEBSITE MODAL (order.php — globe icon full-screen overlay)
   ===================================================================== */
.website-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:10001;flex-direction:column;}
.website-modal-overlay.open{display:flex;}
.website-modal{flex:1;display:flex;flex-direction:column;background:#fff;border-top-left-radius:12px;border-top-right-radius:12px;overflow:hidden;margin-top:env(safe-area-inset-top);}
.website-modal-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;padding-top:calc(8px + env(safe-area-inset-top));background:#fff;border-bottom:1px solid var(--line,#eee);flex-shrink:0;}
.website-modal-iframe{flex:1;border:none;width:100%;}
@media(min-width:768px){
  .website-modal{margin:40px auto 0 auto;width:90%;max-width:1000px;border-radius:12px;}
}

/* =====================================================================
   CUSTOMER CHAT WIDGET (order.php — floating chat bubble)
   ===================================================================== */
.chat-widget-btn{position:fixed;bottom:calc(var(--bottom-nav-h,60px) + env(safe-area-inset-bottom) + 16px);right:16px;width:52px;height:52px;border-radius:50%;background:var(--accent,#6366f1);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,0.2);z-index:9990;display:flex;align-items:center;justify-content:center;transition:transform .15s;}
.chat-widget-btn:hover{transform:scale(1.08);}
.chat-widget-btn:active{transform:scale(0.95);}
.chat-widget-badge{position:absolute;top:-2px;right:-2px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;}
.chat-widget-panel{display:none;position:fixed;bottom:calc(var(--bottom-nav-h,60px) + env(safe-area-inset-bottom) + 76px);right:16px;width:340px;max-width:calc(100vw - 32px);height:400px;max-height:50vh;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.18);z-index:9991;flex-direction:column;overflow:hidden;}
.chat-widget-panel.open{display:flex;}
.chat-widget-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--accent,#6366f1);color:#fff;flex-shrink:0;}
.chat-widget-header h4{margin:0;font-size:14px;font-weight:600;}
.chat-widget-close{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0 4px;opacity:0.8;}
.chat-widget-close:hover{opacity:1;}
.chat-widget-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:4px;background:#f0f2f5;-webkit-overflow-scrolling:touch;}
.chat-widget-composer{display:flex;gap:8px;padding:8px 12px;border-top:1px solid var(--line,#eee);background:#fff;flex-shrink:0;}
.chat-widget-composer input{flex:1;border:1px solid var(--line,#ddd);border-radius:20px;padding:8px 14px;font-size:13px;outline:none;font-family:inherit;}
.chat-widget-composer input:focus{border-color:var(--accent,#6366f1);}
.chat-widget-composer button{width:34px;height:34px;border-radius:50%;border:none;background:var(--accent,#6366f1);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;}

/* =====================================================================
   AI STUDIO (prompt pills + output actions)
   ===================================================================== */
.prompt-pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px;}
.prompt-pill{padding:6px 12px;font-size:12px;font-weight:500;border:1px solid var(--line,#ddd);border-radius:16px;background:var(--bg,#f8f9fa);cursor:pointer;white-space:nowrap;transition:all .15s;color:var(--text,#333);}
.prompt-pill:hover{border-color:var(--accent,#6366f1);color:var(--accent,#6366f1);background:#f0f0ff;}
.prompt-pill:active{transform:scale(0.96);}
.output-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}
.output-actions .btn{font-size:12px;padding:6px 14px;}
.studio-chat-area{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:200px;}
.studio-response{background:#f8f9fa;border:1px solid var(--line,#eee);border-radius:12px;padding:14px;font-size:14px;line-height:1.5;}
.studio-response img,.studio-response video{max-width:100%;border-radius:8px;margin-top:8px;}
.studio-composer{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line,#eee);background:#fff;align-items:flex-end;}
.studio-composer textarea{flex:1;border:1px solid var(--line,#ddd);border-radius:20px;padding:10px 16px;font-size:14px;resize:none;max-height:100px;outline:none;font-family:inherit;line-height:1.4;}
.studio-composer textarea:focus{border-color:var(--accent,#6366f1);}
.studio-history-item{padding:10px 14px;border-bottom:1px solid var(--line,#eee);cursor:pointer;transition:background .15s;}
.studio-history-item:hover{background:rgba(0,0,0,0.03);}
.studio-history-prompt{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.studio-history-meta{font-size:11px;color:var(--muted,#888);margin-top:2px;}

/* Social proof avatar stack */
.sp-row{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(0,0,0,0.55);margin-top:6px;}
.sp-avatars{display:flex;}
.sp-avi{width:22px;height:22px;border-radius:50%;border:2px solid #fff;margin-right:-8px;object-fit:cover;background:#e5e7eb;}
.sp-avatars>.sp-avi:last-child{margin-right:0;}
.sp-badge{font-size:12px;opacity:0.85;white-space:nowrap;}
.sp-row-dark{color:rgba(255,255,255,0.7);}
.sp-row-dark .sp-avi{border-color:#111;background:#333;}
.sp-row-light{color:rgba(0,0,0,0.55);}
.sp-row-light .sp-avi{border-color:#fff;}

/* =====================================================================
   SURGICAL DASHBOARD MODERNIZATION (CSS ONLY)
   ===================================================================== */

/* 1. Global Container & Mobile Spacing */
@media (max-width: 768px) {
  .container { padding: 12px !important; }
  .topbar { padding: 10px 0 !important; margin-bottom: 20px !important; }
  .card { padding: 20px !important; border-radius: 20px !important; }
}

/* 2. Professional Card Overhaul */
.card {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 24px !important;
  padding: 24px !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.03) !important;
  margin-bottom: 24px !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}
.card:hover {
  box-shadow: 0 10px 30px rgba(0,0,0,0.05) !important;
}

/* 3. Responsive Stats & Grid Stacking */
/* This targets the legacy style="display:grid" and force stacks on mobile */
div[style*="display:grid"], div[style*="display: grid"] {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: 20px !important;
}

@media (max-width: 600px) {
  div[style*="display:grid"], div[style*="display: grid"] {
    grid-template-columns: 1fr !important;
  }
  /* Specific override for the setup checklist to be 2-column on small screens */
  div[style*="repeat(auto-fit, minmax(100px, 1fr))"] {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* 4. Modern Quest Items (Startup Widget) */
.quest-item {
  background: #fff !important;
  border: 1.5px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 8px !important;
  transition: all 0.2s ease !important;
}
.quest-item:hover {
  transform: translateY(-3px) !important;
  border-color: var(--accent) !important;
  box-shadow: 0 10px 25px rgba(83, 64, 255, 0.1) !important;
}
.quest-item.done {
  background: #f8fafc !important;
  border-color: var(--success) !important;
  opacity: 0.7 !important;
}
.quest-item .icon { font-size: 24px !important; margin-bottom: 4px !important; }
.quest-item .label { font-weight: 800 !important; color: var(--text) !important; font-size: 11px !important; text-transform: uppercase !important; }

/* 5. Horizontal Content Rails (Stories/Updates) */
div[style*="overflow-x:auto"], div[style*="overflow-x: auto"] {
  display: flex !important;
  gap: 12px !important;
  padding-bottom: 16px !important;
  scrollbar-width: none !important;
  -webkit-overflow-scrolling: touch !important;
}
div[style*="overflow-x:auto"]::-webkit-scrollbar { display: none !important; }

/* 6. Refined Table UI */
.table-responsive {
  border-radius: 16px !important;
  border: 1px solid var(--line) !important;
  overflow: hidden !important;
}
table { width: 100% !important; border-collapse: collapse !important; }
th { background: #f8fafc !important; font-size: 11px !important; font-weight: 800 !important; color: var(--muted) !important; padding: 16px !important; border-bottom: 1px solid var(--line) !important; }
td { padding: 16px !important; border-bottom: 1px solid var(--line) !important; font-size: 14px !important; font-weight: 600 !important; }

/* 7. Modernized Link Bar */
div[style*="border: 2px solid var(--accent)"] {
  border-radius: 20px !important;
  padding: 16px !important;
  background: #fff !important;
  box-shadow: 0 4px 15px rgba(83, 64, 255, 0.08) !important;
}

/* 8. Improved Buttons */
.btn {
  border-radius: 12px !important;
  font-weight: 700 !important;
  transition: all 0.2s ease !important;
}
.btn:active { transform: scale(0.96) !important; }
