/* ============================================
   HermitStash — Webfolio-inspired dark creative
   ============================================ */

/* ---- Variables — Dark (default) ---- */
:root {
  --bg: #0f0f0f;
  --bg-sub: #121212;
  --bg-surface: #1a1a1a;
  --text: #ffffff;
  --text-body: #d8dadc;
  --text-muted: #999;
  --main-color: #fd5b38;
  --accent: #caff33;
  --border: rgba(255,255,255,0.1);
  --border-thin: rgba(255,255,255,0.06);
  --danger: #ff4444;
  --invert: 0;
}

/* ---- Variables — Light ---- */
[data-theme="light"] {
  --bg: #f5f5f7;
  --bg-sub: #ffffff;
  --bg-surface: #eaeaec;
  --text: #1a1a1a;
  --text-body: #444444;
  --text-muted: #777;
  --main-color: #e04a2f;
  --accent: #2d8a3e;
  --border: rgba(0,0,0,0.08);
  --border-thin: rgba(0,0,0,0.05);
  --danger: #d32f2f;
  --invert: 1;
}
/* Hero stroke text — much bolder for readability */
[data-theme="light"] .hero-title .stroke{-webkit-text-stroke:2px rgba(0,0,0,.5);color:transparent}
[data-theme="light"] .navbar{background:rgba(245,245,247,.85)}
[data-theme="light"] .navbar.scrolled{background:rgba(245,245,247,.95)}
/* Marquee — all items fully opaque, stroke items bolder */
[data-theme="light"] .marquee-item{color:var(--text)}
[data-theme="light"] .marquee-item:nth-child(even){color:transparent;-webkit-text-stroke:1px rgba(0,0,0,.4)}
[data-theme="light"] .marquee-section::before{background:linear-gradient(to right,var(--bg),transparent)}
[data-theme="light"] .marquee-section::after{background:linear-gradient(to left,var(--bg),transparent)}
[data-theme="light"] body::after{opacity:.015}
[data-theme="light"] .hero::before{background:radial-gradient(circle,rgba(253,91,56,.06) 0%,transparent 70%)}
[data-theme="light"] .hero::after{background:radial-gradient(circle,rgba(45,138,62,.04) 0%,transparent 70%)}
[data-theme="light"] .terminal{border-color:rgba(0,0,0,.1)}
[data-theme="light"] .terminal-body{background:#1a1a1a;color:#d8dadc}
[data-theme="light"] .terminal-bar{background:rgba(0,0,0,.04)}
[data-theme="light"] .code-line{color:#d8dadc}
[data-theme="light"] .code-prompt{color:#fd5b38}
[data-theme="light"] .announcement-banner{background:linear-gradient(90deg,#e04a2f,#ff6b4a)}
/* Logos */
[data-theme="light"] .navbar-logo-img,[data-theme="light"] .footer-logo-img,[data-theme="light"] .light-invert{filter:brightness(0)}

/* Buttons — dark text/borders instead of white */
[data-theme="light"] .butn-bord{border-color:rgba(0,0,0,.2);color:var(--text)}
[data-theme="light"] .butn-bord:hover{background:var(--text);color:var(--bg);border-color:var(--text)}
[data-theme="light"] .butn-bord-thin{border-color:rgba(0,0,0,.1);color:var(--text)}
[data-theme="light"] .butn-bord-thin:hover{background:var(--text);color:var(--bg)}
/* Circle button + CTA text */
[data-theme="light"] .btn-circle{border-color:rgba(0,0,0,.2);color:var(--text)}
[data-theme="light"] .butn-crev .text{color:var(--text)}
[data-theme="light"] .navbar-btn{background:var(--main-color);color:#fff}

/* Cards & panels — add shadow instead of relying on border */
[data-theme="light"] .admin-panel,[data-theme="light"] .flow-card,[data-theme="light"] .share-card,[data-theme="light"] .bundle-card,[data-theme="light"] .auth-card,[data-theme="light"] .file-card,[data-theme="light"] .stat-card,[data-theme="light"] .modal-card{box-shadow:0 2px 12px rgba(0,0,0,.06);border-color:rgba(0,0,0,.06)}
[data-theme="light"] .admin-panel:hover,[data-theme="light"] .flow-card:hover,[data-theme="light"] .file-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.1)}

/* Sub-bg sections — slightly different shade for contrast */
[data-theme="light"] .sub-bg{background:#ededef}
[data-theme="light"] .feat-section{background:#ededef}

/* Drop zone */
[data-theme="light"] .drop-zone{background:#fff;border-color:rgba(0,0,0,.12)}
[data-theme="light"] .drop-zone-border{border-color:rgba(0,0,0,.12)}
[data-theme="light"] .drop-zone:hover .drop-zone-border{border-color:rgba(0,0,0,.2)}
[data-theme="light"] .drop-area{background:#fff;border-color:rgba(0,0,0,.12)}

/* Service icons — dark stroke */
[data-theme="light"] .svc-icon{color:var(--text);border-color:rgba(0,0,0,.06);background:rgba(0,0,0,.02)}
[data-theme="light"] .svc-item:hover .svc-icon{color:var(--main-color);border-color:rgba(224,74,47,.15);background:rgba(224,74,47,.04)}

/* Gradient borders */
[data-theme="light"] .grd-border-top::before,[data-theme="light"] .grd-border-bottom::after{background:linear-gradient(to right,transparent,rgba(0,0,0,.1),transparent)}

/* Form inputs */
[data-theme="light"] .text-input{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.1);color:#1a1a1a}
[data-theme="light"] .text-input:hover{border-color:rgba(0,0,0,.2)}
[data-theme="light"] .text-input:focus{border-color:var(--main-color);box-shadow:0 0 0 3px rgba(224,74,47,.08)}
[data-theme="light"] select.text-input option{background:#fff;color:#1a1a1a}

/* Badges */
[data-theme="light"] .badge-admin{background:rgba(33,150,243,.08);border-color:rgba(33,150,243,.2)}
[data-theme="light"] .badge-user{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.08);color:#666}
[data-theme="light"] .file-ext-sm{background:rgba(224,74,47,.06);border-color:rgba(224,74,47,.12)}

/* Settings */
[data-theme="light"] .settings-tab.active::after{background:var(--main-color)}
[data-theme="light"] .toggle-slider{background:rgba(0,0,0,.08);border-color:rgba(0,0,0,.12)}

/* Upload progress */
[data-theme="light"] .progress-bar-track{background:rgba(0,0,0,.06)}
[data-theme="light"] .file-preview,[data-theme="light"] .result-summary-card,[data-theme="light"] .result-link-card{background:#fff;border-color:rgba(0,0,0,.06);box-shadow:0 1px 6px rgba(0,0,0,.04)}

/* Extension pills */
[data-theme="light"] .ext-pill{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.08);color:#555}
[data-theme="light"] .ext-pill:hover{border-color:var(--main-color);color:var(--main-color);background:rgba(224,74,47,.04)}

/* Stat pills */
[data-theme="light"] .stat-pill{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.06);color:#555}
[data-theme="light"] .stat-pill.stat-accepted{background:rgba(45,138,62,.06);border-color:rgba(45,138,62,.15);color:#2d8a3e}
[data-theme="light"] .stat-pill.stat-skipped{background:rgba(224,74,47,.06);border-color:rgba(224,74,47,.15);color:#e04a2f}

/* Scroll progress */
[data-theme="light"] .scroll-prog-bg{stroke:rgba(0,0,0,.08)}
[data-theme="light"] .scroll-progress{background:#fff;border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.1)}

/* Activity feed */
[data-theme="light"] .activity-row:hover{background:rgba(0,0,0,.02)}

/* Profile danger zone */
[data-theme="light"] .profile-danger{background:rgba(211,47,47,.02);border-color:rgba(211,47,47,.1)}

/* Account prompt */
[data-theme="light"] .account-prompt{background:rgba(45,138,62,.04);border-color:rgba(45,138,62,.1)}

/* Share page cards */
[data-theme="light"] .share-card::before,[data-theme="light"] .bundle-card::before{background:linear-gradient(135deg,rgba(224,74,47,.06),transparent 50%,rgba(45,138,62,.03))}

/* Hero mascot on result */
[data-theme="light"] .result-mascot-img{filter:brightness(0)}
[data-theme="light"] .result-glow{background:radial-gradient(circle,rgba(45,138,62,.06) 0%,transparent 70%)}

/* Skipped notice */
/* Footer */
[data-theme="light"] .site-footer{border-top-color:rgba(0,0,0,.08)}
[data-theme="light"] .site-footer::before{background:linear-gradient(to right,transparent,rgba(0,0,0,.08),transparent)}
[data-theme="light"] .footer-left{color:#555}
[data-theme="light"] .footer-right a{color:#555}
[data-theme="light"] .footer-right a:hover{color:var(--main-color)}
[data-theme="light"] .footer-copy{color:#888;opacity:1}

/* Skipped notice */
[data-theme="light"] .skipped-notice{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}

/* Limits bar */
[data-theme="light"] .drop-limits{background:#fff;border-color:rgba(0,0,0,.06)}

/* How it works — flow card top lines */
[data-theme="light"] .flow-public::before{background:linear-gradient(to right,var(--main-color),rgba(224,74,47,.15))}
[data-theme="light"] .flow-team::before{background:linear-gradient(to right,var(--accent),rgba(45,138,62,.15))}

/* ---- Theme Toggle ---- */
.theme-toggle{background:none;border:1px solid var(--border);width:34px;height:34px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .4s;color:var(--text-muted);flex-shrink:0;padding:0}
.theme-toggle:hover{border-color:var(--main-color);color:var(--main-color)}
.theme-toggle svg{width:16px;height:16px}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
[data-theme="light"] .theme-toggle .icon-sun{display:block}
[data-theme="light"] .theme-toggle .icon-moon{display:none}

/* Smooth theme transition */
body.theme-transitioning,
body.theme-transitioning *{transition:background-color .3s,color .3s,border-color .3s,box-shadow .3s!important}

/* ---- Reset ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
::selection{background:var(--main-color);color:#fff}

body {
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text-body);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
  line-height:1.8;
  overflow-x:hidden;
}

h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:600;color:var(--text);line-height:1.3}
a{color:inherit;text-decoration:none;transition:all .4s}

/* ---- Grain Overlay ---- */
body::after {
  content:'';
  position:fixed;
  inset:0;
  z-index:9999;
  pointer-events:none;
  opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;
  background-size:256px;
}

/* ---- Gradient Border Lines ---- */
.grd-border-top{position:relative}
.grd-border-top::before{content:'';position:absolute;top:0;left:0;width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.3),transparent)}
.grd-border-bottom{position:relative}
.grd-border-bottom::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.3),transparent)}

/* ---- Navbar ---- */
.navbar {
  position:fixed;
  left:0;top:0;
  width:100%;
  padding:0 40px;
  z-index:999;
  border-bottom:1px solid rgba(255,255,255,.05);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  background:rgba(15,15,15,.6);
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:72px;
  transition:all .8s cubic-bezier(.25,.46,.45,.94);
}

.navbar-logo {
  display:flex;align-items:center;gap:10px;
  font-size:1.1rem;font-weight:700;color:var(--text);
  letter-spacing:-.02em;
}
.navbar-logo-img{width:28px;height:28px;object-fit:contain;max-height:28px}

.navbar-links{display:flex;align-items:center;gap:32px}
.navbar-links a {
  color:var(--text-muted);
  font-size:.88rem;font-weight:500;
  letter-spacing:.02em;
  position:relative;
  overflow:hidden;
  display:inline-block;
  padding:4px 0;
}
.navbar-links a:hover{color:var(--text)}

/* Rolling text effect on nav links */
.navbar-links a .rolling-text {
  display:inline-block;
  position:relative;
  transition:transform .5s cubic-bezier(.76,0,.24,1);
}
.navbar-links a:hover .rolling-text {
  transform:translateY(-100%);
}
.navbar-links a .rolling-text::after {
  content:attr(data-text);
  position:absolute;
  top:100%;left:0;
  color:var(--text);
}

.navbar-right{display:flex;align-items:center;gap:16px}

.navbar-avatar{width:30px;height:30px;border-radius:50%;border:1px solid var(--border)}

.navbar-divider{width:1px;height:20px;background:var(--border);margin:0 8px}

/* ---- Buttons ---- */
.butn {
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:1px solid transparent;
  font-family:inherit;font-weight:600;font-size:.88rem;
  cursor:pointer;
  transition:all .4s;
  letter-spacing:.01em;
  white-space:nowrap;
  text-decoration:none;
  color:var(--text);
}

.butn-md{padding:14px 35px}
.butn-sm{padding:8px 20px;font-size:.82rem}
.butn-full{width:100%;padding:15px 25px;text-align:center}
.radius-30{border-radius:30px}
.radius-5{border-radius:5px}

/* Border button — white outline, fills white on hover */
.butn-bord {
  border-color:rgba(255,255,255,.3);
  background:transparent;
  color:#fff;
}
.butn-bord:hover{background:#fff;color:#000;border-color:#fff}

/* Thin border */
.butn-bord-thin {
  border-color:rgba(255,255,255,.12);
  background:transparent;
  color:#fff;
}
.butn-bord-thin:hover{background:#fff;color:#000}

/* Solid color background — inverts to outline on hover */
.butn-bg {
  background:var(--main-color);
  border-color:var(--main-color);
  color:#fff;
}
.butn-bg:hover{background:transparent!important;border-color:#fff;color:#fff!important}

/* Circle button — scale-in orange bg on hover */
.btn-circle {
  border-radius:50%;
  border:1px solid rgba(255,255,255,.3);
  width:56px;height:56px;
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .4s;
  cursor:pointer;
  background:transparent;
  color:#fff;font-size:1rem;
}
.btn-circle::after {
  content:'';position:absolute;inset:0;
  border-radius:50%;background:var(--main-color);
  transform:scale(0);transition:transform .4s;
}
.btn-circle:hover{border-color:var(--main-color)}
.btn-circle:hover::after{transform:scale(1)}
.btn-circle span,.btn-circle i{position:relative;z-index:2;transition:color .4s}

/* CTA button with circle + text */
.butn-crev {
  display:inline-flex;align-items:center;gap:15px;
  cursor:pointer;
  text-decoration:none;
}
.butn-crev .text{font-size:.95rem;font-weight:600;color:var(--text)}
.butn-crev:hover .text{color:var(--main-color)}

/* Legacy btn classes for compatibility */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;border-radius:30px;font-size:.88rem;font-weight:600;border:1px solid transparent;cursor:pointer;transition:all .4s;font-family:inherit;letter-spacing:.01em;white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--main-color);color:#fff;border-color:var(--main-color)}
.btn-primary:hover{background:transparent;color:var(--main-color)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn-outline:hover{background:#fff;color:#000;border-color:#fff}
.btn-sm{padding:7px 16px;font-size:.78rem}
.btn-lg{padding:15px 36px;font-size:.95rem}
.btn-danger{background:transparent;color:var(--danger);border-color:rgba(255,68,68,.3)}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-login{background:var(--main-color);color:#fff;padding:9px 22px;border-radius:30px;font-weight:600;font-size:.82rem;border:1px solid var(--main-color);transition:all .4s}
.btn-login:hover{background:transparent;color:var(--main-color)}
.navbar-links a.navbar-btn{background:var(--main-color);color:#fff!important;padding:9px 24px;border-radius:30px;font-weight:600;font-size:.82rem;border:1px solid var(--main-color);overflow:visible}
.navbar-links a.navbar-btn:hover{background:transparent;color:var(--main-color)!important;border-color:var(--main-color)}
.navbar-links a.navbar-btn::after{display:none}
.btn-logout{color:var(--text-muted)!important;font-size:.82rem}

/* ---- Layout ---- */
.main {
  flex:1;
  max-width:1200px;
  width:100%;
  margin:0 auto;
  padding:48px 40px;
  padding-top:120px;
}

.section-padding{padding:120px 0}
.sub-bg{background:var(--bg-sub)}

/* ---- Sub-title Pattern ---- */
.sub-title {
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:3px;
  font-weight:600;
  color:var(--main-color);
  display:inline-block;
  margin-bottom:12px;
}

/* ---- Section Head ---- */
.sec-head {
  margin-bottom:60px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
}
.sec-head h2{font-size:3rem;font-weight:700;letter-spacing:-.03em;line-height:1.1}
.sec-head h2 .fw-200{font-weight:200}

/* ---- Page Header ---- */
.page-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:60px;padding-bottom:30px;
  position:relative;
}
.page-header::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.2),transparent)}
.page-header h1{font-size:2.8rem;font-weight:700;letter-spacing:-.04em}
.page-header p{color:var(--text-muted);margin-top:4px;font-size:.9rem}

/* ---- Hero / Landing ---- */
.hero {
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  padding:140px 40px 100px;
  overflow:hidden;
}

.hero-content{position:relative;z-index:2;text-align:center;max-width:900px}

.hero-icon{margin-bottom:32px}
.hero-icon img{max-width:120px;max-height:120px;width:auto;height:auto;object-fit:contain}

.hero-title{font-size:5.5rem;font-weight:700;line-height:1.05;letter-spacing:-.05em;margin-bottom:8px}
.hero-title .fw-200{font-weight:200}
.hero-title .main-color{color:var(--main-color)}
.hero-title .stroke{color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.6)}

.hero-sub{font-size:1.15rem;color:var(--text-muted);line-height:1.7;max-width:500px;margin:24px auto 48px}

.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* Decorative blur circles */
.hero::before {
  content:'';position:absolute;
  width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(253,91,56,.08) 0%,transparent 70%);
  top:-100px;right:-100px;
  pointer-events:none;
}
.hero::after {
  content:'';position:absolute;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(202,255,51,.05) 0%,transparent 70%);
  bottom:-50px;left:-100px;
  pointer-events:none;
}

/* ---- Marquee ---- */
.marquee-section{overflow:hidden;position:relative;padding:40px 0}
.marquee-section::before,.marquee-section::after{content:'';position:absolute;top:0;width:200px;height:100%;z-index:2;pointer-events:none}
.marquee-section::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.marquee-section::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.marquee-section.sub-bg::before{background:linear-gradient(to right,var(--bg-sub),transparent)}
.marquee-section.sub-bg::after{background:linear-gradient(to left,var(--bg-sub),transparent)}

.marquee-track{display:flex;width:max-content}
.marquee-track:hover .marquee-box{animation-play-state:paused}
.marquee-box{display:flex;flex-shrink:0;animation:marquee-scroll 20s linear infinite}
.marquee-item{white-space:nowrap;padding:0 32px;font-size:2.5rem;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:32px;flex-shrink:0}
.marquee-item .sep{color:var(--main-color);font-size:1rem}
.marquee-item:nth-child(even){color:transparent;-webkit-text-stroke:.5px rgba(255,255,255,.4)}

@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}

/* ---- Features / Services Section ---- */
.feat-section{padding:120px 0;position:relative;overflow:hidden}
.feat-section::after{content:'';position:absolute;bottom:-200px;left:50%;transform:translateX(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(253,91,56,.04) 0%,transparent 70%);pointer-events:none}
.feat-inner{max-width:1100px;margin:0 auto;padding:0 40px;position:relative;z-index:2}

.feat-head{margin-bottom:80px}
.feat-title{font-size:3.2rem;font-weight:700;letter-spacing:-.04em;line-height:1.1}
.feat-title .fw-200{font-weight:200}
.feat-title .stroke{color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.5)}

/* Service List — horizontal items */
.svc-list{margin-bottom:60px}

.svc-item{display:flex;align-items:flex-start;gap:32px;padding:40px 0;transition:all .4s;position:relative}
.svc-item:hover{padding-left:16px}
.svc-item:hover .svc-num{color:var(--main-color)}
.svc-item:hover h3{color:var(--main-color)}

.svc-num{font-size:1rem;font-weight:700;color:rgba(255,255,255,.15);letter-spacing:.04em;flex-shrink:0;width:40px;padding-top:4px;transition:color .4s}

.svc-body{flex:1;min-width:0}
.svc-body h3{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;margin-bottom:10px;transition:color .4s}
.svc-body h3 .fw-200{font-weight:200}
.svc-body h3 .main-color{color:var(--main-color)}
.svc-body p{font-size:.92rem;color:var(--text-muted);line-height:1.7;max-width:500px}
.svc-body code{font-family:'Plus Jakarta Sans',monospace;background:rgba(255,255,255,.06);padding:2px 8px;border-radius:4px;font-size:.82rem;color:var(--text-body)}

.svc-icon{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid var(--border-thin);transition:all .4s;opacity:.5}
.svc-icon svg{width:24px;height:24px}
.svc-item:hover .svc-icon{border-color:rgba(253,91,56,.2);background:rgba(253,91,56,.05);opacity:1;color:var(--main-color)}

/* CTA with circle button */
.feat-cta{padding-top:20px;display:flex;justify-content:center}

/* ---- How It Works ---- */
.how-section{padding:120px 0;position:relative}
.how-inner{max-width:1100px;margin:0 auto;padding:0 40px}
.how-head{margin-bottom:64px}
.how-lead{font-size:1rem;color:var(--text-muted);margin-top:16px}

.how-flows{display:grid;grid-template-columns:1fr 1fr;gap:28px}

.flow-card{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:20px;padding:0;transition:all .4s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.flow-card:hover{border-color:var(--border);transform:translateY(-3px);box-shadow:0 20px 60px rgba(0,0,0,.3)}

/* Orange accent top line — public */
.flow-public::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--main-color),rgba(253,91,56,.2))}
/* Lime accent top line — team */
.flow-team::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--accent),rgba(202,255,51,.2))}

.flow-top{display:flex;align-items:center;gap:12px;padding:32px 36px 0}
.flow-badge{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(253,91,56,.08);color:var(--main-color);border:1px solid rgba(253,91,56,.15)}
.flow-badge-alt{background:rgba(202,255,51,.06);color:var(--accent);border-color:rgba(202,255,51,.12)}
.flow-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;color:var(--main-color)}
.flow-label-alt{color:var(--accent)}

.flow-card h3{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:8px;padding:16px 36px 0}
.flow-card h3 .fw-200{font-weight:200}
.flow-desc{font-size:.88rem;color:var(--text-muted);padding:0 36px;line-height:1.6}

.flow-divider{height:1px;margin:20px 36px;background:linear-gradient(to right,var(--border),transparent)}

.flow-steps{list-style:none;counter-reset:step;padding:0 36px;flex:1}
.flow-steps li{counter-increment:step;position:relative;padding:11px 0 11px 40px;font-size:.88rem;color:var(--text-body);border-bottom:1px solid var(--border-thin)}
.flow-steps li:last-child{border-bottom:none}
.flow-steps li::before{content:counter(step);position:absolute;left:0;top:11px;width:24px;height:24px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:var(--text-muted);transition:all .3s}
.flow-steps li:hover::before{border-color:var(--main-color);color:var(--main-color)}
.flow-team .flow-steps li:hover::before{border-color:var(--accent);color:var(--accent)}
.flow-step-text{display:block}
.flow-code{font-family:'Plus Jakarta Sans',monospace;background:rgba(255,255,255,.06);padding:1px 8px;border-radius:4px;font-size:.82rem;color:var(--main-color)}

.flow-bottom{padding:24px 36px 32px}

/* ---- Get Started ---- */
.start-section{padding:120px 0;text-align:center;position:relative;overflow:hidden}
.start-section::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(202,255,51,.04) 0%,transparent 70%);bottom:-150px;left:50%;transform:translateX(-50%);pointer-events:none}
.start-inner{max-width:640px;margin:0 auto;padding:0 40px;position:relative;z-index:2}
.start-title{font-size:2.8rem;font-weight:700;letter-spacing:-.04em;margin-bottom:40px;color:var(--text)}
.start-title .main-color{color:var(--main-color)}

/* Terminal window */
.terminal{border-radius:14px;overflow:hidden;border:1px solid var(--border);margin-bottom:28px;box-shadow:0 12px 48px rgba(0,0,0,.4)}
.terminal-bar{display:flex;align-items:center;gap:7px;padding:12px 16px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--border-thin)}
.terminal-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.1)}
.terminal-dot:first-child{background:#ff5f57}
.terminal-dot:nth-child(2){background:#ffbd2e}
.terminal-dot:nth-child(3){background:#28c840}
.terminal-title{font-size:.68rem;color:var(--text-muted);margin-left:auto;letter-spacing:.04em}
.terminal-body{padding:24px 28px;background:var(--bg);text-align:left}

.code-line{font-family:'Plus Jakarta Sans',monospace;font-size:.85rem;color:var(--text-body);padding:5px 0;letter-spacing:.02em}
.code-prompt{color:var(--main-color);margin-right:10px;font-weight:700}
.code-comment{color:var(--text-muted);opacity:.5}
.code-comment .code-prompt{color:var(--text-muted);opacity:.6}
.code-output{color:var(--text-muted);opacity:.7;padding-left:2px}

.start-note{font-size:.9rem;color:var(--text-muted);margin-bottom:32px}
.start-note code{font-family:'Plus Jakarta Sans',monospace;background:rgba(255,255,255,.06);padding:2px 8px;border-radius:4px;font-size:.82rem;color:var(--text-body)}
.start-buttons{display:flex;justify-content:center;gap:16px}

/* ---- Upload Zone ---- */
.upload-zone {
  background:var(--bg-sub);
  border:1px dashed rgba(255,255,255,.15);
  border-radius:16px;
  padding:80px 40px;
  text-align:center;
  cursor:pointer;
  transition:all .4s;
  min-height:360px;
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  position:relative;overflow:hidden;
}
.upload-zone::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(253,91,56,.06) 0%,transparent 70%);opacity:0;transition:opacity .4s}
.upload-zone:hover::before,.upload-zone.drag-over::before{opacity:1}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--main-color)}

.upload-icon{font-size:3rem;margin-bottom:16px;position:relative;z-index:1}
.upload-text{font-size:1.15rem;font-weight:600;margin-bottom:6px;color:var(--text);position:relative;z-index:1}
.upload-hint{color:var(--text-muted);font-size:.9rem;position:relative;z-index:1}
.upload-exts-label{color:var(--text-muted);font-size:.82rem;margin-top:16px;position:relative;z-index:1}
.upload-exts{color:var(--text-muted);font-size:.72rem;margin-top:8px;max-width:440px;line-height:1.8;letter-spacing:.02em;opacity:.7;position:relative;z-index:1}

/* ---- Progress ---- */
.progress-bar-track{width:100%;height:3px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden;margin-bottom:10px}
.progress-bar-fill{height:100%;width:0;background:var(--main-color);border-radius:99px;transition:width .3s ease}

/* ---- Share / Result ---- */
.file-name{font-weight:600;margin-bottom:16px;word-break:break-all;font-size:.92rem;color:var(--text)}
.progress-text{font-size:.82rem;color:var(--text-muted);font-weight:500}
.result-icon{width:64px;height:64px;background:rgba(202,255,51,.1);color:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto 16px;border:1px solid rgba(202,255,51,.15)}
.result-title{font-size:1.8rem;font-weight:700;margin-bottom:24px;color:var(--text);letter-spacing:-.03em}
.error-icon{width:64px;height:64px;background:rgba(255,68,68,.08);color:var(--danger);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto 16px;border:1px solid rgba(255,68,68,.15)}
.error-message{color:var(--danger);margin-bottom:16px;font-weight:500}

/* ---- Share Link Box ---- */
.share-link-box{display:flex;gap:8px;margin-bottom:16px}
.share-link-box.compact{margin-bottom:0}
.share-input{flex:1;padding:11px 18px;border:1px solid var(--border);border-radius:30px;font-size:.82rem;font-family:inherit;background:rgba(255,255,255,.03);color:var(--text);outline:none;min-width:0;transition:border-color .4s}
.share-input:focus{border-color:var(--main-color)}

/* ---- File Grid (Dashboard) ---- */
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.file-card{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:16px;overflow:hidden;transition:all .4s}
.file-card:hover{border-color:var(--border);transform:translateY(-3px)}
.file-card-top{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 0}
.file-ext{background:rgba(253,91,56,.1);color:var(--main-color);padding:4px 14px;border-radius:30px;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.file-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:6px;border-radius:50%;transition:all .15s;line-height:1}
.file-delete:hover{color:var(--danger);background:rgba(255,68,68,.08)}
.file-card-body{padding:16px 22px}
.file-card-body .file-name{font-weight:600;font-size:.92rem;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.file-meta{display:flex;gap:14px;font-size:.78rem;color:var(--text-muted);margin-bottom:4px}
.file-card-actions{padding:0 22px 18px}

/* ---- Empty State ---- */
.empty-state{text-align:center;padding:100px 20px;color:var(--text-muted)}
.empty-icon{font-size:3rem;margin-bottom:20px;opacity:.7}
.empty-state p{margin-bottom:24px;font-size:1.05rem}

/* ---- Share Page ---- */
.share-page{display:flex;align-items:center;justify-content:center;min-height:60vh}
.share-card,.bundle-card{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:16px;padding:60px 48px;text-align:center;max-width:460px;width:100%;position:relative}
.share-card::before,.bundle-card::before{content:'';position:absolute;inset:-1px;border-radius:16px;background:linear-gradient(135deg,rgba(253,91,56,.1),transparent 50%,rgba(202,255,51,.05));z-index:-1}
.bundle-card{max-width:660px}
.share-logo{max-width:48px;max-height:48px;width:auto;height:auto;object-fit:contain;margin-bottom:20px}
.share-file-ext{display:inline-block;background:rgba(253,91,56,.1);color:var(--main-color);padding:6px 20px;border-radius:30px;font-size:.72rem;font-weight:700;letter-spacing:.08em;margin-bottom:16px;text-transform:uppercase}
.share-file-name{font-size:1.3rem;word-break:break-all;margin-bottom:12px;color:var(--text);font-weight:700;letter-spacing:-.02em}
.share-meta{display:flex;gap:20px;justify-content:center;color:var(--text-muted);font-size:.82rem;margin-bottom:36px}
.share-disclaimer{margin-top:28px;font-size:.7rem;color:var(--text-muted);opacity:.7;letter-spacing:.08em;text-transform:uppercase}

/* ---- Bundle Tree ---- */
.bundle-tree{text-align:left;margin-top:36px;border:1px solid var(--border-thin);border-radius:12px;overflow:hidden}
.tree-item{padding:11px 18px;font-size:.85rem;border-bottom:1px solid var(--border-thin);display:flex;align-items:center;gap:8px;transition:background .3s}
.tree-item:last-child{border-bottom:none}
.tree-item:hover{background:rgba(255,255,255,.02)}
.tree-folder{font-weight:600;color:var(--text)}
.tree-file{color:var(--text-body)}
.tree-ext{background:rgba(253,91,56,.08);color:var(--main-color);padding:2px 8px;border-radius:4px;font-size:.65rem;font-weight:700;letter-spacing:.04em;flex-shrink:0}
.tree-file-link{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-body)}
.tree-file-link:hover{color:var(--main-color)}
.tree-size{font-size:.72rem;color:var(--text-muted);flex-shrink:0;margin-left:auto}
.tree-empty{padding:32px;text-align:center;color:var(--text-muted)}

/* ---- Auth Pages ---- */
.auth-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:40px 20px}
.auth-card{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:20px;padding:48px 44px;max-width:420px;width:100%;position:relative;overflow:hidden}
.auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--main-color),transparent)}
.auth-logo{margin-bottom:24px}
.auth-logo-img{max-width:72px;max-height:72px;width:auto;height:auto;object-fit:contain}
.auth-title{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}
.auth-desc{font-size:.88rem;color:var(--text-muted);margin-bottom:28px}

.auth-error{background:rgba(255,68,68,.08);border:1px solid rgba(255,68,68,.15);color:var(--danger);padding:10px 16px;border-radius:8px;font-size:.85rem;margin-bottom:20px}

.auth-form{display:flex;flex-direction:column;gap:18px}
.auth-field .input-label{margin-bottom:6px}

.auth-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:.78rem}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border-thin)}

/* Google Sign-In button — follows Google branding guidelines */
.google-signin-btn{
  display:flex;align-items:center;justify-content:center;width:100%;
  height:44px;border-radius:22px;text-decoration:none;cursor:pointer;
  background:#131314;border:1px solid #8e918f;
  transition:background .2s,border-color .2s;
  font-family:'Roboto',system-ui,sans-serif;
}
.google-signin-btn:hover{background:#1f1f1f;border-color:#aaa}
.google-signin-icon{
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;background:#fff;border-radius:50%;
  margin-right:10px;flex-shrink:0;
}
.google-signin-text{
  font-size:14px;font-weight:500;color:#e3e3e3;letter-spacing:.25px;
}
/* Light mode variant */
[data-theme="light"] .google-signin-btn{background:#fff;border-color:#747775}
[data-theme="light"] .google-signin-btn:hover{background:#f6f6f6}
[data-theme="light"] .google-signin-icon{background:#fff}
[data-theme="light"] .google-signin-text{color:#1f1f1f}

.auth-alt{text-align:center;margin-top:24px;font-size:.85rem;color:var(--text-muted)}
.auth-alt a{color:var(--main-color);font-weight:600}
.auth-alt a:hover{text-decoration:underline}

/* ---- Admin Dashboard ---- */
.admin-hero{padding:140px 40px 60px;position:relative;overflow:hidden}
.admin-hero::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(253,91,56,.05) 0%,transparent 70%);top:-200px;right:-100px;pointer-events:none}
.admin-hero-inner{max-width:1100px;margin:0 auto;position:relative;z-index:2}
.admin-title{font-size:3rem;font-weight:700;letter-spacing:-.04em;line-height:1.1}

.admin-body{padding:0 40px 80px}
.admin-inner{max-width:1100px;margin:0 auto}

/* Stats row */
.admin-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:48px}
.admin-stat{display:flex;align-items:center;gap:14px;background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:14px;padding:20px 22px;transition:border-color .4s}
.admin-stat:hover{border-color:var(--border)}
.admin-stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(253,91,56,.06);color:var(--main-color);flex-shrink:0;border:1px solid rgba(253,91,56,.1)}
.admin-stat-info{min-width:0}
.admin-stat-value{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1.2}
.admin-stat-label{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}

/* Panels */
.admin-panel{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:16px;overflow:hidden;margin-bottom:28px;transition:border-color .4s}
.admin-panel:hover{border-color:rgba(255,255,255,.1)}
.admin-panel-head{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;border-bottom:1px solid var(--border-thin)}
.admin-panel-head h2{font-size:1.1rem;font-weight:600;letter-spacing:-.01em;margin:0;display:flex;align-items:center;gap:10px}
.admin-panel-head h2::before{content:'';width:3px;height:18px;background:var(--main-color);border-radius:2px}
.admin-panel-count{font-size:.72rem;font-weight:700;color:var(--text-muted);background:rgba(255,255,255,.04);padding:4px 14px;border-radius:30px;border:1px solid var(--border-thin)}
.admin-panel-body{padding:0}
.collapsible .admin-panel-head{cursor:pointer;user-select:none}
.collapsible .admin-panel-head:hover{background:rgba(255,255,255,.02)}
[data-theme="light"] .collapsible .admin-panel-head:hover{background:rgba(0,0,0,.02)}
.collapse-chevron{color:var(--muted);transition:transform .3s ease;flex-shrink:0}
.collapsible:not(.collapsed) .collapse-chevron{transform:rotate(180deg)}
.admin-panel-collapse{overflow:hidden;max-height:2000px;opacity:1;transition:max-height .4s ease,opacity .3s ease}
.collapsed .admin-panel-collapse{max-height:0;opacity:0}
.collapsed .admin-panel-head{border-bottom:none}
.admin-empty{padding:48px 28px;text-align:center;color:var(--text-muted);font-size:.9rem;opacity:.7}

/* User rows */
.admin-user-row{display:flex;align-items:center;gap:16px;padding:18px 28px;border-bottom:1px solid var(--border-thin);transition:all .4s}
.admin-user-row:last-child{border-bottom:none}
.admin-user-row:hover{background:rgba(255,255,255,.02);padding-left:32px}
.admin-user-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.admin-user-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;border:1px solid var(--border-thin)}
.admin-user-avatar img{width:100%;height:100%;object-fit:cover}
.admin-user-initial{font-size:.82rem;font-weight:700;color:var(--text-muted)}
.admin-user-name{font-size:.9rem;font-weight:600;color:var(--text)}
.admin-user-email{font-size:.78rem;color:var(--text-muted)}
.admin-user-meta{display:flex;align-items:center;gap:16px;flex-shrink:0}
.admin-user-date{font-size:.75rem;color:var(--text-muted)}
.admin-user-actions{flex-shrink:0}
.admin-you-badge{font-size:.72rem;color:var(--text-muted);background:rgba(255,255,255,.04);padding:4px 14px;border-radius:20px}

/* File/Bundle rows */
.admin-file-row{display:flex;align-items:center;gap:16px;padding:16px 28px;border-bottom:1px solid var(--border-thin);transition:all .4s}
.admin-file-row:last-child{border-bottom:none}
.admin-file-row:hover{background:rgba(255,255,255,.02);padding-left:32px}
.admin-file-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.admin-file-name{font-size:.88rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-file-by{font-size:.75rem;color:var(--text-muted)}
.admin-file-meta{display:flex;align-items:center;gap:16px;flex-shrink:0}
.admin-file-size{font-size:.82rem;color:var(--text-body);font-weight:500}
.admin-file-dls{font-size:.72rem;color:var(--text-muted)}
.admin-file-actions{display:flex;gap:8px;flex-shrink:0}

/* Shared badges — bordered pill style */
.badge{display:inline-block;padding:5px 15px;border-radius:30px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border:1px solid transparent;transition:all .4s}
.badge-admin{background:rgba(33,150,243,.12);color:#64b5f6;border-color:rgba(33,150,243,.25)}
.badge-user{background:rgba(255,255,255,.04);color:var(--text-muted);border-color:var(--border-thin)}
.badge-active{background:rgba(76,175,80,.1);color:#81c784;border-color:rgba(76,175,80,.25)}
.badge-suspended{background:rgba(244,67,54,.1);color:#e57373;border-color:rgba(244,67,54,.25)}
.badge-ok{background:rgba(76,175,80,.1);color:#81c784;border-color:rgba(76,175,80,.25)}
.badge-err{background:rgba(244,67,54,.1);color:#e57373;border-color:rgba(244,67,54,.25)}
.badge-warn{background:rgba(255,152,0,.1);color:#ffb74d;border-color:rgba(255,152,0,.25)}
.badge-info{background:rgba(255,255,255,.03);color:var(--text-muted);border-color:var(--border-thin)}
.file-ext-sm{display:inline-block;background:rgba(253,91,56,.06);color:var(--main-color);padding:5px 12px;border-radius:30px;font-size:.65rem;font-weight:700;flex-shrink:0;border:1px solid rgba(253,91,56,.15);letter-spacing:.04em}
.text-muted{color:var(--text-muted);font-size:.82rem}

/* ---- Settings Panel ---- */
.settings-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-thin);overflow-x:auto}
.settings-tab{background:none;border:none;padding:14px 24px;font-family:inherit;font-size:.82rem;font-weight:600;color:var(--text-muted);cursor:pointer;position:relative;transition:color .3s;white-space:nowrap}
.settings-tab:hover{color:var(--text)}
.settings-tab.active{color:var(--main-color)}
.settings-tab.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--main-color)}

.settings-pane{display:none;padding:28px}
.settings-pane.active{display:block}

.settings-group{display:flex;flex-direction:column;gap:20px}
.settings-field{display:grid;grid-template-columns:220px 1fr;align-items:center;gap:16px}
.settings-field .text-input{width:100%}
.settings-field select.text-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
select.text-input option{background:var(--bg,#0f0f0f);color:var(--text,#e8e8e8)}
.settings-textarea{width:100%;resize:vertical;min-height:60px;font-family:inherit}
/* Extension category picker */
.ext-categories{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.ext-cat-btn{font-size:.78rem;padding:5px 14px;border-radius:20px;border:1px solid var(--border-thin);background:none;color:var(--muted);cursor:pointer;font-family:inherit;font-weight:500;transition:all .2s;user-select:none}
.ext-cat-btn.active{background:var(--main-color);color:#fff;border-color:var(--main-color)}
.ext-cat-btn:not(.active):hover{border-color:var(--main-color);color:var(--main-color)}
.ext-selected{display:flex;flex-wrap:wrap;gap:4px;min-height:32px;padding:8px 10px;border:1px solid var(--border-thin);border-radius:8px;background:var(--bg-sub)}
.ext-tag{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;padding:2px 8px;border-radius:12px;background:rgba(255,255,255,.06);color:var(--body-color);border:1px solid var(--border-thin);font-weight:500}
.ext-tag-rm{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;padding:0 2px;line-height:1;transition:color .2s}
.ext-tag-rm:hover{color:var(--danger)}
[data-theme="light"] .ext-tag{background:rgba(0,0,0,.04)}

.tpl-mode-toggle{display:inline-flex;border:1px solid var(--border-thin);border-radius:8px;overflow:hidden}
.tpl-mode-btn{background:none;border:none;padding:6px 16px;font-size:.82rem;font-weight:500;color:var(--muted);cursor:pointer;font-family:inherit;transition:all .2s}
.tpl-mode-btn.active{background:var(--main-color);color:#fff}
.tpl-mode-btn:not(.active):hover{background:rgba(255,255,255,.04)}
[data-theme="light"] .tpl-mode-btn:not(.active):hover{background:rgba(0,0,0,.04)}

.size-input-group{display:flex;gap:8px;width:100%}
.size-input-group .text-input{flex:1}
.size-input-group .size-unit{width:80px;flex:none}

.settings-label{font-size:.88rem;font-weight:500;color:var(--text);display:flex;align-items:center;gap:8px;min-width:180px;flex-shrink:0}
.settings-hint{font-size:.72rem;color:var(--text-muted);font-weight:400}

.restart-badge{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--main-color);background:rgba(253,91,56,.08);padding:2px 8px;border-radius:20px}

.settings-divider{height:1px;background:var(--border-thin);margin:4px 0}

.settings-actions{margin-top:28px;display:flex;gap:12px;align-items:center}
.settings-msg-inline{font-size:.82rem;font-weight:500;margin-left:12px;transition:opacity .4s ease}
.msg-ok{color:var(--accent,#caff33)}
.msg-err{color:var(--danger,#ff4444)}

.settings-msg{padding:14px 22px;border-radius:8px;font-size:.85rem;margin:12px 28px;border-left:3px solid transparent}
.settings-msg-ok{background:rgba(76,175,80,.06);color:#81c784;border-color:rgba(76,175,80,.15);border-left-color:#4caf50}
.settings-msg-err{background:rgba(244,67,54,.06);color:#e57373;border-color:rgba(244,67,54,.15);border-left-color:#f44336}

/* Toggle switch */
.toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:rgba(255,255,255,.06);border-radius:24px;transition:all .4s;border:1px solid rgba(255,255,255,.1)}
.toggle-slider::before{content:'';position:absolute;height:18px;width:18px;left:2px;bottom:2px;background:var(--text-muted);border-radius:50%;transition:all .4s}
.toggle:hover .toggle-slider{border-color:rgba(255,255,255,.2)}
.toggle input:checked+.toggle-slider{background:rgba(253,91,56,.15);border-color:var(--main-color)}
.toggle input:checked+.toggle-slider::before{transform:translateX(20px);background:var(--main-color);box-shadow:0 0 8px rgba(253,91,56,.4)}

/* ---- Error Page ---- */
.error-page{text-align:center;padding:80px 20px;max-width:500px;margin:0 auto}
.error-mascot{margin-bottom:24px}
.error-mascot-img{width:80px;height:auto;opacity:.6}
[data-theme="light"] .error-mascot-img{filter:brightness(0);opacity:.3}
.error-heading{font-size:2.2rem;font-weight:700;margin-bottom:12px;letter-spacing:-.03em}
.error-message{color:var(--text-muted);margin-bottom:32px;font-size:1rem;line-height:1.6}
.error-actions{display:flex;gap:12px;justify-content:center;margin-bottom:40px}
.error-help{padding-top:32px;border-top:1px solid var(--border-thin)}
.error-help p{font-size:.85rem;color:var(--text-muted);margin-bottom:12px}
.error-links{display:flex;gap:20px;justify-content:center}
.error-links a{font-size:.85rem;color:var(--main-color);font-weight:600;transition:opacity .3s}
.error-links a:hover{opacity:.7}

/* ---- Maintenance Page ---- */
.maint-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}
.maint-card{text-align:center;max-width:480px;width:100%}
.maint-mascot{margin-bottom:20px}
.maint-mascot-img{width:56px;height:auto;opacity:.5}
[data-theme="light"] .maint-mascot-img{filter:brightness(0);opacity:.3}
.maint-icon{color:var(--main-color);margin-bottom:24px;opacity:.7}
.maint-title{font-size:2.4rem;font-weight:700;letter-spacing:-.04em;margin-bottom:12px}
.maint-sub{color:var(--text-muted);font-size:1rem;line-height:1.6;margin-bottom:28px;max-width:380px;margin-left:auto;margin-right:auto}
.maint-status{display:inline-flex;align-items:center;gap:10px;padding:8px 20px;border-radius:30px;background:rgba(253,91,56,.06);border:1px solid rgba(253,91,56,.15);font-size:.82rem;font-weight:600;color:var(--main-color);margin-bottom:32px}
.maint-dot{width:8px;height:8px;border-radius:50%;background:var(--main-color);animation:maintPulse 1.5s ease infinite}
@keyframes maintPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.maint-tip{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:12px;padding:20px 24px;margin-bottom:28px;text-align:left}
.maint-tip p{font-size:.85rem;color:var(--text-muted);margin-bottom:10px;font-weight:600}
.maint-tip ul{list-style:none;padding:0;margin:0}
.maint-tip li{font-size:.85rem;color:var(--text-body);padding:4px 0 4px 20px;position:relative}
.maint-tip li::before{content:'';position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--main-color);opacity:.5}
[data-theme="light"] .maint-status{background:rgba(224,74,47,.06);border-color:rgba(224,74,47,.12)}
[data-theme="light"] .maint-tip{background:#fff;border-color:rgba(0,0,0,.06);box-shadow:0 2px 8px rgba(0,0,0,.04)}

/* ---- Public Upload Form (Drop) ---- */
.public-upload-form{max-width:700px;margin:0 auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px}
.input-label{display:block;font-size:.72rem;font-weight:600;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}
.text-input{width:100%;padding:14px 20px;border:1px solid rgba(255,255,255,.08);border-radius:8px;font-size:.9rem;font-family:inherit;background:rgba(255,255,255,.02);color:var(--text);outline:none;transition:all .4s}
.text-input:hover{border-color:rgba(255,255,255,.15)}
.text-input:focus{border-color:var(--main-color);box-shadow:0 0 0 3px rgba(253,91,56,.08)}
.text-input:focus{border-color:var(--main-color)}
.text-input::placeholder{color:var(--text-muted);opacity:.6}

.drop-area{border:1px dashed rgba(255,255,255,.15);border-radius:16px;padding:64px 32px;text-align:center;cursor:pointer;transition:all .4s;position:relative;overflow:hidden;background:var(--bg-sub)}
.drop-area::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(253,91,56,.06) 0%,transparent 70%);opacity:0;transition:opacity .4s}
.drop-area:hover::before,.drop-area.drag-over::before{opacity:1}
.drop-area:hover,.drop-area.drag-over{border-color:var(--main-color)}
.drop-btns{display:flex;gap:12px;justify-content:center;margin-top:20px;position:relative;z-index:1}

.file-preview{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:16px;padding:32px}
.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.preview-header h3{font-size:1.15rem;font-weight:600}
.preview-stats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.stat-pill{padding:5px 16px;border-radius:30px;font-size:.72rem;font-weight:600;background:rgba(255,255,255,.04);color:var(--text-body);border:1px solid var(--border-thin)}
.stat-pill.stat-accepted{background:rgba(202,255,51,.08);color:var(--accent);border-color:rgba(202,255,51,.15)}
.stat-pill.stat-skipped{background:rgba(253,91,56,.08);color:var(--main-color);border-color:rgba(253,91,56,.15)}

.skipped-notice{margin-bottom:20px;background:rgba(255,255,255,.02);border-radius:10px;padding:14px 18px;border:1px solid var(--border-thin)}
.skipped-notice summary{cursor:pointer;font-size:.82rem;color:var(--text-muted);font-weight:500}
.skipped-list{list-style:none;margin-top:10px;max-height:200px;overflow-y:auto}
.skipped-list li{font-size:.78rem;padding:5px 0;display:flex;justify-content:space-between;border-bottom:1px solid var(--border-thin)}
.skipped-path{color:var(--text-body)}
.skipped-reason{color:var(--text-muted);font-size:.72rem;flex-shrink:0;margin-left:12px}

.folder-tree{border:1px solid var(--border-thin);border-radius:10px;overflow:hidden;max-height:300px;overflow-y:auto;margin-bottom:20px}
.preview-summary{font-size:.85rem;color:var(--text-muted);margin-bottom:24px}

.upload-progress-panel{max-width:500px;margin:0 auto;text-align:center;padding:80px 20px}
.upload-progress-panel h2{font-size:1.5rem;margin-bottom:32px;letter-spacing:-.02em}
.dot-anim{animation:dotPulse 1.4s infinite}
@keyframes dotPulse{0%,20%{opacity:0}50%{opacity:1}100%{opacity:0}}
.progress-details{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-muted);margin-top:10px}
.progress-current{font-size:.78rem;color:var(--text-muted);margin-top:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.progress-live-stats{font-size:.78rem;color:var(--text-muted);margin-top:8px;opacity:.6}

.upload-result-panel{max-width:500px;margin:0 auto;text-align:center;padding:80px 20px}
.result-summary-card{background:rgba(255,255,255,.02);border:1px solid var(--border-thin);border-radius:12px;padding:24px;margin-bottom:28px;text-align:left}
.summary-row{display:flex;justify-content:space-between;padding:9px 0;font-size:.85rem;color:var(--text-body);border-bottom:1px solid var(--border-thin)}
.summary-row:last-child{border-bottom:none}
.summary-row strong{color:var(--text);font-weight:600}
.summary-row.summary-skip strong{color:var(--main-color)}
.summary-row.summary-err strong{color:var(--danger)}
.summary-errors{list-style:none;padding:8px 0;font-size:.78rem;color:var(--danger)}
.email-sent-notice{font-size:.85rem;color:var(--accent);margin-bottom:16px}
.result-instructions{margin-top:20px;margin-bottom:28px}
.result-instructions h4{font-size:.72rem;font-weight:600;margin-bottom:6px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}
.result-instructions p{font-size:.85rem;color:var(--text-muted)}

/* ---- Footer ---- */
.site-footer {
  position:relative;
  border-top:1px solid var(--border-thin);
  padding:60px 40px 30px;
  margin-top:auto;
}
.site-footer::before{content:'';position:absolute;top:0;left:0;width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.15),transparent)}
.site-footer::after{content:'';position:absolute;bottom:0;right:60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(253,91,56,.04) 0%,transparent 70%);pointer-events:none}

.footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.footer-left{font-size:.78rem;color:var(--text-muted);letter-spacing:.04em;display:flex;align-items:center;gap:8px}
.footer-logo-img{width:20px;height:20px;object-fit:contain;max-height:20px}
.footer-right{display:flex;gap:24px}
.footer-right a{font-size:.78rem;color:var(--text-muted);transition:color .4s;letter-spacing:.02em}
.footer-right a:hover{color:var(--text)}
.footer-copy{text-align:center;margin-top:40px;padding-top:24px;border-top:1px solid var(--border-thin);font-size:.72rem;color:var(--text-muted);opacity:.7}

/* Legacy footer class */
.footer{text-align:center;padding:28px;font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--border-thin);letter-spacing:.04em;opacity:.7}

/* ---- Drop Page ---- */
.drop-hero{padding:100px 40px 40px;text-align:center;position:relative;overflow:hidden}
.drop-hero::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(253,91,56,.06) 0%,transparent 70%);top:-200px;left:50%;transform:translateX(-50%);pointer-events:none}
.drop-hero-content{position:relative;z-index:2;max-width:600px;margin:0 auto}
.drop-title{font-size:2.8rem;font-weight:700;letter-spacing:-.04em;line-height:1.1;margin-bottom:12px;color:var(--text)}
.drop-title .fw-200{font-weight:200}
.drop-subtitle{font-size:1.05rem;color:var(--text-muted);line-height:1.7}

.drop-section{padding:0 40px 48px;transition:opacity .3s,transform .3s}
.drop-container{max-width:720px;margin:0 auto}

/* Fade-in animation */
.fade-in{transition:opacity .4s ease,transform .4s ease}

.drop-step{display:flex;gap:20px;margin-bottom:36px;position:relative;transition:opacity .3s,transform .3s}
.drop-step::before{content:'';position:absolute;left:14px;top:32px;bottom:-36px;width:1px;background:linear-gradient(to bottom,rgba(255,255,255,.06),transparent);pointer-events:none}
.drop-step:last-child::before{display:none}

.drop-step-num{width:30px;height:30px;border-radius:50%;border:1px solid var(--border-thin);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:var(--text-muted);flex-shrink:0;background:var(--bg);position:relative;z-index:2;letter-spacing:.04em;transition:all .4s}
.step-num-active{background:var(--main-color);color:#fff;border-color:var(--main-color)}
.drop-step-content{flex:1;min-width:0}
.drop-step-title{font-size:1.2rem;font-weight:600;margin-bottom:16px;letter-spacing:-.02em}
.drop-step-title .fw-200{font-weight:200}

.drop-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.drop-field .input-label{margin-bottom:6px;font-size:.82rem}

/* More options toggle */
.drop-more-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-muted);font-size:.82rem;cursor:pointer;padding:4px 0;margin-top:4px;transition:color .2s;font-family:inherit}
.drop-more-toggle:hover{color:var(--main-color)}
.drop-more-toggle svg{transition:transform .3s}
.drop-more-toggle.open svg{transform:rotate(180deg)}
.drop-more-fields{overflow:hidden;max-height:0;opacity:0;transition:max-height .35s ease,opacity .25s ease,margin .25s ease;margin-top:0}
.drop-more-fields.show{max-height:300px;opacity:1;margin-top:12px}

/* Drop Zone — animated marching border */
.drop-zone{border:none;border-radius:16px;padding:0;overflow:hidden;transition:all .4s;position:relative;background:var(--bg-sub)}
.drop-zone::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(253,91,56,.05) 0%,transparent 70%);opacity:0;transition:opacity .5s;z-index:0}
.drop-zone:hover::before,.drop-zone.drag-over::before{opacity:1}

/* Animated dashed border overlay */
.drop-zone-border{position:absolute;inset:0;border-radius:16px;pointer-events:none;z-index:1}
.drop-zone-border{background:none;border:2px dashed rgba(255,255,255,.1);border-radius:16px;transition:border-color .4s}
.drop-zone:hover .drop-zone-border{border-color:rgba(255,255,255,.2)}
.drop-zone.drag-over .drop-zone-border{border-color:var(--main-color);border-style:solid;animation:borderPulse 1s ease infinite}
@keyframes borderPulse{0%,100%{border-color:var(--main-color)}50%{border-color:rgba(253,91,56,.4)}}

/* Drag state — icon bounce & zone scale */
.drop-zone.drag-over{transform:scale(1.01)}
.drop-zone.drag-over .drop-zone-icon{color:var(--main-color);animation:iconBounce .6s ease infinite}
@keyframes iconBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

.drop-zone-inner{padding:40px 28px 16px;text-align:center;cursor:pointer;position:relative;z-index:2}
.drop-zone-icon{margin-bottom:14px;color:var(--text-muted);transition:all .4s}
.drop-zone-title{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:4px}
.drop-zone-hint{font-size:.82rem;color:var(--text-muted);margin-bottom:16px}

/* Extension pills */
.drop-zone-exts{text-align:center;margin-top:4px}
.drop-zone-exts-label{display:none}
.ext-pills{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:420px;margin:0 auto}
.ext-pill{font-size:.62rem;padding:2px 8px;border-radius:20px;background:rgba(255,255,255,.03);color:var(--text-muted);border:1px solid var(--border-thin);font-weight:500;letter-spacing:.02em;transition:all .3s}
.ext-pill:hover{border-color:var(--main-color);color:var(--main-color);background:rgba(253,91,56,.06)}
.ext-more{font-size:.72rem;color:var(--text-muted);cursor:pointer;padding:2px 0;transition:color .2s}
.ext-more:hover{color:var(--main-color)}

.drop-zone-actions{display:flex;gap:10px;justify-content:center;padding:16px 28px 24px;position:relative;z-index:2}

/* Upload limits bar */
.drop-limits{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:14px;padding:10px 20px;border-radius:8px;font-size:.78rem;color:var(--text-muted)}
.limit-item{text-align:center}
.limit-label{display:none}
.limit-value{font-size:.78rem;font-weight:600;color:var(--text-muted)}
.limit-sep{width:3px;height:3px;border-radius:50%;background:var(--border);flex-shrink:0}

/* Trust line */
.drop-trust{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:10px;font-size:.72rem;color:var(--text-muted);opacity:.5}
.drop-trust svg{opacity:.4;flex-shrink:0}

/* Preview */
.preview-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.preview-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:8px}
.preview-footer .preview-summary{margin-bottom:0}

/* Progress — ring indicator */
.progress-card{text-align:center;padding:60px 20px;max-width:500px;margin:0 auto}
.progress-ring{position:relative;width:64px;height:64px;margin:0 auto 28px}
.progress-ring svg{display:block}
.progress-ring circle{transition:stroke-dashoffset .3s ease}
.progress-ring-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--main-color)}
.progress-title{font-size:1.6rem;font-weight:600;margin-bottom:32px;letter-spacing:-.02em}

/* Result — with glow */
.result-card{text-align:center;max-width:500px;margin:0 auto;padding:40px 0;position:relative}
.result-glow{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(202,255,51,.06) 0%,transparent 70%);pointer-events:none;animation:glowPulse 3s ease infinite}
@keyframes glowPulse{0%,100%{opacity:.6;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.1)}}
.result-card .result-icon{width:80px;height:80px;font-size:2rem;margin-bottom:24px;position:relative;z-index:2}
.result-card .result-title{margin-bottom:32px;position:relative;z-index:2;font-size:2.2rem}
.result-link-card{background:var(--bg-sub);border:1px solid var(--border-thin);border-radius:12px;padding:20px 24px;margin-bottom:20px;position:relative;z-index:2}
.result-link-label{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600;margin-bottom:10px}
.result-link-card .share-link-box{margin-bottom:0}
.result-next{margin:20px 0 28px;position:relative;z-index:2}
.result-next p{font-size:.88rem;color:var(--text-muted);line-height:1.6}
.summary-err-item{font-size:.78rem;color:var(--danger);padding:4px 0}

/* Per-file status list */
.file-status-list{margin-top:24px;max-height:280px;overflow-y:auto;border:1px solid var(--border-thin);border-radius:10px}
.fsl-row{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--border-thin);font-size:.82rem;transition:background .2s}
.fsl-row:last-child{border-bottom:none}
.fsl-row:hover{background:rgba(255,255,255,.02)}
.fsl-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-body)}
.fsl-size{font-size:.72rem;color:var(--text-muted);flex-shrink:0}
.fsl-status{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:all .3s}
.fsl-queued{background:rgba(255,255,255,.15)}
.fsl-uploading{background:var(--main-color);box-shadow:0 0 6px var(--main-color);animation:statusPulse 1s ease infinite}
.fsl-done{background:var(--accent)}
.fsl-failed{background:var(--danger)}
@keyframes statusPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Preview checkboxes */
.preview-actions{display:flex;gap:8px}
.tree-file-select{display:flex;align-items:center;gap:8px;padding:7px 14px;border-bottom:1px solid var(--border-thin);font-size:.82rem;transition:background .2s}
.tree-file-select:last-child{border-bottom:none}
.tree-file-select:hover{background:rgba(255,255,255,.02)}
.tree-file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-body)}
.file-check{display:flex;align-items:center;cursor:pointer;flex-shrink:0}
.file-check input{display:none}
.file-check-box{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .2s}
.file-check input:checked+.file-check-box{background:var(--main-color);border-color:var(--main-color)}
.file-check input:checked+.file-check-box::after{content:'';display:block;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);margin-top:-2px}

/* Progress header layout */
.progress-header{display:flex;align-items:center;gap:20px;margin-bottom:24px}
.progress-header-text{text-align:left;flex:1}
.progress-header .progress-title{margin-bottom:4px;font-size:1.3rem}
.progress-header .progress-ring{margin:0;flex-shrink:0}

/* Result stats grid */
.result-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:12px;margin-bottom:24px;position:relative;z-index:2}
.result-stat{background:rgba(255,255,255,.03);border:1px solid var(--border-thin);border-radius:10px;padding:14px 12px;text-align:center}
.result-stat-value{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:2px}
.result-stat-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.result-stat.stat-skip .result-stat-value{color:var(--main-color)}
.result-stat.stat-fail .result-stat-value{color:var(--danger)}

/* Result mascot */
.result-mascot{position:relative;z-index:2;margin-bottom:16px}
.result-mascot-img{width:64px;height:auto}

/* Account prompt after upload */
.account-prompt{display:flex;align-items:center;gap:16px;background:rgba(202,255,51,.04);border:1px solid rgba(202,255,51,.12);border-radius:12px;padding:18px 22px;margin-bottom:20px;position:relative;z-index:2}
.account-prompt-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(202,255,51,.08);color:var(--accent);flex-shrink:0}
.account-prompt-text{flex:1;min-width:0}
.account-prompt-text strong{font-size:.9rem;color:var(--text);display:block;margin-bottom:2px}
.account-prompt-text p{font-size:.78rem;color:var(--text-muted);margin:0;line-height:1.4}
.account-prompt .butn{flex-shrink:0}
.result-actions{display:flex;justify-content:center;gap:12px}

/* ---- Users Toolbar & Pagination ---- */
.users-toolbar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.users-toolbar .text-input{flex:1;min-width:140px}

.users-pagination{display:flex;justify-content:center;gap:6px;margin-top:24px}
.page-btn{background:transparent;border:1px solid rgba(255,255,255,.08);color:var(--text-muted);padding:8px 16px;border-radius:8px;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .4s}
.page-btn:hover{border-color:rgba(255,255,255,.2);color:var(--text);background:rgba(255,255,255,.02)}
.page-btn.active{background:var(--main-color);border-color:var(--main-color);color:#fff}

.user-suspended{opacity:.5}
.badge-suspended{background:rgba(255,68,68,.08);color:var(--danger)}

/* ---- Modal ---- */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;animation:modalFadeIn .3s ease}
.modal-card{background:var(--bg);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:40px 36px;max-width:480px;width:90%;position:relative;animation:modalSlideUp .3s ease;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.modal-title{font-size:1.3rem;font-weight:700;margin-bottom:24px;letter-spacing:-.02em}
@keyframes modalFadeIn{from{opacity:0}to{opacity:1}}
@keyframes modalSlideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Help modal content */
#helpBody h4{font-size:.95rem;font-weight:700;margin:20px 0 6px;letter-spacing:-.01em}
#helpBody h4:first-child{margin-top:0}
#helpBody p{margin:0 0 10px;color:var(--muted)}
#helpBody ul,#helpBody ol{margin:0 0 12px;padding-left:22px;color:var(--muted)}
#helpBody li{margin-bottom:6px}
#helpBody code{background:rgba(255,255,255,.08);padding:2px 6px;border-radius:4px;font-size:.82rem;font-family:'JetBrains Mono',monospace}
#helpBody pre{background:rgba(255,255,255,.06);border:1px solid var(--border-thin);border-radius:8px;padding:12px 16px;overflow-x:auto;margin:8px 0 12px}
#helpBody pre code{background:none;padding:0;font-size:.82rem}
#helpBody strong{color:var(--heading-color);font-weight:600}
[data-theme="light"] #helpBody code{background:rgba(0,0,0,.06)}
[data-theme="light"] #helpBody pre{background:rgba(0,0,0,.03)}

/* ---- Profile ---- */
.profile-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-thin)}
.profile-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.profile-section-title{font-size:1rem;font-weight:600;margin-bottom:16px;letter-spacing:-.01em}
.profile-avatar{width:56px;height:56px;border-radius:50%;overflow:hidden;margin-bottom:20px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;border:1px solid var(--border-thin)}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.profile-initial{font-size:1.3rem;font-weight:700;color:var(--text-muted)}
.profile-field{margin-bottom:14px}
.profile-field .input-label{margin-bottom:6px}
.profile-edit-row{display:flex;gap:8px}
.profile-edit-row .text-input{flex:1}
.profile-hint{font-size:.72rem;color:var(--text-muted);margin-top:4px;display:block}
.profile-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:16px}
.profile-danger{border:1px solid rgba(255,68,68,.12);border-left:3px solid rgba(255,68,68,.4);border-radius:12px;padding:24px;margin-top:8px;background:rgba(255,68,68,.02)}

/* ---- Announcement Banner ---- */
.announcement-banner{background:linear-gradient(90deg,var(--main-color),#ff7a5c);color:#fff;text-align:center;padding:12px 20px;font-size:.82rem;font-weight:600;letter-spacing:.03em;position:relative;z-index:1000;text-transform:uppercase}

/* ---- Activity Feed ---- */
.activity-row{display:flex;align-items:center;gap:12px;padding:14px 28px;border-bottom:1px solid var(--border-thin);border-left:3px solid transparent;font-size:.82rem;transition:all .4s}
.activity-row:last-child{border-bottom:none}
.activity-row:hover{background:rgba(255,255,255,.02);border-left-color:var(--main-color)}
.activity-time{color:var(--text-muted);font-size:.68rem;width:140px;flex-shrink:0;letter-spacing:.02em}
.activity-detail{flex:1;color:var(--text-body);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.activity-who{color:var(--text-muted);font-size:.68rem;flex-shrink:0;opacity:.7}
.badge-ok{background:rgba(202,255,51,.08);color:var(--accent)}
.badge-err{background:rgba(255,68,68,.08);color:var(--danger)}
.badge-warn{background:rgba(253,91,56,.08);color:var(--main-color)}
.badge-info{background:rgba(255,255,255,.04);color:var(--text-muted)}

/* ---- Scroll Animations ---- */

/* Scroll animations — same pattern as test-anim.html */
[data-anim]{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}
[data-anim].in-view{opacity:1;transform:translateY(0)}

/* Scroll progress indicator */
.scroll-progress{position:fixed;bottom:30px;right:30px;width:44px;height:44px;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .4s;z-index:100;cursor:pointer}
.scroll-progress.visible{opacity:1;visibility:visible;transform:translateY(0)}
.scroll-progress svg{display:block;transform:rotate(-90deg)}
.scroll-prog-bg{fill:none;stroke:rgba(255,255,255,.08);stroke-width:3}
.scroll-prog-circle{fill:none;stroke:var(--main-color);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .1s}
.scroll-progress-arrow{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.7rem}

/* Reduce motion — only affects marquee, not scroll animations */
@media(prefers-reduced-motion:reduce){
  .marquee-box{animation-duration:60s}
}

/* ---- Scrollbar ---- */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}

/* ---- Responsive ---- */
@media(max-width:768px){
  .navbar{padding:0 20px;height:60px}
  .navbar-links{gap:16px}
  .main{padding:32px 20px;padding-top:92px}
  .hero{padding:100px 20px 60px}
  .hero-title{font-size:2.8rem}
  .hero-sub{font-size:1rem}
  .feat-section{padding:80px 0}
  .feat-inner{padding:0 20px}
  .feat-title{font-size:2rem}
  .feat-head{margin-bottom:48px}
  .svc-item{flex-direction:column;gap:16px}
  .svc-item:hover{padding-left:0}
  .svc-body h3{font-size:1.3rem}
  .how-section,.start-section{padding:80px 0}
  .how-inner,.start-inner{padding:0 20px}
  .how-flows{grid-template-columns:1fr}
  .flow-card:hover{transform:none}
  .start-title{font-size:2rem}
  .terminal-body{padding:20px}
  .marquee-item{font-size:1.6rem}
  .page-header h1{font-size:1.8rem}
  .page-header{flex-direction:column;gap:12px;align-items:flex-start}
  .file-grid{grid-template-columns:1fr}
  .admin-hero{padding:100px 20px 40px}
  .admin-title{font-size:2rem}
  .admin-body{padding:0 20px 60px}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
  .admin-user-row,.admin-file-row{flex-wrap:wrap}
  .admin-user-meta,.admin-file-meta{width:100%;padding-left:52px}
  .admin-file-actions{width:100%;padding-left:52px}
  .settings-field{grid-template-columns:1fr;gap:6px}
  .settings-label{min-width:0}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .share-card,.bundle-card{padding:36px 24px}
  .form-row{grid-template-columns:1fr}
  .drop-hero{padding:80px 20px 28px}
  .drop-title{font-size:2rem}
  .drop-section{padding:0 16px 36px}
  .drop-fields{grid-template-columns:1fr}
  .drop-step{gap:12px}
  .drop-step-num{width:26px;height:26px;font-size:.6rem}
  .drop-step-title{font-size:1.05rem}
  .preview-footer{flex-direction:column;align-items:stretch}
  .sec-head{flex-direction:column;align-items:flex-start}
  .sec-head h2{font-size:2rem}
  .site-footer{padding:40px 20px 20px}
  .footer-inner{flex-direction:column;gap:16px;text-align:center}
}

@media(max-width:480px){
  .hero-title{font-size:2rem}
  .features-grid{grid-template-columns:1fr}
  .feature-item{border-right:none!important}
  .stats-grid{grid-template-columns:1fr}
  .navbar-links{gap:10px;font-size:.8rem}
}
