*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:var(--bg-app, #e9ebf0);font-family:var(--font-sans, system-ui);color:var(--text-main)}.dark body{background:#05080f}#root{height:100%}button{font-family:inherit}svg.lucide{width:18px;height:18px;flex:0 0 auto}.tv-stage{height:100vh;display:grid;place-items:center;padding:0}.tv-app{width:100%;max-width:440px;height:100%;max-height:920px;background:var(--bg-body);display:flex;flex-direction:column;overflow:hidden;position:relative}@media(min-width:480px){.tv-stage{padding:24px}.tv-app{border-radius:28px;box-shadow:0 30px 80px #0f172a40;border:1px solid var(--border-subtle)}}.tv-pin{flex:1;display:flex;flex-direction:column}.tv-pin-hero{background:var(--brand-gradient-deep, linear-gradient(150deg,#ea580c,#f97316));color:#fff;padding:48px 28px 36px}.tv-pin-hero .tvh-logo{width:56px;height:56px;border-radius:16px;background:#ffffff29;display:grid;place-items:center;margin-bottom:20px}.tv-pin-hero .tvh-logo .lucide{width:30px;height:30px}.tv-pin-hero h1{font-size:1.7rem;margin:0 0 6px;letter-spacing:-.02em}.tv-pin-hero p{margin:0;color:#ffffffd9;font-size:var(--fs-sm)}.tv-pin-body{flex:1;padding:28px;display:flex;flex-direction:column}.tv-pin-label{font-size:var(--fs-sm);font-weight:650;color:var(--text-strong);margin-bottom:12px}.tv-pin-dots{display:flex;gap:12px;justify-content:center;margin:8px 0 28px}.tv-pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border-strong);transition:all var(--dur-fast)}.tv-pin-dot.filled{background:var(--accent-strong);border-color:var(--accent-strong)}.tv-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.tv-key{height:60px;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-subtle);font-size:1.4rem;font-weight:600;color:var(--text-strong);cursor:pointer;transition:all var(--dur-fast)}.tv-key:hover{border-color:var(--border-flame)}.tv-key:active{transform:scale(.96);background:var(--bg-flame-soft)}.tv-key:disabled{cursor:default;opacity:.6}.tv-key.ghost{background:none;border-color:transparent;color:var(--text-muted)}.tv-key .lucide{width:22px;height:22px}.tv-pin-foot{margin-top:20px;text-align:center;font-size:var(--fs-xs);color:var(--text-faint);display:flex;align-items:center;justify-content:center;gap:6px}.tv-pin-foot .lucide{width:13px;height:13px}.tv-pin-err{color:var(--status-danger);font-size:var(--fs-xs);text-align:center;min-height:18px;margin-bottom:4px}.tv-head{padding:20px 22px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:12px}.tv-head .tvh-av{width:42px;height:42px;border-radius:50%;background:var(--brand-gradient);color:#fff;display:grid;place-items:center;font-weight:700;flex:0 0 auto}.tv-head .tvh-name{font-size:var(--fs-h4);font-weight:700;color:var(--text-strong)}.tv-head .tvh-sub{font-size:var(--fs-xs);color:var(--text-muted)}.tv-head .tvh-out{margin-left:auto;width:38px;height:38px;border-radius:10px;border:0;background:var(--bg-subtle);color:var(--text-muted);cursor:pointer;display:grid;place-items:center}.tv-head .tvh-out:disabled{opacity:.5;cursor:default}.tv-head .tvh-out .lucide{width:18px;height:18px}.tv-body{flex:1;overflow-y:auto;padding:18px 18px 90px}.tv-sec-label{font-size:var(--fs-2xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);margin:6px 4px 10px;display:flex;align-items:center;gap:6px}.tv-sec-label .lucide{width:14px;height:14px}.tv-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-soft)}.tv-card .tvc-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}.tv-card .tvc-ico{width:38px;height:38px;border-radius:11px;background:var(--bg-flame-soft);color:var(--accent-strong);display:grid;place-items:center;flex:0 0 auto}.tv-card .tvc-ico .lucide{width:19px;height:19px}.tv-card .tvc-title{font-size:var(--fs-sm);font-weight:700;color:var(--text-strong)}.tv-card .tvc-sub{font-size:var(--fs-xs);color:var(--text-muted);margin-top:1px}.tv-card .tvc-rows{border-top:1px solid var(--border-subtle);margin-top:12px;padding-top:10px;display:flex;flex-direction:column;gap:7px}.tv-card .tvc-row{display:flex;align-items:center;justify-content:space-between;font-size:var(--fs-xs);gap:12px}.tv-card .tvc-row .k{color:var(--text-muted);flex:0 0 auto}.tv-card .tvc-row .v{color:var(--text-strong);font-weight:600;text-align:right}.tv-card .tvc-row .v a{color:var(--accent-strong);text-decoration:none}.tv-bigbtn{width:100%;height:50px;border-radius:var(--radius-lg);border:0;background:var(--brand-gradient);color:#fff;font-size:var(--fs-body);font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-flame)}.tv-bigbtn.sec{background:var(--bg-subtle);color:var(--text-strong);border:1px solid var(--border-default);box-shadow:none}.tv-bigbtn:disabled{opacity:.6;cursor:default}.tv-bigbtn .lucide{width:19px;height:19px}.tv-bottom{position:absolute;left:0;right:0;bottom:0;height:66px;border-top:1px solid var(--border-subtle);background:var(--bg-body);display:flex}.tv-bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:0;background:none;cursor:pointer;color:var(--text-muted);font-size:10px;font-weight:600}.tv-bn .lucide{width:22px;height:22px}.tv-bn.active{color:var(--accent-strong)}.tv-pill{font-size:var(--fs-2xs);font-weight:700;padding:3px 9px;border-radius:999px;letter-spacing:.02em;flex:0 0 auto;white-space:nowrap}.tv-pill.active,.tv-pill.approved,.tv-pill.confirmed{background:var(--status-success-soft, rgba(34,197,94,.14));color:var(--status-success, #16a34a)}.tv-pill.planned,.tv-pill.pending,.tv-pill.new{background:var(--bg-flame-soft);color:var(--accent-strong)}.tv-pill.completed,.tv-pill.standard{background:var(--bg-subtle);color:var(--text-muted)}.tv-pill.cancelled,.tv-pill.rejected{background:#dc26261f;color:var(--status-danger)}.tv-empty{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:var(--fs-sm)}.tv-empty .lucide{width:34px;height:34px;color:var(--text-faint);margin-bottom:12px}.tv-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:50px 20px;color:var(--text-muted);font-size:var(--fs-sm)}.tv-spin{width:18px;height:18px;animation:tv-spin .9s linear infinite;flex:0 0 auto}@keyframes tv-spin{to{transform:rotate(360deg)}}.tv-error{margin:0 0 12px;padding:12px 14px;border-radius:var(--radius-md);background:#dc26261a;border:1px solid rgba(220,38,38,.25);color:var(--status-danger);font-size:var(--fs-xs)}.tv-toast{position:absolute;left:18px;right:18px;bottom:80px;background:var(--bg-inverted);color:var(--bg-body);padding:14px 16px;border-radius:var(--radius-md);display:flex;align-items:center;gap:10px;font-size:var(--fs-sm);box-shadow:var(--shadow-lg)}.tv-toast .lucide{width:18px;height:18px;color:var(--brand-flame-300)}.tv-soon{font-size:var(--fs-xs);color:var(--text-faint);padding:14px 4px;text-align:center;line-height:var(--lh-snug)}
