*{box-sizing:border-box}
body{margin:0;background:#0e0b1a;color:#e9e7f5;font-family:"Inter",-apple-system,"Segoe UI",sans-serif;font-size:14px;line-height:1.5;min-height:100vh}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(600px 400px at 10% -10%,#6d28d988 0,transparent 60%),
  radial-gradient(500px 400px at 100% 0%,#db277788 0,transparent 60%),
  radial-gradient(700px 500px at 50% 120%,#2563eb55 0,transparent 60%)}

/* centered card (login/register) */
.wrap{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px}
.card-auth{background:#ffffff08;border:1px solid #ffffff15;border-radius:14px;padding:32px;width:100%;max-width:420px;backdrop-filter:blur(10px)}
.card-auth h1{font-size:22px;font-weight:700;margin:0 0 20px;letter-spacing:-0.01em}

/* app shell: sidebar + main */
.app{position:relative;z-index:1;display:grid;grid-template-columns:240px 1fr;min-height:100vh}
aside{padding:24px 18px;border-right:1px solid #ffffff0f;background:#0c0918cc;backdrop-filter:blur(20px)}
.logo{font-size:19px;font-weight:800;letter-spacing:-0.02em;display:flex;align-items:center;gap:8px;margin-bottom:30px;color:#fff;text-decoration:none}
.logo .i{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#a78bfa,#ec4899);display:flex;align-items:center;justify-content:center;font-size:15px}

nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;color:#b7b3d1;text-decoration:none;border-radius:8px;font-size:14px;font-weight:500;margin-bottom:3px}
nav a:hover{background:#ffffff0a;color:#fff}
nav a.active{background:linear-gradient(90deg,#6d28d940,#ec489920);color:#fff;box-shadow:inset 0 0 0 1px #ffffff15}
nav .sec{font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:#7a7599;margin:22px 12px 8px}

.usage{margin-top:30px;padding:14px;background:#ffffff08;border-radius:10px;border:1px solid #ffffff10}
.usage .t{font-size:12px;color:#b7b3d1;margin-bottom:8px;display:flex;justify-content:space-between}
.usage .bar{height:6px;background:#ffffff10;border-radius:3px;overflow:hidden}
.usage .bar > div{height:100%;background:linear-gradient(90deg,#a78bfa,#ec4899)}
.usage .h{font-size:11px;color:#7a7599;margin-top:8px}

main{padding:24px 32px 60px;max-width:1200px}

.topbar{display:flex;align-items:center;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.topbar h1{font-size:24px;font-weight:700;margin:0;letter-spacing:-0.01em}
.topbar .spacer{flex:1}

.btn{background:#ffffff0e;color:#fff;border:1px solid #ffffff18;padding:8px 14px;border-radius:8px;font-size:13px;cursor:pointer;font-family:inherit;font-weight:500;text-decoration:none;display:inline-block}
.btn:hover{background:#ffffff16}
.btn.primary{background:linear-gradient(135deg,#8b5cf6,#ec4899);border:none;padding:9px 16px;box-shadow:0 6px 20px #ec489944}
.btn.primary:hover{filter:brightness(1.1)}
.btn-ghost{background:#ffffff0e;border:1px solid #ffffff18;padding:6px 12px;border-radius:8px;color:#fff;font:inherit;font-size:13px;cursor:pointer;text-decoration:none;display:inline-block}
.btn-ghost:hover{background:#ffffff18}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.kpi{padding:18px 20px;border-radius:14px;background:#ffffff08;border:1px solid #ffffff10;backdrop-filter:blur(10px)}
.kpi .k{color:#b7b3d1;font-size:12px;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.kpi .v{font-size:28px;font-weight:700;letter-spacing:-0.01em}
.kpi .d{font-size:12px;color:#4ade80;margin-top:4px}
.kpi .d.down{color:#fb7185}
.kpi.accent{background:linear-gradient(135deg,#6d28d955,#ec489933);border-color:#ffffff25}
@media (max-width:900px){.kpis{grid-template-columns:repeat(2,1fr)}}

/* inline dropzone on dashboard */
.dropzone{padding:24px;border-radius:14px;margin-bottom:26px;background:#ffffff06;border:1.5px dashed #ffffff25;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.dropzone .icn{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,#a78bfa,#ec4899);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;color:#fff}
.dropzone .t1{font-size:15px;font-weight:600;margin-bottom:2px}
.dropzone .t2{color:#b7b3d1;font-size:13px}
.dropzone-grow{flex:1;min-width:200px}
.dropzone input[type=url]{flex:1;min-width:180px;background:#0c0918;border:1px solid #ffffff15;border-radius:10px;padding:10px 14px;color:#fff;font-family:inherit;font-size:14px;outline:none;max-width:340px}

/* grid: featured + side */
.grid2{display:grid;grid-template-columns:1.4fr 1fr;gap:22px}
@media (max-width:1000px){.grid2{grid-template-columns:1fr}}

/* cards */
.card{background:#ffffff08;border:1px solid #ffffff10;border-radius:16px;padding:22px;backdrop-filter:blur(10px);margin-bottom:22px}
.card h2{font-size:16px;font-weight:700;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.card h2 .dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#a78bfa,#ec4899)}

/* hero (featured breakdown) */
.hero{display:grid;grid-template-columns:200px 1fr;gap:20px}
@media (max-width:600px){.hero{grid-template-columns:1fr}}
.hero .thumb{aspect-ratio:9/16;border-radius:12px;background:linear-gradient(135deg,#1a1430,#3a1a4a);position:relative;overflow:hidden;max-width:200px}
.hero .thumb::after{content:"▶";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:38px;color:#fff;opacity:0.8}
.hero .thumb .time{position:absolute;bottom:8px;right:8px;background:#0009;color:#fff;font-size:11px;padding:2px 7px;border-radius:4px}
.hero .meta .src{display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;background:linear-gradient(90deg,#ec489933,#a78bfa33);color:#e9b3f0;margin-bottom:10px;letter-spacing:0.02em}
.hero .meta h3{margin:0 0 8px;font-size:18px;font-weight:700;line-height:1.3}
.hero .meta h3 a{color:inherit;text-decoration:none}
.hero .meta h3 a:hover{color:#c4b5fd}
.hero .meta .sub{color:#b7b3d1;font-size:12px;margin-bottom:14px}
.score{display:flex;gap:14px;margin-top:10px;flex-wrap:wrap}
.score .s{background:#ffffff08;padding:8px 12px;border-radius:10px;border:1px solid #ffffff10;min-width:70px}
.score .s .k{font-size:10px;color:#7a7599;text-transform:uppercase;letter-spacing:0.08em}
.score .s .v{font-size:18px;font-weight:700}
.score .s.hl .v{background:linear-gradient(90deg,#a78bfa,#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent}

.pills{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 4px}
.pill{font-size:12px;padding:5px 11px;border-radius:999px;background:#ffffff0c;border:1px solid #ffffff12;color:#d3cfe8}
.pill.good{background:#10b98122;border-color:#10b98144;color:#6ee7b7}
.pill.warn{background:#f59e0b22;border-color:#f59e0b44;color:#fcd34d}

/* active queue */
.queue .q{display:flex;align-items:center;gap:12px;padding:10px 0;border-top:1px solid #ffffff0d;text-decoration:none;color:inherit}
.queue .q:first-of-type{border-top:none}
.queue .q:hover{background:#ffffff05;margin:0 -8px;padding:10px 8px;border-radius:6px}
.queue .t{flex:1;font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.queue .t .sub{color:#7a7599;font-size:11px;margin-top:2px;white-space:normal}
.queue .status{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:600;flex-shrink:0}
.st-ok{background:#10b98122;color:#6ee7b7}
.st-run{background:#f59e0b22;color:#fcd34d}
.st-q{background:#ffffff0c;color:#b7b3d1}
.st-err{background:#fb718522;color:#fecaca}

/* patterns list */
.plist{display:grid;gap:10px}
.plist .r{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #ffffff0d;font-size:13px}
.plist .r:last-child{border-bottom:none}
.plist .r b{color:#fff}

/* forms (login/register/new) */
label{display:block;font-size:12px;color:#b7b3d1;margin:14px 0 6px}
input[type=email],input[type=password],input[type=url],input[type=text]{width:100%;background:#0c0918;border:1px solid #ffffff15;border-radius:10px;padding:10px 14px;color:#fff;font:inherit;outline:none}
input[type=email]:focus,input[type=password]:focus,input[type=url]:focus,input[type=text]:focus{border-color:#a78bfa}
input[type=file]{color:#b7b3d1;font:inherit}
button[type=submit]{margin-top:20px;width:100%;background:linear-gradient(135deg,#8b5cf6,#ec4899);border:none;padding:11px 16px;border-radius:10px;color:#fff;font:inherit;font-weight:600;cursor:pointer;box-shadow:0 6px 20px #ec489944}
button[type=submit]:hover{filter:brightness(1.1)}
.err{margin-top:14px;padding:10px 12px;background:#fb718522;border:1px solid #fb718555;border-radius:8px;color:#fecdd3;font-size:13px}
.links{margin-top:18px;text-align:center;font-size:13px;color:#b7b3d1}
.links a{color:#c4b5fd;text-decoration:none}
.links a:hover{text-decoration:underline}
.sub{color:#7a7599;font-size:12px;margin-top:4px}

/* misc */
a{color:#c4b5fd}
a:hover{color:#e9b3f0}

/* ideas (apply to your content) */
.ideas{display:grid;gap:10px}
.ideas .idea{padding:12px 14px;border-radius:10px;background:#ffffff06;border:1px solid #ffffff0e;font-size:13px;line-height:1.55}
.ideas .idea b{background:linear-gradient(90deg,#a78bfa,#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent;margin-right:6px}

/* key frames gallery */
.frames{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.frame{position:relative;border-radius:10px;overflow:hidden;border:1px solid #ffffff10;background:#0c0918;aspect-ratio:9/16}
.frame img{width:100%;height:100%;object-fit:cover;display:block}
.frame .tm{position:absolute;bottom:6px;right:6px;background:#0009;color:#fff;font-size:11px;padding:2px 7px;border-radius:4px;font-variant-numeric:tabular-nums}
.frame .vd{position:absolute;inset:0;background:#0e0b1af0;color:#e9e7f5;padding:10px;font-size:11px;line-height:1.45;opacity:0;transition:opacity .18s;overflow:auto;backdrop-filter:blur(2px)}
.frame:hover .vd{opacity:1}

/* video player wrapper */
.video-wrap{background:#0c0918;border-radius:12px;overflow:hidden;border:1px solid #ffffff10;max-width:320px}
.video-wrap video{width:100%;height:auto;display:block;max-height:560px;background:#000}

/* reach risks — главная фишка анализа */
.risks{display:grid;gap:10px}
.risks .r{padding:12px 14px;border-radius:10px;background:#fb718514;border:1px solid #fb718540;color:#fecdd3;font-size:13px;line-height:1.55;display:flex;gap:10px;align-items:flex-start}
.risks .r::before{content:"⚠";flex-shrink:0;color:#fb7185;font-size:16px;line-height:1.3}

/* drop points */
.drops{display:grid;gap:8px}
.drops .d{display:grid;grid-template-columns:52px 1fr;gap:12px;padding:10px 12px;border-radius:10px;background:#f59e0b14;border:1px solid #f59e0b40;align-items:center}
.drops .d .tm{font-weight:700;color:#fcd34d;font-variant-numeric:tabular-nums;font-size:13px}
.drops .d .why{font-size:13px;color:#fef3c7;line-height:1.5}

/* technical checklist */
.tech{display:grid;gap:8px}
.tech .row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:#ffffff06;font-size:13px}
.tech .row.bad{background:#fb718514;border:1px solid #fb718530}
.tech .row.good{background:#10b98114;border:1px solid #10b98130}
.tech .row .ico{flex-shrink:0;width:20px;text-align:center;font-weight:700}
.tech .row.good .ico{color:#6ee7b7}
.tech .row.bad .ico{color:#fb7185}
.tech .aq-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;margin-left:auto}
.tech .aq-good{background:#10b98122;color:#6ee7b7}
.tech .aq-ok{background:#f59e0b22;color:#fcd34d}
.tech .aq-poor{background:#fb718522;color:#fb7185}
.tech .notes{padding:0 10px;font-size:12px;color:#b7b3d1;line-height:1.55}
.tech .notes li{margin-top:4px}

/* hook quote */
.hook-quote{padding:14px 16px;border-radius:12px;background:linear-gradient(135deg,#6d28d933,#ec489922);border:1px solid #ffffff20;font-style:italic;font-size:14px;line-height:1.55;color:#e9e7f5}

/* library grid */
.lib-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.lib-filters select{background:#0c0918;border:1px solid #ffffff15;border-radius:10px;padding:8px 14px;color:#fff;font:inherit;font-size:13px;outline:none;cursor:pointer}
.lib-filters select:focus{border-color:#a78bfa}
.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.lib-card{background:#ffffff08;border:1px solid #ffffff10;border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:border-color .15s}
.lib-card:hover{border-color:#ffffff25}
.lib-card .thumb{aspect-ratio:9/16;background:#1a1430;background-size:cover;background-position:center;position:relative}
.lib-card .thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,#000a 100%)}
.lib-card .time{position:absolute;bottom:8px;right:8px;background:#0009;color:#fff;font-size:11px;padding:2px 7px;border-radius:4px;z-index:1}
.lib-card .score-badge{position:absolute;top:8px;left:8px;background:linear-gradient(135deg,#a78bfa,#ec4899);color:#fff;font-size:13px;font-weight:700;padding:4px 10px;border-radius:999px;z-index:1}
.lib-card .status-badge{position:absolute;top:8px;left:8px;font-size:11px;padding:3px 9px;border-radius:999px;font-weight:600;z-index:1}
.lib-card .body{padding:12px 14px;flex:1;display:flex;flex-direction:column;gap:4px}
.lib-card .t{font-size:13px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lib-card .meta{font-size:11px;color:#7a7599;margin-top:auto;padding-top:6px}
.lib-card .src{font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:#c4b5fd}

/* empty state */
.empty{text-align:center;padding:60px 22px;color:#b7b3d1}
.empty h2{justify-content:center;margin-bottom:6px}
.empty p{max-width:440px;margin:6px auto 18px}

/* patterns bars */
.bars{display:grid;gap:12px}
.bars .row{display:grid;grid-template-columns:180px 1fr 60px;gap:12px;align-items:center;font-size:13px}
.bars .label{color:#d3cfe8}
.bars .val{text-align:right;font-weight:700;font-variant-numeric:tabular-nums}
.bars .track{height:10px;background:#ffffff0c;border-radius:5px;overflow:hidden;border:1px solid #ffffff10}
.bars .fill{height:100%;background:linear-gradient(90deg,#a78bfa,#ec4899);border-radius:5px}
@media (max-width:600px){.bars .row{grid-template-columns:1fr 50px;grid-template-rows:auto auto}.bars .track{grid-column:1 / -1}}

/* timeline reused for structure/transcript */
.tl{margin-top:6px}
.tl .row{display:grid;grid-template-columns:50px 1fr auto;gap:12px;padding:10px 0;border-top:1px solid #ffffff0d;align-items:center}
.tl .row:first-child{border-top:none}
.tl .tm{font-weight:700;color:#e9b3f0;font-variant-numeric:tabular-nums;font-size:13px}
.tl .tx{font-size:13px}
.tl .tg{font-size:11px;color:#7a7599;padding:2px 8px;background:#ffffff08;border-radius:999px}
