*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fafafa;--bg2:#f3f2f7;--bg3:#eae8f0;--bg4:#ddd9e8;
  --card:#ffffff;--card-hover:#fefeff;
  --glass:rgba(255,255,255,.7);--glass-border:rgba(140,120,200,.12);
  --ink:#1a1430;--ink2:#5a5272;--ink3:#9089a6;
  --accent:#8b5cf6;--accent2:#a78bfa;--accent-light:#f5f3ff;
  --accent-glow:rgba(139,92,246,.15);--accent-border:rgba(139,92,246,.20);
  --fire:#f97316;--fire-light:#fff7ed;--fire-border:rgba(249,115,22,.2);
  --green:#10b981;--green-light:#ecfdf5;--green-border:rgba(16,185,129,.2);
  --blue:#3b82f6;--blue-light:#eff6ff;--blue-border:rgba(59,130,246,.2);
  --amber:#a78bfa;--amber-light:#fffbeb;--amber-border:rgba(245,158,11,.2);
  --rose:#f43f5e;--rose-light:#fff1f2;--rose-border:rgba(244,63,94,.2);
  --shadow-sm:0 1px 3px rgba(26,20,48,.06);
  --shadow:0 4px 20px rgba(26,20,48,.07);
  --shadow-lg:0 12px 40px rgba(26,20,48,.1);
  --shadow-xl:0 20px 60px rgba(26,20,48,.12);
  --shadow-accent:0 8px 30px rgba(139,92,246,.2);
  --r:16px;--r2:20px;--r3:24px;
}
html{height:100%;scroll-behavior:smooth}
body{min-height:100%;font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}

.screen{display:none;min-height:100vh;flex-direction:column;position:relative;z-index:1}
.screen.active{display:flex}

/* LOGO */
.logo-wrap{display:flex;align-items:center;gap:12px}
.logo-mark{width:38px;height:38px;flex-shrink:0;filter:drop-shadow(0 2px 8px rgba(139,92,246,.3))}
.logo-name{font-family:'Playfair Display',serif;font-size:20px;color:var(--ink);letter-spacing:-.02em;display:block;line-height:1.1;font-weight:700}
.logo-sub{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600;display:block;margin-top:2px}

/* NAV */
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 40px;background:rgba(255,255,255,.75);border-bottom:1px solid var(--glass-border);position:sticky;top:0;z-index:100;backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6)}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-pill{font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--accent);background:var(--accent-light);border:1px solid var(--accent-border);padding:4px 14px;border-radius:20px;text-transform:uppercase}

/* Usage badge */
.usage-badge{font-size:11px;font-weight:600;color:var(--ink2);background:var(--bg2);border:1px solid var(--glass-border);padding:4px 14px;border-radius:20px;display:none}
.usage-badge.visible{display:inline-block}
.usage-badge.exhausted{color:var(--amber);background:var(--amber-light);border-color:var(--amber-border)}

/* Language switcher */
.lang-switch{display:flex;background:var(--bg2);border:1px solid var(--glass-border);border-radius:20px;padding:3px;gap:2px}
.lang-btn{font-size:12px;font-weight:700;letter-spacing:.06em;padding:6px 14px;border-radius:16px;border:none;cursor:pointer;background:none;color:var(--ink3);font-family:'Inter';transition:all .25s}
.lang-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 10px rgba(139,92,246,.35)}
.lang-btn:hover:not(.active){color:var(--ink2)}

/* Auth button */
.btn-auth{font-size:12px;font-weight:600;color:var(--ink2);background:var(--card);border:1px solid var(--glass-border);padding:6px 16px;border-radius:20px;cursor:pointer;transition:all .25s;font-family:'Inter'}
.btn-auth:hover{border-color:var(--accent-border);color:var(--accent)}

/* HERO */
.hero{position:relative;overflow:hidden;padding:70px 40px 40px;text-align:center;
  background:linear-gradient(160deg,#f5f3ff 0%,#fafafa 40%,#eff6ff 100%);
  background-size:400% 400%;
  animation:heroGradient 10s ease infinite}
@keyframes heroGradient{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 70% 55% at 50% -10%,rgba(139,92,246,.08),transparent 65%),
  radial-gradient(ellipse 50% 45% at 15% 80%,rgba(139,92,246,.05),transparent 55%),
  radial-gradient(ellipse 45% 40% at 85% 70%,rgba(59,130,246,.05),transparent 55%)}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(139,92,246,.2),transparent)}
.hero>*{position:relative;z-index:2}

/* Animated gradient orbs */
.hero-orb{position:absolute;border-radius:50%;filter:blur(90px);animation:orbFloat 10s ease-in-out infinite;pointer-events:none;z-index:0}
.orb1{width:500px;height:500px;background:rgba(139,92,246,.22);top:-180px;right:-120px;animation-delay:0s}
.orb2{width:380px;height:380px;background:rgba(249,115,22,.14);bottom:-100px;left:-100px;animation-delay:-4s}
.orb3{width:300px;height:300px;background:rgba(59,130,246,.12);top:40%;left:55%;animation-delay:-7s}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(25px,-18px) scale(1.04)}66%{transform:translate(-18px,12px) scale(.96)}}

.live-badge{display:inline-flex;align-items:center;gap:8px;background:var(--card);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:50px;padding:8px 18px 8px 12px;margin-bottom:32px;font-size:12px;font-weight:600;color:var(--ink2);box-shadow:var(--shadow-sm)}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;box-shadow:0 0 0 3px rgba(16,185,129,.2);animation:livePulse 2s ease-in-out infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 3px rgba(16,185,129,.2)}50%{box-shadow:0 0 0 8px rgba(16,185,129,.06)}}

.hero-title{font-family:'Playfair Display',serif;font-size:clamp(36px,5.5vw,62px);line-height:1.08;letter-spacing:-.03em;margin-bottom:22px;color:var(--ink);font-weight:700;display:flex;flex-direction:column;align-items:center;gap:10px}
.hero-title-main{font-family:'Playfair Display',serif;font-size:3.5rem;font-weight:700;letter-spacing:-.03em;line-height:1.1;background:linear-gradient(135deg,var(--accent) 0%,var(--blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-title-sub{font-family:'Inter',system-ui,sans-serif;font-size:1.3rem;font-weight:400;color:var(--ink2);margin-top:.5rem;letter-spacing:-.01em}
.hero-highlight{display:inline-block;background:linear-gradient(135deg,var(--accent) 0%,var(--fire) 60%,var(--accent2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:italic;background-size:200% 200%;animation:shiftGrad 4s ease-in-out infinite}
@keyframes shiftGrad{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.hero-desc{font-size:16px;color:var(--ink2);max-width:480px;margin:0 auto 38px;line-height:1.7;font-weight:400}

/* Hero CTA button */
/* Hero CTA block */
.hero-cta-block{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:36px}
.btn-hero-cta{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;text-decoration:none;border-radius:16px;padding:18px 44px;font-family:'Inter',sans-serif;font-size:17px;font-weight:700;letter-spacing:-.01em;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 28px rgba(139,92,246,.45),0 2px 8px rgba(139,92,246,.2);border:none;cursor:pointer;position:relative;overflow:hidden}
.btn-hero-cta::after{content:'→';font-size:18px;transition:transform .2s}
.btn-hero-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.18),transparent);opacity:0;transition:opacity .3s}
.btn-hero-cta:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(139,92,246,.55),0 4px 12px rgba(139,92,246,.25)}
.btn-hero-cta:hover::before{opacity:1}
.btn-hero-cta:hover::after{transform:translateX(4px)}
.btn-hero-cta:active{transform:translateY(-1px)}

/* Hero social proof */
.hero-social-proof{display:inline-flex;align-items:center;gap:6px;color:var(--ink3);font-size:13px}
.hero-proof-number{font-weight:700;color:var(--accent);font-size:14px}
.hero-proof-text{font-weight:400}

/* Feature pills */
.feat-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:10px}
.feat-pill{display:flex;align-items:center;gap:7px;background:var(--card);backdrop-filter:blur(6px);border:1px solid var(--glass-border);border-radius:50px;padding:8px 16px;font-size:12px;font-weight:500;color:var(--ink2);cursor:default;transition:all .3s;box-shadow:var(--shadow-sm)}
.feat-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow);background:var(--card-hover)}
.feat-pill .fp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.fp-icon{font-size:14px;line-height:1;flex-shrink:0}

/* Floating decorative hero icons */
.hero-float{position:absolute;font-size:44px;opacity:.22;pointer-events:none;z-index:0;animation:floatDrift 8s ease-in-out infinite}
.hero-float--1{top:12%;left:22%;animation-delay:0s}
.hero-float--2{top:15%;right:22%;animation-delay:1.5s}
.hero-float--3{bottom:20%;left:26%;animation-delay:3s}
.hero-float--4{top:40%;right:20%;animation-delay:2s;font-size:36px}
.hero-float--5{bottom:18%;right:24%;animation-delay:4s}
.hero-float--6{top:55%;left:20%;animation-delay:5s;font-size:36px}
@keyframes floatDrift{0%,100%{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-12px) rotate(4deg)}66%{transform:translateY(6px) rotate(-3deg)}}
@media(max-width:680px){.hero-float{display:none}}

/* UPLOAD BODY */
.upload-body{padding:32px 24px 60px;background:var(--bg)}
.upload-inner{max-width:860px;margin:0 auto}
.sec-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}

.upload-row{display:grid;grid-template-columns:1fr 56px 1fr;gap:16px;align-items:stretch;margin-bottom:40px}
.vs-col{display:flex;align-items:center;justify-content:center;padding-top:64px}
.vs-badge{width:40px;height:40px;border-radius:50%;background:var(--bg2);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:var(--ink3);letter-spacing:.04em}

.drop-card{background:var(--card);border:2px dashed var(--bg4);border-radius:var(--r2);padding:40px 24px;display:flex;flex-direction:column;align-items:center;gap:16px;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;text-align:center;box-shadow:var(--shadow-sm)}
.drop-card:hover{border-color:var(--accent-border);background:var(--accent-light);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.drop-card.filled{border-style:solid;border-color:var(--accent);background:var(--accent-light)}
.type-badge{position:absolute;top:-12px;left:18px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:20px}
.badge-o{background:var(--blue-light);color:var(--blue);border:1px solid var(--blue-border)}
.badge-m{background:var(--green-light);color:var(--green);border:1px solid var(--green-border)}
.d-icon{width:60px;height:60px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:26px}
.d-title{font-size:17px;font-weight:600;color:var(--ink)}
.d-desc{font-size:13px;color:var(--ink2);line-height:1.55}
.d-hint{font-size:11px;color:var(--ink3);background:var(--bg2);border:1px solid var(--glass-border);padding:5px 14px;border-radius:20px}
.d-placeholder{display:flex;flex-direction:column;align-items:center;gap:14px;width:100%}
.drop-card.filled .d-placeholder{display:none}
.drop-card.filled .d-filled{display:flex}
.d-filled{display:none;flex-direction:column;align-items:center;gap:10px;width:100%}
.d-check{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(139,92,246,.3)}
.d-fname{font-size:13px;font-weight:600;color:var(--ink)}
.d-fsize{font-size:11px;color:var(--ink3)}
.d-change{font-size:11px;color:var(--accent);text-decoration:underline;cursor:pointer;text-underline-offset:3px}
.vid-editor{width:100%;display:flex;flex-direction:column;gap:12px}
.vid-preview-wrap{position:relative;border-radius:10px;overflow:hidden;background:#000;aspect-ratio:16/9}
.vid-preview{width:100%;height:100%;object-fit:contain;display:block}
.vid-preview.mirrored{transform:scaleX(-1)}
.vid-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);border:none;color:#fff;cursor:pointer;transition:opacity .2s;opacity:1}
.vid-play-btn.playing{opacity:0}
.vid-play-btn:hover{opacity:1!important}
.vid-time{position:absolute;bottom:6px;right:8px;font-size:11px;color:rgba(255,255,255,.8);background:rgba(0,0,0,.5);padding:2px 6px;border-radius:4px;pointer-events:none}
.vid-trim{display:flex;align-items:center;gap:8px;flex-wrap:wrap;position:relative}
.vid-trim-label{font-size:11px;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}
.vid-range{-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--bg3);outline:none;flex:1;min-width:60px}
.vid-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.vid-range-start{direction:rtl}
.vid-trim-times{display:flex;justify-content:space-between;width:100%;font-size:10px;color:var(--ink3);margin-top:-4px}
.vid-tools{display:flex;gap:8px;justify-content:center}
.vid-tool-btn{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:8px;border:1px solid var(--glass-border);background:var(--bg2);font-size:12px;color:var(--ink2);cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s}
.vid-tool-btn:hover{border-color:var(--accent-border);color:var(--accent);background:var(--accent-light)}
.vid-tool-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.vid-status{display:flex;align-items:center;gap:6px;padding:8px 12px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);border-radius:8px;color:#16a34a;font-size:12px;font-weight:500}
.vid-status svg{flex-shrink:0}
.vid-status-info{color:var(--ink3);font-weight:400;margin-left:auto}

/* CHECKERS (compact chips) */
.settings-inline{display:flex;flex-direction:column;gap:16px;max-width:860px;margin:0 auto;padding-bottom:8px}
.settings-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.settings-row-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3);white-space:nowrap}
.checkers-count{font-size:11px;font-weight:700;color:var(--accent);background:var(--accent-light);padding:2px 8px;border-radius:10px;white-space:nowrap}
.checkers-chips{display:flex;flex-wrap:wrap;gap:8px}
.checker-chip{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:20px;border:1.5px solid var(--bg4);background:transparent;color:var(--ink3);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}
.checker-chip:hover{border-color:var(--accent-border);color:var(--ink2)}
.checker-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.checker-chip.active:hover{background:var(--accent2);border-color:var(--accent2)}
.checker-chip.inactive{opacity:.5;background:transparent;border-color:var(--bg4);color:var(--ink3)}
.chip-emoji{font-size:15px;line-height:1}
.chip-check{display:none;font-size:11px;font-weight:700;line-height:1}
.checker-chip.active .chip-check{display:inline}
.chip-add{display:inline-flex;align-items:center;gap:4px;padding:7px 14px;border-radius:20px;border:1.5px dashed var(--bg4);background:transparent;color:var(--ink3);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}
.chip-add:hover{border-color:var(--accent);color:var(--accent)}
.chip-add-input{width:110px;padding:7px 14px;border-radius:20px;border:1.5px solid var(--accent);background:var(--card);font-size:13px;font-family:inherit;color:var(--ink);outline:none}
.chip-remove{margin-left:3px;font-size:13px;opacity:.6;cursor:pointer;background:none;border:none;color:inherit;padding:0;line-height:1;font-weight:400}
.chip-remove:hover{opacity:1}

/* TOOLTIPS */
[data-tooltip]{position:relative}
[data-tooltip]::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:400;line-height:1.4;white-space:normal;max-width:220px;width:max-content;text-align:center;opacity:0;pointer-events:none;transition:opacity .2s;z-index:100;font-family:'Inter',sans-serif;letter-spacing:normal;text-transform:none}
[data-tooltip]::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ink);opacity:0;pointer-events:none;transition:opacity .2s;z-index:100}
/* tooltips disabled — [data-tooltip]:hover::after,[data-tooltip]:hover::before{opacity:1} */
/* tooltips disabled — [data-tooltip].tooltip-visible::after,[data-tooltip].tooltip-visible::before{opacity:1} */

/* FLOW STEPPER */
.flow-stepper{display:flex;align-items:center;justify-content:center;padding:12px 40px}
.fs-step{display:flex;align-items:center;gap:6px}
.fs-dot{width:24px;height:24px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink3);flex-shrink:0;transition:all .3s}
.fs-num{display:inline}
.fs-check{display:none;font-size:12px}
.fs-label{font-size:12px;font-weight:500;color:var(--ink3);white-space:nowrap;transition:all .3s;font-family:'Inter',sans-serif}
.fs-line{width:32px;height:2px;background:var(--bg4);margin:0 8px;flex-shrink:0;border-radius:1px;position:relative;overflow:hidden}
.fs-line::after{content:'';position:absolute;top:0;left:0;height:100%;width:0;background:var(--green);border-radius:1px}
/* Active step: accent + pulse */
#s-upload .fs-step[data-step="1"] .fs-dot,
#s-analyzing .fs-step[data-step="2"] .fs-dot,
#s-results .fs-step[data-step="3"] .fs-dot{background:var(--accent);color:#fff;animation:stepPulse 2s ease-in-out infinite}
#s-upload .fs-step[data-step="1"] .fs-label,
#s-analyzing .fs-step[data-step="2"] .fs-label,
#s-results .fs-step[data-step="3"] .fs-label{color:var(--accent);font-weight:700}
/* Done steps: green + checkmark pop */
#s-analyzing .fs-step[data-step="1"] .fs-dot,
#s-results .fs-step[data-step="1"] .fs-dot,
#s-results .fs-step[data-step="2"] .fs-dot{background:var(--green);color:#fff}
#s-analyzing .fs-step[data-step="1"] .fs-num,
#s-results .fs-step[data-step="1"] .fs-num,
#s-results .fs-step[data-step="2"] .fs-num{display:none}
#s-analyzing .fs-step[data-step="1"] .fs-check,
#s-results .fs-step[data-step="1"] .fs-check,
#s-results .fs-step[data-step="2"] .fs-check{display:inline;animation:checkPop .4s ease}
#s-analyzing .fs-step[data-step="1"] .fs-label,
#s-results .fs-step[data-step="1"] .fs-label,
#s-results .fs-step[data-step="2"] .fs-label{color:var(--ink2)}
/* Done lines: animated fill left→right */
#s-analyzing .fs-step[data-step="1"]+.fs-line::after,
#s-results .fs-step[data-step="1"]+.fs-line::after,
#s-results .fs-step[data-step="2"]+.fs-line::after{animation:lineFill .6s ease forwards}
@keyframes stepPulse{0%,100%{box-shadow:0 0 0 0 rgba(139,92,246,.35)}50%{box-shadow:0 0 0 6px rgba(139,92,246,0)}}
@keyframes checkPop{0%{transform:scale(0)}60%{transform:scale(1.3)}100%{transform:scale(1)}}
@keyframes lineFill{from{width:0}to{width:100%}}


/* CTA */
.cta-wrap{display:flex;flex-direction:column;align-items:center;gap:12px}
.btn-main{background:linear-gradient(135deg,var(--accent),#a78bfa);color:#fff;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-weight:600;font-size:16px;padding:18px 64px;border-radius:50px;letter-spacing:.02em;transition:all .35s;box-shadow:var(--shadow-accent);position:relative;overflow:hidden}
.btn-main::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:opacity .3s}
.btn-main:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(139,92,246,.35)}
.btn-main:hover::before{opacity:1}
.btn-main:active{transform:translateY(-1px)}
.btn-main:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}
.btn-main:disabled::before{display:none}
.cta-note{font-size:12px;color:var(--ink3)}

/* ANALYZING */
#s-analyzing{background:linear-gradient(170deg,#fff 0%,var(--bg2) 100%);align-items:center;justify-content:center;gap:44px}
.a-ring-wrap{position:relative;width:90px;height:90px}
.a-ring{position:absolute;inset:0;border-radius:50%;border:2.5px solid transparent;animation:spin 2s linear infinite}
.a-ring.r1{border-top-color:var(--accent);border-right-color:rgba(139,92,246,.2);animation-duration:1.6s}
.a-ring.r2{inset:14px;border-top-color:var(--fire);border-left-color:rgba(249,115,22,.15);animation-duration:2.4s;animation-direction:reverse}
.a-ring.r3{inset:28px;border-top-color:var(--blue);animation-duration:3.2s}
.a-ring-center{position:absolute;inset:32px;border-radius:50%;background:var(--accent-light);display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 4px 20px rgba(139,92,246,.12)}
@keyframes spin{to{transform:rotate(360deg)}}
.a-title{font-family:'Playfair Display',serif;font-size:30px;color:var(--ink);margin-bottom:10px;text-align:center}
.a-sub{font-size:14px;color:var(--ink2);text-align:center}
.steps-box{background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r2);padding:22px;width:360px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow)}
.a-step{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:12px;font-size:13px;color:var(--ink3);transition:all .4s}
.a-step.done{color:var(--green);background:var(--green-light)}
.a-step.active{color:var(--ink);background:var(--accent-light);font-weight:500}
.a-step.skipped{display:none}
.a-step.warn{color:var(--fire);background:var(--fire-light);font-weight:500}
.a-step.crit{color:var(--rose);background:var(--rose-light);font-weight:500}
.a-step.error{color:var(--rose);background:var(--rose-light);font-weight:500;animation:stepShake .4s ease}
.a-dot{width:8px;height:8px;border-radius:50%;background:var(--bg4);flex-shrink:0;transition:all .3s}
.a-step.done .a-dot{background:var(--green);box-shadow:0 0 6px rgba(16,185,129,.4)}
.a-step.active .a-dot{background:var(--accent);box-shadow:0 0 6px rgba(139,92,246,.4);animation:pulse 1.2s ease-in-out infinite}
.a-step.warn .a-dot{background:var(--fire);box-shadow:0 0 6px rgba(249,115,22,.4)}
.a-step.crit .a-dot{background:var(--rose);box-shadow:0 0 6px rgba(244,63,94,.4)}
.a-step.error .a-dot{background:var(--rose)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
@keyframes stepShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
/* Context strip — shows mode/skill/checkers info during analysis */
.a-context-strip{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;padding:0 24px;max-width:500px}
.a-ctx-chip{background:var(--card);border:1px solid var(--glass-border);border-radius:20px;padding:5px 14px;font-size:12px;font-family:'Inter',sans-serif;color:var(--ink2);font-weight:500;white-space:nowrap}

/* RESULTS */
#s-results{background:var(--bg);overflow-y:auto}
.r-nav{background:rgba(255,255,255,.8);border-bottom:1px solid var(--glass-border);padding:15px 40px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;backdrop-filter:blur(20px)}
.r-crumb{font-size:13px;color:var(--ink2)}
.r-crumb strong{color:var(--ink)}
.btn-back{background:var(--card);border:1px solid var(--glass-border);color:var(--ink2);font-family:'Inter';font-size:13px;padding:8px 18px;border-radius:10px;cursor:pointer;transition:all .25s;box-shadow:var(--shadow-sm)}
.btn-back:hover{border-color:var(--accent-border);color:var(--accent);box-shadow:var(--shadow)}
.att-badge{background:var(--fire-light);border:1px solid var(--fire-border);color:var(--fire);font-size:11px;font-weight:700;padding:5px 14px;border-radius:20px}

.r-body{max-width:920px;margin:0 auto;padding:48px 24px 80px}

.overall-card{background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r3);padding:40px;margin-bottom:36px;display:flex;align-items:center;gap:40px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:background .4s,border-color .4s}
.overall-card::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.06),transparent 70%);pointer-events:none;transition:background .4s}
.overall-card::after{content:'';position:absolute;bottom:-40px;left:-40px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(249,115,22,.04),transparent 70%);pointer-events:none}

/* Score-based card colors */
.overall-card--critical{background:linear-gradient(135deg,rgba(239,68,68,.06),rgba(239,68,68,.02));border-color:rgba(239,68,68,.25)}
.overall-card--critical::before{background:radial-gradient(circle,rgba(239,68,68,.08),transparent 70%)}
.overall-card--critical .ring-fi{stroke:var(--rose,#ef4444)}
.overall-card--warning{background:linear-gradient(135deg,rgba(249,115,22,.07),rgba(249,115,22,.02));border-color:rgba(249,115,22,.25)}
.overall-card--warning::before{background:radial-gradient(circle,rgba(249,115,22,.1),transparent 70%)}
.overall-card--warning .ring-fi{stroke:var(--fire,#f97316)}
.overall-card--good{background:linear-gradient(135deg,rgba(59,130,246,.06),rgba(59,130,246,.02));border-color:rgba(59,130,246,.25)}
.overall-card--good::before{background:radial-gradient(circle,rgba(59,130,246,.08),transparent 70%)}
.overall-card--good .ring-fi{stroke:var(--blue,#3b82f6)}
.overall-card--excellent{background:linear-gradient(135deg,rgba(34,197,94,.07),rgba(34,197,94,.02));border-color:rgba(34,197,94,.25)}
.overall-card--excellent::before{background:radial-gradient(circle,rgba(34,197,94,.1),transparent 70%)}
.overall-card--excellent .ring-fi{stroke:var(--green,#22c55e)}
.overall-card>*{position:relative;z-index:1}
.ring-svg-wrap{position:relative;width:120px;height:120px;flex-shrink:0}
.ring-svg-wrap svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-tr{fill:none;stroke:var(--bg3);stroke-width:6}
.ring-fi{fill:none;stroke:url(#scoreGrad);stroke-width:6;stroke-linecap:round;stroke-dasharray:283;stroke-dashoffset:283;transition:stroke-dashoffset 1.8s cubic-bezier(.4,0,.2,1)}
.ring-lbl{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-n{font-family:'Playfair Display',serif;font-size:36px;color:var(--ink);line-height:1;font-weight:700}
.ring-u{font-size:10px;color:var(--ink3);letter-spacing:.06em;margin-top:3px}
.ov-eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.ov-headline{font-family:'Playfair Display',serif;font-size:28px;margin-bottom:12px;line-height:1.2;font-weight:700}
.ov-body{font-size:14px;color:var(--ink2);line-height:1.7}
.ov-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.ov-tag{font-size:12px;font-weight:600;padding:5px 14px;border-radius:20px}
.ot-g{background:var(--green-light);color:var(--green);border:1px solid var(--green-border)}
.ot-a{background:var(--amber-light);color:var(--amber);border:1px solid var(--amber-border)}

.r-sec{font-family:'Playfair Display',serif;font-size:24px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--glass-border);color:var(--ink);font-weight:600}

/* Score Summary */
.score-summary{background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r2);padding:20px 24px;margin-bottom:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}
.ss-row{display:flex;align-items:center;gap:12px;border-radius:10px;padding:6px 0;transition:background .2s}
.ss-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ss-name{font-size:13px;font-weight:500;color:var(--ink);width:130px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ss-bar-wrap{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.ss-bar{height:100%;border-radius:3px;width:0;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.ss-score{font-size:15px;font-weight:700;min-width:32px;text-align:right}
.ss-row--worst{background:var(--rose-light);border-radius:10px;padding:6px 12px;margin:0 -12px}

/* Accordion */
.accordion{margin-bottom:36px}
.accordion-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:none;border-bottom:1px solid var(--glass-border);padding:0 0 16px;margin-bottom:0;cursor:pointer;transition:color .2s;font-family:'Playfair Display',serif;font-size:24px;font-weight:600;color:var(--ink);text-align:left}
.accordion-toggle:hover{color:var(--accent)}
.accordion-title{flex:1}
.accordion-chevron{width:22px;height:22px;color:var(--ink3);flex-shrink:0;transition:transform .35s cubic-bezier(.4,0,.2,1);margin-left:12px}
.accordion.open .accordion-chevron{transform:rotate(180deg)}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1),opacity .3s;opacity:0}
.accordion.open .accordion-body{max-height:3000px;opacity:1;overflow:visible}
.accordion-body-inner{padding-top:24px}

.metrics-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:0}
.m-card{background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r);padding:24px;box-shadow:var(--shadow-sm);transition:all .35s}
.m-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.m-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.m-left{display:flex;align-items:center;gap:12px}
.m-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.m-name{font-size:13px;font-weight:600;color:var(--ink)}
.m-score{font-family:'Playfair Display',serif;font-size:30px;font-weight:700}
.bar-tr{height:5px;background:var(--bg3);border-radius:3px;overflow:hidden;margin-bottom:12px}
.bar-fi{height:100%;border-radius:3px;width:0;transition:width 1.4s cubic-bezier(.4,0,.2,1)}
.m-note{font-size:12px;color:var(--ink2);line-height:1.6}
.m-pills{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.pill{font-size:10px;font-weight:700;padding:3px 10px;border-radius:10px}
.pill-g{background:var(--green-light);color:var(--green);border:1px solid var(--green-border)}
.pill-a{background:var(--amber-light);color:var(--amber);border:1px solid var(--amber-border)}
.pill-r{background:var(--rose-light);color:var(--rose);border:1px solid var(--rose-border)}

.fb-section{background:#fff;border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);padding:36px 0;margin:0 -24px 0}
.fb-section-inner{max-width:920px;margin:0 auto;padding:0 24px}
.fb-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fb-card{border-radius:var(--r);padding:28px}
.fb-card.good{background:var(--green-light);border:1px solid var(--green-border)}
.fb-card.improve{background:var(--amber-light);border:1px solid var(--amber-border)}
.fb-head{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px}
.g-head{color:var(--green)}.a-head{color:var(--amber)}
.fb-list{display:flex;flex-direction:column;gap:12px}
.fb-row{display:flex;align-items:flex-start;gap:12px;font-size:13px;color:var(--ink);line-height:1.6}
.fb-bul{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;margin-top:1px}
.bul-g{background:rgba(16,185,129,.15);color:var(--green)}
.bul-a{background:rgba(245,158,11,.15);color:var(--amber)}

.tip-card{background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r2);padding:20px 24px;margin-bottom:28px;display:flex;gap:16px;align-items:flex-start;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.tip-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow)}
.tip-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent),var(--fire));border-radius:3px 0 0 3px}
.tip-icon{width:36px;height:36px;border-radius:10px;background:var(--accent-light);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;margin-top:1px}
.tip-content{flex:1;min-width:0}
.tip-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.tip-body{font-size:13px;color:var(--ink2);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:all .3s}
.tip-body.expanded{display:block;-webkit-line-clamp:unset;overflow:visible}
.tip-body strong{color:var(--ink);font-weight:600}
.tip-toggle{display:inline-block;margin-top:6px;font-size:12px;font-weight:600;color:var(--accent);cursor:pointer}

.prog-card{background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r2);padding:28px;margin-bottom:36px;box-shadow:var(--shadow-sm)}
.prog-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}

/* History list */
.history-list{display:flex;flex-direction:column;gap:10px;margin-bottom:36px}
.history-empty{color:var(--ink3);font-size:14px;text-align:center;padding:24px 0}
.history-row{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r2);padding:14px 20px;box-shadow:var(--shadow-sm)}
.history-score{font-size:22px;font-weight:800;min-width:44px;text-align:center;flex-shrink:0}
.history-score--critical{color:var(--rose,#ef4444)}
.history-score--warning{color:var(--fire,#f97316)}
.history-score--good{color:var(--blue,#3b82f6)}
.history-score--excellent{color:var(--green,#22c55e)}
.history-meta{flex:1;min-width:0}
.history-mode{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3)}
.history-date{font-size:12px;color:var(--ink3);margin-top:2px}
.history-bar-wrap{width:80px;flex-shrink:0}
.history-bar-track{height:4px;background:var(--bg3);border-radius:4px;overflow:hidden}
.history-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}
.prog-title{font-size:14px;font-weight:600;color:var(--ink)}
.prog-cnt{font-size:12px;color:var(--ink3)}
.bars-row{display:flex;align-items:flex-end;gap:8px;height:90px}
.b-col{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}
.b-bar{width:100%;border-radius:6px 6px 0 0;transition:height .8s cubic-bezier(.4,0,.2,1)}
.b-val{font-size:12px;font-weight:700;color:var(--ink2)}
.b-lbl{font-size:10px;color:var(--ink3)}
.b-col.cur .b-val{color:var(--accent)}

.bottom-actions{display:flex;flex-direction:column;gap:12px}
.bottom-actions-row{display:flex;gap:10px}
.btn-cta{width:100%;background:linear-gradient(135deg,var(--accent),#a78bfa);border:none;color:#fff;font-family:'Inter';font-size:15px;font-weight:600;padding:17px;border-radius:14px;cursor:pointer;transition:all .35s;box-shadow:var(--shadow-accent)}
.btn-cta:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(139,92,246,.3)}
.btn-sec{flex:1;background:var(--card);border:1px solid var(--glass-border);color:var(--ink2);font-family:'Inter';font-size:13px;font-weight:500;padding:13px 12px;border-radius:14px;cursor:pointer;transition:all .25s;box-shadow:var(--shadow-sm)}
.btn-sec:hover{border-color:var(--accent-border);color:var(--ink);box-shadow:var(--shadow)}
.btn-publish{flex:1;background:var(--card);border:1.5px solid var(--accent-border);color:var(--accent);font-family:'Inter';font-size:13px;font-weight:600;padding:13px 12px;border-radius:14px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-sm)}
.btn-publish:hover{background:var(--accent-light);box-shadow:var(--shadow)}
.btn-publish svg{width:16px;height:16px;flex-shrink:0}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(26,20,48,.35);backdrop-filter:blur(6px);z-index:200;display:none;align-items:flex-end;justify-content:center}
.modal-overlay.open{display:flex}
.modal-sheet{background:var(--card);border:1px solid var(--glass-border);border-radius:24px 24px 0 0;padding:36px 32px 44px;width:100%;max-width:540px;box-shadow:var(--shadow-xl);animation:slideUp .35s cubic-bezier(.4,0,.2,1)}
@keyframes slideUp{from{transform:translateY(80px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-handle{width:44px;height:4px;background:var(--bg4);border-radius:2px;margin:0 auto 28px}
.modal-title{font-family:'Playfair Display',serif;font-size:24px;margin-bottom:8px;font-weight:700}
.gen-mode-tabs{display:flex;gap:0;background:var(--bg2);border-radius:10px;padding:3px;margin-bottom:12px}
.gen-mode-tab{flex:1;padding:8px 0;border:none;background:transparent;font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--ink3);border-radius:8px;cursor:pointer;transition:all .2s}
.gen-mode-tab.active{background:var(--card);color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.modal-sub{font-size:13px;color:var(--ink2);margin-bottom:28px;line-height:1.6}
.publish-preview{background:var(--bg2);border:1px solid var(--glass-border);border-radius:14px;padding:18px;margin-bottom:28px;display:flex;align-items:center;gap:16px}
.preview-icon{width:52px;height:52px;border-radius:14px;background:var(--accent-light);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.preview-title{font-size:14px;font-weight:600;color:var(--ink)}
.preview-meta{font-size:12px;color:var(--ink3);margin-top:4px}
.platforms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}
.platform-btn{background:var(--card);border:1.5px solid var(--glass-border);border-radius:14px;padding:16px 8px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:all .3s;box-shadow:var(--shadow-sm)}
.platform-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.platform-btn.selected{border-color:var(--accent);background:var(--accent-light);box-shadow:var(--shadow),0 0 0 1px var(--accent-border)}
.p-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.p-name{font-size:11px;font-weight:600;color:var(--ink2)}
.p-tiktok:hover{border-color:#555}
.p-instagram:hover{border-color:#C13584}
.p-youtube:hover{border-color:#FF0000}
.p-telegram:hover{border-color:#0088cc}
.modal-caption{margin-bottom:24px}
.caption-label{font-size:12px;font-weight:600;color:var(--ink2);margin-bottom:8px}
.caption-input{width:100%;background:var(--bg2);border:1px solid var(--glass-border);border-radius:12px;padding:14px 16px;font-family:'Inter';font-size:13px;color:var(--ink);resize:none;outline:none;transition:border-color .2s}
.caption-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,92,246,.08)}
.modal-actions{display:flex;gap:12px}
.modal-btn-cancel{flex:1;background:var(--bg2);border:1px solid var(--glass-border);color:var(--ink2);font-family:'Inter';font-size:14px;font-weight:500;padding:14px;border-radius:12px;cursor:pointer;transition:all .2s}
.modal-btn-cancel:hover{color:var(--ink);background:var(--bg3)}
.modal-btn-go{flex:2;background:linear-gradient(135deg,var(--accent),#a78bfa);border:none;color:#fff;font-family:'Inter';font-size:14px;font-weight:600;padding:14px;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:0 4px 14px rgba(139,92,246,.25)}
.modal-btn-go:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(139,92,246,.35)}

/* Login modal */
.login-modal-body{text-align:center;padding:20px 0}
.login-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent-light);border:2px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 20px}
.login-form{display:flex;flex-direction:column;gap:12px;margin:20px 0}
.login-input{width:100%;background:var(--bg2);border:1px solid var(--glass-border);border-radius:12px;padding:14px 16px;font-family:'Inter';font-size:14px;color:var(--ink);outline:none;transition:border-color .2s}
.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,92,246,.08)}
.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:#fff;border:1.5px solid var(--glass-border);color:var(--ink);font-family:'Inter';font-size:14px;font-weight:600;padding:14px;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:var(--shadow-sm)}
.btn-google:hover{border-color:var(--accent-border);box-shadow:var(--shadow)}

/* Limit overlay */
.limit-overlay{position:fixed;inset:0;background:rgba(26,20,48,.5);backdrop-filter:blur(8px);z-index:250;display:none;align-items:center;justify-content:center}
.limit-overlay.open{display:flex}
.limit-card{background:var(--card);border:1px solid var(--glass-border);border-radius:var(--r3);padding:48px 40px;max-width:440px;width:90%;text-align:center;box-shadow:var(--shadow-xl);animation:slideUp .35s cubic-bezier(.4,0,.2,1)}
.limit-icon{font-size:48px;margin-bottom:16px}
.limit-title{font-family:'Playfair Display',serif;font-size:24px;margin-bottom:12px;font-weight:700}
.limit-text{font-size:14px;color:var(--ink2);line-height:1.7;margin-bottom:28px}
.limit-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:20px;color:var(--ink3);cursor:pointer}

.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(80px);background:linear-gradient(135deg,var(--accent),#a78bfa);color:#fff;font-size:13px;font-weight:600;padding:14px 28px;border-radius:50px;z-index:300;transition:transform .4s cubic-bezier(.4,0,.2,1);white-space:nowrap;box-shadow:0 8px 28px rgba(139,92,246,.35)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.error{background:linear-gradient(135deg,var(--rose),#e11d48)}

/* Entrance animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .7s cubic-bezier(.4,0,.2,1) both}
.fade-up-d1{animation-delay:.12s}.fade-up-d2{animation-delay:.24s}.fade-up-d3{animation-delay:.36s}

@media(max-width:680px){
  .nav,.r-nav{padding:12px 16px}
  .flow-stepper{padding:10px 16px}
  .fs-line{width:20px;margin:0 4px}
  .fs-label{font-size:11px}
  .nav{flex-wrap:wrap;gap:10px}
  .settings-inline{gap:10px}
  .settings-row{gap:8px}
  .checkers-chips{gap:6px}
  .checker-chip{padding:5px 10px;font-size:12px;gap:4px}
  .chip-emoji{font-size:13px}
  .chip-add{padding:5px 10px;font-size:12px}
  .skill-btn{padding:6px 12px;font-size:13px;gap:4px}
  .skill-icon{font-size:13px}
  .hero{padding:56px 20px 48px}
  .upload-row{grid-template-columns:1fr}.vs-col{display:none}
  .upload-row--script{grid-template-columns:1fr}
  .upload-row--script .script-text-card{min-height:200px}
  .panel-expanded{inset:0;border-radius:0!important}
  .metrics-grid{grid-template-columns:1fr 1fr}
  .fb-cols{grid-template-columns:1fr}
  .overall-card{flex-direction:column;text-align:center;padding:32px 24px}
  .steps-box{width:90vw}
  .r-body{padding:24px 16px 60px}
  .fb-section{margin:0 -16px 32px}.fb-section-inner{padding:0 16px}
  .ss-name{width:80px;font-size:12px}
  .score-summary{padding:16px 16px}
  .bottom-actions-row{flex-direction:column}
  .btn-sec,.btn-publish{flex:unset;width:100%}
  .upload-body{padding:40px 20px}
  .modal-sheet{padding:28px 20px 36px}
  .lang-switch{padding:2px;gap:1px}
  .lang-btn{padding:5px 10px;font-size:11px}
  .platforms-grid{grid-template-columns:repeat(2,1fr)}
  .hero-orb{display:none}
  .limit-card{padding:32px 24px}
}

/* === DEMO SECTION === */
/* === STEPS SLIDER === */
.steps-section{padding:72px 24px 64px;background:var(--bg2)}
.steps-inner{max-width:920px;margin:0 auto}
.steps-header{text-align:center;margin-bottom:48px}
.steps-label{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);padding:4px 12px;border-radius:20px;margin-bottom:14px}
.steps-title{font-family:'Playfair Display',serif;font-size:clamp(22px,4vw,34px);color:var(--ink);letter-spacing:-.02em}

/* Slider container */
.steps-slider-wrap{position:relative;overflow:hidden;border-radius:24px}
.steps-track{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.step-slide{min-width:100%;display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}

/* Visual side */
.step-visual{position:relative;background:linear-gradient(135deg,var(--accent-light) 0%,var(--bg) 100%);padding:48px 36px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;min-height:360px}
.step-visual--analyze{background:linear-gradient(135deg,#eff6ff 0%,var(--bg) 100%)}
.step-visual--results{background:linear-gradient(135deg,#ecfdf5 0%,var(--bg) 100%)}
.step-num-badge{position:absolute;top:20px;left:20px;width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(139,92,246,.35)}

/* Step 1 mockup */
.step-mockup{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}
.step-mock-card{background:var(--card);border:1px solid var(--glass-border);border-radius:14px;padding:16px 14px;text-align:center;min-width:90px;box-shadow:var(--shadow-sm)}
.step-mock-card--accent{border-color:var(--accent-border);background:var(--accent-light)}
.step-mock-label{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.step-mock-icon{font-size:28px;line-height:1;margin-bottom:6px}
.step-mock-hint{font-size:10px;color:var(--ink3)}
.step-mock-vs{font-size:12px;font-weight:600;color:var(--ink3);padding:4px 8px;background:var(--bg3);border-radius:20px}
.step-mock-arrow{font-size:22px;color:var(--accent);font-weight:700}

/* Step 2 mockup */
.step-mockup--analyze{flex-direction:column;gap:20px;width:100%;max-width:280px}
.step-ai-pulse{position:relative;width:80px;height:80px;margin:0 auto;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.step-ai-ring{position:absolute;border-radius:50%;border:2px solid var(--accent);opacity:.4}
.step-ai-ring--1{width:80px;height:80px;animation:aiPulse 2s ease-in-out infinite}
.step-ai-ring--2{width:60px;height:60px;animation:aiPulse 2s ease-in-out infinite .4s}
.step-ai-ring--3{width:40px;height:40px;animation:aiPulse 2s ease-in-out infinite .8s}
@keyframes aiPulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:.15;transform:scale(1.08)}}
.step-ai-core{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;z-index:1}
.step-analyze-bars{display:flex;flex-direction:column;gap:8px;width:100%}
.step-bar-row{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ink2)}
.step-bar-row span{width:52px;flex-shrink:0}
.step-bar-track{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.step-bar-fill{height:100%;border-radius:3px;animation:barGrow .8s ease-out both}
@keyframes barGrow{from{width:0!important}to{}}

/* Step 3 mockup */
.step-mockup--results{flex-direction:column;gap:14px;width:100%;max-width:280px}
.step-result-score{position:relative;width:80px;height:80px;margin:0 auto;flex-shrink:0}
.step-result-score svg{width:100%;height:100%}
.step-result-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--ink)}
.step-result-cards{display:flex;flex-direction:column;gap:6px;width:100%}
.step-result-item{font-size:12px;padding:7px 12px;border-radius:8px;font-weight:500}
.step-result-good{background:var(--green-light);color:#065f46}
.step-result-imp{background:var(--amber-light);color:#92400e}
.step-result-exercise{background:var(--accent-light);color:var(--accent)}

/* Content side */
.step-content{background:var(--card);padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:16px}
.step-title{font-family:'Playfair Display',serif;font-size:clamp(20px,2.5vw,26px);font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.2}
.step-desc{font-size:15px;color:var(--ink2);line-height:1.7}
.step-bullets{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;margin-top:4px}
.step-bullets li{font-size:14px;color:var(--ink2);display:flex;align-items:flex-start;gap:8px;line-height:1.5}

/* Prev / Next buttons */
.steps-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--card);border:1px solid var(--glass-border);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink2);box-shadow:var(--shadow);transition:all .2s;z-index:10}
.steps-nav:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--shadow-accent)}
.steps-prev{left:12px}
.steps-next{right:12px}
.steps-nav:disabled{opacity:.3;cursor:default;pointer-events:none}

/* Dots */
.steps-dots{display:flex;justify-content:center;gap:8px;margin-top:20px}
.steps-dot{width:8px;height:8px;border-radius:50%;background:var(--bg4);border:none;cursor:pointer;transition:all .25s;padding:0}
.steps-dot.active{width:24px;border-radius:4px;background:var(--accent)}

/* CTA */
.steps-cta{text-align:center;margin-top:40px;display:flex;flex-direction:column;align-items:center;gap:10px}
.steps-cta-note{font-size:12px;color:var(--ink3)}

/* Mobile */
@media(max-width:680px){
  .step-slide{grid-template-columns:1fr;grid-template-rows:auto auto}
  .step-visual{min-height:220px;padding:32px 20px}
  .step-content{padding:28px 24px}
  .steps-nav{display:none}
}

/* === TASK 2: NAV PROFILE DROPDOWN === */
.nav-profile{position:relative;display:flex;align-items:center}
.user-avatar-btn{display:flex;align-items:center;gap:8px;background:transparent;border:none;cursor:pointer;padding:6px 12px;border-radius:8px;transition:background .2s;font-family:'Inter',sans-serif}
.user-avatar-btn:hover{background:rgba(0,0,0,.05)}
.user-avatar-initials{width:32px;height:32px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:white;flex-shrink:0}
.user-nav-name{font-size:13px;font-weight:500;color:var(--ink);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.plan-badge{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--accent-light);color:var(--accent);font-weight:600;border:1px solid var(--accent-border)}
.dropdown-arrow{color:var(--ink3);flex-shrink:0;transition:transform .2s}
.user-avatar-btn[aria-expanded="true"] .dropdown-arrow{transform:rotate(180deg)}
.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--card);border:1px solid var(--glass-border);border-radius:12px;padding:8px;box-shadow:0 20px 40px rgba(26,20,48,.12);display:none;z-index:200}
.profile-dropdown.open{display:block}
.dropdown-item{display:block;padding:8px 12px;border-radius:8px;color:var(--ink);text-decoration:none;cursor:pointer;font-size:14px;background:transparent;border:none;width:100%;text-align:left;font-family:'Inter',sans-serif;transition:background .15s}
.dropdown-item:hover{background:rgba(0,0,0,.04)}
.dropdown-divider{height:1px;background:var(--glass-border);margin:4px 0}
.dropdown-signout{color:var(--rose)}
.dropdown-signout:hover{background:var(--rose-light)}

/* === TASK 3: SKILL LEVEL SELECTOR === */
.skill-selector{margin-bottom:24px;text-align:center}
.skill-label{display:block;font-size:13px;color:var(--ink3);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.skill-toggle{display:inline-flex;background:rgba(0,0,0,.04);border-radius:12px;padding:4px;gap:4px;border:1px solid var(--glass-border)}
.skill-btn{padding:8px 16px;border-radius:9px;border:1.5px solid transparent;background:transparent;color:var(--ink3);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:6px;font-family:'Inter',sans-serif}
.skill-btn.active{background:var(--card);color:var(--ink);box-shadow:0 2px 8px rgba(26,20,48,.1),0 0 0 2px var(--accent-glow);border-color:var(--accent)}
.skill-btn:hover:not(.active){color:var(--ink);background:rgba(0,0,0,.03)}
.skill-icon{font-size:15px;line-height:1}

.upload-card-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}

/* === TASK 4: MODE TABS === */
.mode-tabs{display:flex;gap:8px;margin-bottom:24px;background:rgba(0,0,0,.03);border-radius:12px;padding:4px;width:fit-content;border:1px solid var(--glass-border)}
.mode-tab{padding:8px 20px;border-radius:9px;border:none;background:transparent;color:var(--ink3);cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;transition:all .2s;font-family:'Inter',sans-serif}
.mode-tab.active{background:var(--card);color:var(--ink);box-shadow:0 2px 8px rgba(26,20,48,.08)}
.mode-tab:hover:not(.active){color:var(--ink);background:rgba(0,0,0,.03)}
.script-text-card{display:none;background:var(--card);border:1px solid var(--glass-border);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm)}
.script-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.btn-generate-ai{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1.5px solid var(--accent-border,rgba(139,92,246,.25));background:var(--accent-light,#f5f3ff);color:var(--accent);cursor:pointer;font-size:12px;font-weight:600;font-family:'Inter',sans-serif;transition:all .2s;white-space:nowrap}
.btn-generate-ai:hover{background:var(--accent);color:#fff;box-shadow:0 4px 14px rgba(139,92,246,.25)}
.gen-form{margin:20px 0 16px}
.gen-prompt-input{width:100%;background:var(--bg2);border:1px solid var(--glass-border);border-radius:10px;color:var(--ink);font-size:14px;padding:12px;resize:none;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s}
.gen-prompt-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,92,246,.08)}
.gen-tags{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.gen-tag-group{display:flex;align-items:center;gap:8px;position:relative}
.gen-profile-group{background:var(--accent-light);border-radius:10px;padding:6px 10px;margin:0 -10px}
.gen-profile-group+.gen-profile-group{margin-top:-4px;border-top:1px solid rgba(139,92,246,.1)}
.gen-profile-group:last-of-type{margin-bottom:4px;border-radius:0 0 10px 10px}
.gen-profile-group:first-of-type{border-radius:10px 10px 0 0}
.gen-tag-label{font-size:11px;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;min-width:70px}
.gen-tag-row{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:2px 0}
.gen-tag-row::-webkit-scrollbar{display:none}
.gen-tag{padding:5px 12px;border-radius:20px;background:var(--bg2);border:1px solid var(--glass-border);font-size:12px;color:var(--ink2);cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;white-space:nowrap;flex-shrink:0}
.gen-tag:hover{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent)}
.gen-tag.active{background:var(--accent);border-color:var(--accent);color:#fff}
.gen-clear-btn{background:none;border:none;color:var(--ink3);font-size:12px;cursor:pointer;padding:4px 0;margin-top:4px;font-family:'Inter',sans-serif;transition:color .2s;align-self:flex-start}
.gen-clear-btn:hover{color:var(--accent)}
.gen-result{margin-top:16px;padding:14px;background:var(--bg2);border:1px solid var(--glass-border);border-radius:12px}
.gen-result-header{display:flex;gap:4px;margin-bottom:8px}
.gen-result-text{font-size:13px;line-height:1.6;color:var(--ink);max-height:200px;overflow-y:auto;white-space:pre-wrap}
.gen-result-text mark,.script-textarea-mark{background:rgba(250,204,21,.35);border-radius:2px;padding:0 1px}
.gen-result-actions{display:flex;gap:10px;margin-top:12px;justify-content:center}
.gen-result-btn{display:flex;align-items:center;gap:6px;padding:8px 20px;border-radius:10px;border:1px solid var(--glass-border);font-size:13px;font-family:'Inter',sans-serif;cursor:pointer;transition:all .2s;font-weight:500}
.gen-dislike{background:var(--bg3);color:var(--ink2)}
.gen-dislike:hover{background:#fee;border-color:#e88;color:#c44}
.gen-like{background:linear-gradient(135deg,var(--accent),#a78bfa);border-color:transparent;color:#fff}
.gen-like:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,92,246,.3)}
.modal-btn-go{display:flex;align-items:center;justify-content:center;gap:6px}
.gen-spin{display:inline-block;animation:genBounce 0.6s ease-in-out infinite alternate;font-size:16px}
@keyframes genBounce{0%{transform:translateY(0) rotate(-10deg)}100%{transform:translateY(-4px) rotate(10deg)}}
#generate-modal{align-items:center;justify-content:center}
#generate-modal .modal-sheet{border-radius:20px;width:100%}
#generate-modal .modal-actions{justify-content:center}
@media(max-width:540px){#generate-modal .modal-sheet{border-radius:16px;margin:16px}}
.script-textarea{width:100%;min-height:200px;background:var(--bg2);border:1px solid var(--glass-border);border-radius:10px 10px 0 0;color:var(--ink);font-size:15px;padding:14px;resize:vertical;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s}
.script-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,92,246,.08)}
.text-field-wrap{display:flex;flex-direction:column}
.text-toolbar{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg2);border:1px solid var(--glass-border);border-top:none;border-radius:0 0 10px 10px}
.text-toolbar-sm{border-radius:0 0 12px 12px}
.text-tool{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink3);border-radius:6px;cursor:pointer;transition:all .15s}
.text-tool:hover{background:var(--accent-light);color:var(--accent)}
.text-tool.active{background:var(--accent);color:#fff}
.text-tool-ok{color:var(--accent)!important;animation:toolOk .6s ease}
@keyframes toolOk{0%{transform:scale(1.3)}100%{transform:scale(1)}}
.script-char-count{font-size:12px;color:var(--ink3);margin-left:auto}

/* Upload action buttons (Upload / Record) */
.drop-card--actions{cursor:default}
.drop-card--actions:hover{transform:none;box-shadow:var(--shadow-sm);border-color:var(--accent-border);background:var(--accent-light)}
.d-upload-actions{display:flex;gap:10px;width:100%;justify-content:center;margin-top:2px}
.btn-upload-action{display:flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;border:1.5px solid var(--glass-border);background:var(--card);color:var(--ink);cursor:pointer;font-size:13px;font-weight:500;font-family:'Inter',sans-serif;transition:all .2s;flex:1;justify-content:center;max-width:130px;white-space:nowrap}
.btn-upload-action svg{flex-shrink:0}
.btn-upload-file:hover{background:var(--accent-light);border-color:var(--accent-border);color:var(--accent)}
.btn-upload-record{border-color:var(--rose-light, var(--glass-border))}
.btn-upload-record:hover{background:var(--rose-light);border-color:var(--rose);color:var(--rose)}

/* === TASK 5: CAMERA RECORDER === */
.btn-record{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:1px solid var(--glass-border);background:transparent;color:var(--ink);cursor:pointer;font-size:14px;font-family:'Inter',sans-serif;transition:all .2s}
.btn-record:hover{background:var(--rose-light);border-color:var(--rose);color:var(--rose)}
.btn-record svg{flex-shrink:0}

/* Camera modal */
.modal{background:var(--card);border:1px solid var(--glass-border);border-radius:20px;padding:28px;width:100%;box-shadow:var(--shadow-xl)}
.camera-modal-inner{max-width:640px;width:100%}
.camera-preview-wrap{position:relative;background:#000;border-radius:12px;overflow:hidden;aspect-ratio:16/9;margin-bottom:16px}
.cam-video{width:100%;height:100%;object-fit:cover;display:block}
#cam-preview{transform:scaleX(-1)}
.rec-indicator{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.6);border-radius:20px;padding:4px 12px;color:white}
.rec-dot{width:10px;height:10px;border-radius:50%;background:var(--rose);flex-shrink:0;animation:recBlink 1s infinite}
@keyframes recBlink{0%,100%{opacity:1}50%{opacity:.3}}
.rec-timer{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}
.camera-controls{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.btn{font-family:'Inter',sans-serif;font-size:14px;font-weight:600;padding:10px 22px;border-radius:10px;border:none;cursor:pointer;transition:all .2s}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 14px rgba(139,92,246,.3)}
.btn-primary:hover{background:var(--accent2);transform:translateY(-1px)}
.btn-danger{background:var(--rose);color:white}
.btn-danger:hover{opacity:.9;transform:translateY(-1px)}
.btn-secondary{background:var(--bg2);color:var(--ink);border:1px solid var(--glass-border)}
.btn-secondary:hover{background:var(--bg3)}
.btn-ghost{background:transparent;color:var(--ink3);border:1px solid var(--glass-border)}
.btn-ghost:hover{background:var(--bg2);color:var(--ink)}

/* Modal overlay centering for camera */
#camera-modal{align-items:center;justify-content:center}

/* === PANEL EXPAND (card → modal) === */
.btn-panel-expand{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--glass-border);border-radius:8px;background:var(--bg2);color:var(--ink3);cursor:pointer;padding:0;transition:border-color .2s,color .2s,background .2s;flex-shrink:0}
.btn-panel-expand:hover{border-color:var(--accent-border);color:var(--accent);background:var(--accent-light)}
.btn-panel-expand--card{position:absolute;top:10px;right:10px;z-index:5}
.btn-panel-collapse{display:none;position:absolute;top:16px;right:16px;z-index:10;width:32px;height:32px;border-radius:50%;border:none;background:var(--bg2);color:var(--ink2);cursor:pointer;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:background .2s,color .2s}
.btn-panel-collapse:hover{background:var(--bg3);color:var(--ink)}
.panel-expand-backdrop{display:none;position:fixed;inset:0;background:rgba(26,20,48,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:201}
.panel-expand-backdrop.open{display:block}
.panel-expanded{position:fixed!important;inset:24px;z-index:202;border-radius:20px!important;box-shadow:var(--shadow-xl);overflow-y:auto;background:var(--card);animation:panelExpand .3s cubic-bezier(.4,0,.2,1)}
.panel-expanded .btn-panel-expand{display:none}
.panel-expanded .btn-panel-collapse{display:flex}
@keyframes panelExpand{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
/* Script card expanded — textarea fills the modal */
.script-text-card.panel-expanded{display:flex;flex-direction:column}
.script-text-card.panel-expanded .script-card-header{padding-right:44px}
.script-text-card.panel-expanded .text-field-wrap{flex:1;display:flex;flex-direction:column}
.script-text-card.panel-expanded .script-textarea{flex:1;min-height:unset;font-size:16px;resize:none}
/* Video card expanded */
#card-mine.panel-expanded{cursor:default}
#card-mine.panel-expanded .type-badge{position:static;align-self:flex-start;margin-bottom:12px}

/* === UPLOAD FLOW: SIDE-BY-SIDE LAYOUT (Script Reading) === */
.upload-row--script{grid-template-columns:1fr 1fr;gap:20px}
.upload-row--script .script-text-card{display:flex;flex-direction:column;min-height:380px;margin-bottom:0;border-radius:var(--r)}
.upload-row--script .text-field-wrap{flex:1;display:flex;flex-direction:column}
.upload-row--script .script-textarea{flex:1;min-height:120px;resize:none}
.upload-row--script #card-mine{min-height:380px}


/* === INLINE CAMERA (Script Reading desktop) === */
.cam-inline-active .d-placeholder{display:none!important}
.cam-inline-active .d-filled{display:none!important}
.cam-inline-ui{width:100%;display:flex;flex-direction:column;gap:10px}
.cam-inline-close{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.55);border:none;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;line-height:1}
.cam-inline-active{border-style:solid!important;border-color:var(--rose)!important;background:var(--rose-light)!important;cursor:default!important}
.cam-inline-active:hover{transform:none!important}

/* === RESPONSIVE ADDITIONS === */
@media(max-width:480px){
  .fs-label{display:none}
  .fs-line{width:16px;margin:0 6px}
  .flow-stepper{flex-wrap:wrap}
  .settings-row-label{font-size:10px}
  .checkers-count{font-size:10px;padding:1px 6px}
  .checker-chip{padding:5px 9px;font-size:11px}
  .chip-check{font-size:10px}
  .chip-emoji{font-size:12px}
  .chip-add{padding:5px 9px;font-size:11px}
  .skill-btn{padding:6px 10px;font-size:12px}
  .hero-title-main{font-size:2.2rem}
  .hero-title-sub{font-size:1.1rem}
  .skill-toggle{flex-wrap:wrap;width:100%;justify-content:center}
  .mode-tabs{width:100%;justify-content:center}
  #camera-modal .modal{border-radius:0;min-height:100vh;display:flex;flex-direction:column;justify-content:center}
  #camera-modal{padding:0}
  .camera-modal-inner{max-width:100%;height:100vh;border-radius:0}
}
@media(max-width:680px){
  .user-nav-name{display:none}
  .hero-title-main{font-size:2.4rem}
}

/* === MOBILE FIXES === */

/* Fix: script mode upload row — base rule (.upload-row--script{grid-template-columns:1fr 1fr})
   appears after the 680px media query, so it overrides it. Re-override here at the end. */
@media(max-width:680px){
  .upload-row--script{grid-template-columns:1fr!important;gap:16px!important}
  .upload-row--script .script-text-card,
  .upload-row--script #card-mine{min-height:260px}
  .upload-row--script .script-textarea{min-height:160px}
}

/* Fix: nav overflow — too many items for 430px */
@media(max-width:680px){
  .nav-pill{display:none}
  .usage-badge{display:none!important}
  .nav-right{gap:8px;flex-wrap:nowrap}
}
@media(max-width:480px){
  .nav-right{gap:6px}
  .lang-btn{padding:5px 8px;font-size:11px}
  .btn-auth{padding:5px 10px;font-size:11px}
  /* Fix: mode tabs — each tab takes equal share of full width */
  .mode-tab{flex:1;justify-content:center;padding:8px 10px;font-size:13px}
  /* Fix: reduce upload body horizontal padding for more content space */
  .upload-body{padding:24px 14px 60px}
  .drop-card{padding:28px 16px}
  .d-upload-actions{gap:8px}
  .btn-upload-action{padding:8px 10px;font-size:12px;max-width:unset}
}
