:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #eef2ff;--primary-rgb: 99, 102, 241;--bg-page: #f6f7fb;--bg-soft: #f1f2f8;--bg-softer: #eaecf5;--bg-white: #ffffff;--ink: #1e1b4b;--ink-soft: #475569;--muted: #94a3b8;--border: #e5e7f0;--radius: 14px;--radius-sm: 10px;--radius-lg: 20px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow: 0 8px 24px -8px rgba(15, 23, 42, .15);--shadow-lg: 0 20px 40px -12px rgba(15, 23, 42, .2);--shadow-primary: 0 14px 30px -8px rgba(var(--primary-rgb), .35);--header-h: 64px;--sidebar-w: 240px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg-page);background-image:radial-gradient(1200px 600px at 100% 0%,rgba(var(--primary-rgb),.1),transparent 60%),radial-gradient(900px 500px at 0% 100%,rgba(var(--primary-rgb),.06),transparent 60%);background-attachment:fixed;letter-spacing:-.01em;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-dark)}button{font-family:inherit}.muted{color:var(--ink-soft)}.tiny{font-size:.78rem}.row{display:flex;align-items:center;gap:.5rem}.col{display:flex;flex-direction:column;gap:.75rem}.between{justify-content:space-between}.app-shell{display:grid;min-height:100vh;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) 1fr;grid-template-areas:"topbar topbar" "sidebar main"}.app-shell.no-sidebar{grid-template-columns:1fr;grid-template-areas:"topbar" "main"}.topbar{grid-area:topbar;display:flex;align-items:center;gap:1rem;padding:0 1.25rem;background:#ffffffd9;backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border);z-index:10}.topbar .brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.1rem;color:var(--ink)}.topbar .brand-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.95rem}.topbar-center{flex:1;display:flex;justify-content:center}.topbar-actions{display:flex;align-items:center;gap:.5rem}.sidebar{grid-area:sidebar;background:#ffffffd9;border-right:1px solid var(--border);padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.nav-group{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:.8rem .75rem .3rem}.nav-link{display:flex;align-items:center;gap:.65rem;padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.92rem;font-weight:600;color:var(--ink);transition:background .15s ease,color .15s ease}.nav-link:hover{background:rgba(var(--primary-rgb),.08);color:var(--primary-dark)}.nav-link.active{background:var(--primary-light);color:var(--primary-dark)}.nav-link .ico{font-size:1rem;opacity:.85}.main{grid-area:main;padding:1.5rem clamp(1rem,3vw,2.25rem);max-width:1400px;width:100%}.tab-anim{animation:fade-in .25s ease-out}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.page-title{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin:0 0 .25rem}.page-sub{color:var(--ink-soft);margin:0 0 1.25rem}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm)}.card+.card{margin-top:1rem}.card-title{font-size:1rem;font-weight:700;margin:0 0 .75rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem .95rem;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--ink);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .15s ease}.btn:hover{border-color:var(--primary);color:var(--primary-dark)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-color:transparent;box-shadow:var(--shadow-primary)}.btn-primary:hover{color:#fff;filter:brightness(1.05);transform:translateY(-1px)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg-softer)}.btn-danger{color:#dc2626;border-color:#fecaca}.btn-danger:hover{background:#fef2f2;color:#b91c1c;border-color:#fca5a5}.btn-sm{font-size:.82rem;padding:.4rem .7rem}.btn-block{width:100%;justify-content:center}.btn[disabled]{opacity:.55;cursor:not-allowed}.input,.select,.textarea{width:100%;padding:.55rem .8rem;border:1px solid var(--border);border-radius:10px;background:#fff;font-size:.92rem;font-family:inherit;color:var(--ink);transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.15)}.field{display:flex;flex-direction:column;gap:.3rem}.field>span{font-size:.78rem;font-weight:600;color:var(--ink-soft)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.grid-2{grid-template-columns:1fr}}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:2rem 1rem}.login-card{width:100%;max-width:420px;background:#fff;border-radius:var(--radius-lg);padding:2.25rem 1.75rem;box-shadow:var(--shadow-lg)}.login-brand{display:flex;align-items:center;gap:.65rem;justify-content:center;margin-bottom:1.5rem;font-size:1.35rem;font-weight:800;color:var(--ink)}.login-brand .brand-mark{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:1rem}.num-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.6rem;cursor:pointer;transition:all .15s ease;text-decoration:none;color:var(--ink)}.num-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:var(--shadow)}.num-card-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.num-big{font-size:1.15rem;font-weight:700;letter-spacing:-.01em}.num-dot{width:10px;height:10px;border-radius:50%;background:#cbd5e1}.num-dot.on{background:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.18)}.num-label{color:var(--ink-soft);font-size:.88rem;min-height:1.2em}.num-badges{display:flex;gap:.3rem;flex-wrap:wrap}.num-badge{font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.2rem .5rem;border-radius:999px;background:var(--bg-softer);color:var(--ink-soft)}.num-badge.on{background:var(--primary-light);color:var(--primary-dark)}.num-card-add{border:2px dashed rgba(var(--primary-rgb),.3);background:transparent;align-items:center;justify-content:center;min-height:140px;gap:.35rem}.num-card-add:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark)}.num-add-ico{width:42px;height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary);font-size:1.6rem;font-weight:300}.num-add-title{font-weight:700;font-size:.95rem}.num-add-sub{font-size:.78rem;color:var(--ink-soft);text-align:center}.line-selector{position:relative;min-width:260px}.line-selector-btn{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .8rem;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;font-size:.9rem;color:var(--ink)}.line-selector-btn:hover{border-color:var(--primary)}.ls-num{font-weight:700}.ls-lbl{color:var(--ink-soft);font-size:.82rem}.ls-caret{margin-left:auto;color:var(--muted);font-size:.7rem}.line-selector-pop{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.5rem;z-index:100;max-height:380px;display:flex;flex-direction:column}.ls-list{overflow-y:auto;max-height:320px;margin-top:.4rem}.ls-item{width:100%;text-align:left;display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;border:none;background:transparent;border-radius:8px;cursor:pointer;font-size:.88rem;color:var(--ink)}.ls-item:hover{background:var(--bg-softer)}.ls-item.active{background:var(--primary-light);color:var(--primary-dark)}.ls-item-num{font-weight:700}.ls-item-lbl{color:var(--ink-soft);font-size:.78rem;flex:1}.ls-dot{width:8px;height:8px;border-radius:50%;background:#cbd5e1;margin-left:auto}.ls-dot.on{background:var(--primary)}.account-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .7rem .35rem .35rem;border:1px solid var(--border);border-radius:999px;background:#fff;cursor:pointer;font-size:.88rem}.account-btn:hover{border-color:var(--primary)}.balance-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.2rem .2rem .2rem .75rem;border:1px solid var(--border);border-radius:999px;background:#fff;font-size:.82rem;transition:border-color .15s ease}.balance-pill:hover{border-color:var(--primary)}.balance-pill.low{border-color:#f59e0b;background:#fffbeb}.balance-pill.low .balance-pill-amount{color:#b45309}.balance-pill-info{display:inline-flex;flex-direction:column;line-height:1.1}.balance-pill-label{font-size:.65rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.balance-pill-amount{font-weight:800;font-size:.92rem;color:var(--ink);font-variant-numeric:tabular-nums}.balance-pill-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .75rem;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:700;font-size:.78rem;text-decoration:none;box-shadow:0 4px 10px -2px rgba(var(--primary-rgb),.45);transition:transform .15s ease,box-shadow .15s ease}.balance-pill-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px -2px rgba(var(--primary-rgb),.6);color:#fff}.balance-pill-btn>span:first-child{font-size:1rem;line-height:1;font-weight:900}@media (max-width: 640px){.balance-pill-btn>span:last-child{display:none}.balance-pill{padding-left:.6rem}.balance-pill-label{display:none}}.account-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:800;font-size:.8rem;display:inline-flex;align-items:center;justify-content:center}.account-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.4rem;min-width:220px;z-index:100}.account-menu button{width:100%;text-align:left;padding:.5rem .7rem;border:none;background:transparent;border-radius:8px;cursor:pointer;font-size:.88rem;color:var(--ink)}.account-menu button:hover{background:var(--bg-softer);color:var(--primary-dark)}.calls-table{width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.call-row{display:grid;grid-template-columns:42px 1fr 90px 100px 90px 40px;gap:.5rem;align-items:center;padding:.8rem 1rem;border-top:1px solid var(--border);cursor:pointer;transition:background .12s ease;font-size:.9rem}.call-row:first-child{border-top:none}.call-row:hover{background:var(--bg-soft)}.call-row.selected{background:var(--primary-light)}.call-avatar{width:38px;height:38px;border-radius:50%;background:var(--bg-softer);color:var(--ink-soft);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem}.call-avatar.in{background:rgba(var(--primary-rgb),.12);color:var(--primary-dark)}.call-avatar.out{background:#fef3c7;color:#b45309}.call-name{font-weight:700}.call-sub{color:var(--ink-soft);font-size:.78rem}.call-dur,.call-cost,.call-date{font-variant-numeric:tabular-nums}.call-cost,.call-date{color:var(--ink-soft);font-size:.82rem}@media (max-width: 720px){.call-row{grid-template-columns:42px 1fr auto}.call-dur,.call-cost,.call-date{display:none}}.badge{display:inline-flex;align-items:center;padding:.18rem .5rem;font-size:.7rem;font-weight:700;border-radius:999px;background:var(--bg-softer);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}.badge.ok{background:#dcfce7;color:#166534}.badge.warn{background:#fef3c7;color:#92400e}.badge.err{background:#fee2e2;color:#991b1b}.badge.info{background:var(--primary-light);color:var(--primary-dark)}.drawer-mask{position:fixed;inset:0;background:#0f172a66;z-index:200;animation:fade-in .2s ease-out}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(560px,100%);background:#fff;z-index:201;box-shadow:-20px 0 60px #0f172a40;display:flex;flex-direction:column;animation:slide-in .28s ease-out}@keyframes slide-in{0%{transform:translate(100%)}to{transform:none}}.drawer-head{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.drawer-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem}.drawer-close{border:none;background:transparent;font-size:1.5rem;cursor:pointer;color:var(--ink-soft);padding:.25rem .5rem;border-radius:8px}.drawer-close:hover{background:var(--bg-softer);color:var(--ink)}.kv{display:grid;grid-template-columns:130px 1fr;gap:.5rem 1rem;font-size:.88rem}.kv dt{color:var(--ink-soft)}.kv dd{margin:0}.transcript{display:flex;flex-direction:column;gap:.5rem}.tr-line{display:flex;gap:.6rem;padding:.55rem .75rem;border-radius:10px;font-size:.88rem;line-height:1.45}.tr-line.agent{background:var(--primary-light)}.tr-line.user{background:var(--bg-soft)}.tr-line .who{font-weight:800;font-size:.68rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;min-width:52px;padding-top:2px}.tr-line.agent .who{color:var(--primary-dark)}.contact-summary{padding:.8rem 1rem;background:var(--primary-light);border-radius:var(--radius-sm);color:var(--primary-dark);font-size:.88rem;margin-bottom:1rem;font-weight:600}.balance-card{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-radius:var(--radius);padding:1.75rem;display:flex;flex-direction:column;gap:.3rem;box-shadow:var(--shadow-primary)}.balance-label{font-size:.78rem;letter-spacing:.06em;opacity:.85;text-transform:uppercase;font-weight:700}.balance-amount{font-size:2.4rem;font-weight:800;letter-spacing:-.02em}.recharge-preset{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.6rem;margin:.75rem 0}.recharge-preset button{padding:.8rem;border-radius:12px;border:2px solid var(--border);background:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all .15s ease}.recharge-preset button:hover{border-color:var(--primary)}.recharge-preset button.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark)}.check{display:inline-flex;align-items:center;gap:.7rem;padding:.55rem .8rem;border:1px solid var(--border);border-radius:12px;background:#fff;cursor:pointer;transition:all .15s ease;font-size:.9rem;font-weight:500;color:var(--ink);user-select:none}.check:hover{border-color:var(--primary);background:var(--primary-light)}.check input[type=checkbox]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.check .check-box{width:22px;height:22px;border-radius:7px;border:2px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease;position:relative}.check .check-box:after{content:"";width:6px;height:11px;border-right:2.5px solid #fff;border-bottom:2.5px solid #fff;transform:rotate(45deg) scale(0);transition:transform .18s cubic-bezier(.34,1.56,.64,1);margin-top:-2px}.check input:checked+.check-box{background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-color:var(--primary);box-shadow:0 4px 12px rgba(var(--primary-rgb),.28)}.check input:checked+.check-box:after{transform:rotate(45deg) scale(1)}.check input:focus-visible+.check-box{box-shadow:0 0 0 4px rgba(var(--primary-rgb),.22)}.check.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark)}.check-text{line-height:1.35}.check-text small{display:block;font-weight:400;color:var(--ink-soft);font-size:.78rem;margin-top:2px}.help-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1px solid var(--border);background:var(--bg-soft);color:var(--ink-soft);font-size:.78rem;font-weight:800;cursor:pointer;margin-left:.35rem;vertical-align:middle;transition:all .15s ease}.help-btn:hover{background:var(--primary-light);color:var(--primary-dark);border-color:var(--primary)}.help-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.help-box{margin:-.25rem 0 .85rem;padding:.75rem .9rem;background:var(--primary-light);border-left:3px solid var(--primary);border-radius:8px;font-size:.85rem;color:var(--primary-dark);line-height:1.55;animation:fade-in .2s ease-out}.mode-toggle{display:inline-flex;padding:4px;background:var(--bg-softer);border-radius:999px;gap:2px;margin-bottom:1.25rem}.mode-toggle button{padding:.45rem 1rem;border:none;background:transparent;border-radius:999px;font-weight:600;font-size:.85rem;color:var(--ink-soft);cursor:pointer;transition:all .18s ease}.mode-toggle button.active{background:#fff;color:var(--primary-dark);box-shadow:0 2px 8px #0f172a14}.wizard-steps{display:flex;gap:.5rem;margin-bottom:1.5rem}.wizard-step-dot{flex:1;height:6px;border-radius:999px;background:var(--bg-softer);transition:background .2s ease}.wizard-step-dot.done,.wizard-step-dot.active{background:var(--primary)}.wizard-step-dot.active{box-shadow:0 0 0 4px rgba(var(--primary-rgb),.18)}.wizard-h{font-size:1.4rem;font-weight:800;letter-spacing:-.01em;margin:0 0 .35rem}.wizard-sub{color:var(--ink-soft);margin:0 0 1.5rem}.wizard-choices{display:grid;gap:.6rem}.wizard-choice{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;background:#fff;border:2px solid var(--border);border-radius:14px;cursor:pointer;text-align:left;transition:all .15s ease;font-family:inherit}.wizard-choice:hover{border-color:var(--primary);background:var(--primary-light)}.wizard-choice.selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 4px rgba(var(--primary-rgb),.12)}.wizard-choice-ico{width:44px;height:44px;border-radius:12px;background:var(--primary-light);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.wizard-choice.selected .wizard-choice-ico{background:var(--primary);color:#fff}.wizard-choice-body{flex:1}.wizard-choice-title{font-weight:700;margin-bottom:.1rem}.wizard-choice-sub{color:var(--ink-soft);font-size:.85rem}.wizard-actions{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border)}.audio-list{display:flex;flex-direction:column;gap:.5rem}.audio-item{display:grid;grid-template-columns:40px 1fr auto auto;align-items:center;gap:.8rem;padding:.75rem 1rem;border:1px solid var(--border);border-radius:12px;background:#fff;transition:all .15s ease}.audio-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.audio-item.selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.15)}.audio-icon{width:40px;height:40px;border-radius:10px;background:var(--primary-light);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.audio-icon.tts{background:#fef3c7;color:#b45309}.audio-icon.recording{background:#fee2e2;color:#b91c1c}.audio-body{min-width:0}.audio-name{font-weight:700;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audio-meta{color:var(--ink-soft);font-size:.74rem;margin-top:2px}.audio-play{border:1px solid var(--border);background:#fff;border-radius:999px;padding:.35rem .8rem;cursor:pointer;font-size:.8rem;font-weight:700;color:var(--primary-dark)}.audio-play:hover{border-color:var(--primary);background:var(--primary-light)}.dropzone{position:relative;padding:2rem 1rem;border:2px dashed var(--border);border-radius:14px;background:var(--bg-soft);text-align:center;transition:all .15s ease;cursor:pointer}.dropzone:hover{border-color:var(--primary);background:var(--primary-light)}.dropzone.active{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 4px rgba(var(--primary-rgb),.15);transform:scale(1.01)}.dropzone.has-file{border-style:solid;border-color:var(--primary);background:#fff;text-align:left;padding:1rem 1.25rem}.dropzone-icon{font-size:2.4rem;line-height:1;margin-bottom:.5rem;color:var(--primary)}.dropzone-title{font-weight:800;font-size:1rem;color:var(--ink);margin-bottom:.25rem}.dropzone-sub{font-size:.82rem;color:var(--ink-soft);margin-bottom:1rem}.dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.btn-file{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.2rem;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:700;font-size:.9rem;cursor:pointer;border:none;box-shadow:0 8px 20px -4px rgba(var(--primary-rgb),.5);transition:transform .15s ease,box-shadow .15s ease}.btn-file:hover{transform:translateY(-1px);box-shadow:0 12px 26px -6px rgba(var(--primary-rgb),.6)}.btn-file:active{transform:translateY(0)}.file-info{display:flex;align-items:center;gap:.75rem;width:100%}.file-info-icon{width:44px;height:44px;border-radius:10px;background:var(--primary-light);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.file-info-body{min-width:0;flex:1}.file-info-name{font-weight:700;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-info-meta{font-size:.75rem;color:var(--ink-soft)}.recorder{padding:1.5rem;border:2px dashed var(--border);border-radius:14px;background:var(--bg-soft);text-align:center}.recorder.recording{border-color:#dc2626;background:#fee2e2}.rec-btn{width:72px;height:72px;border-radius:50%;border:none;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:1.6rem;cursor:pointer;box-shadow:0 8px 24px -4px #dc262673;transition:transform .15s ease}.rec-btn:hover{transform:scale(1.05)}.rec-btn.recording{animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 8px 24px -4px #dc262673}50%{box-shadow:0 0 0 12px #dc26262e,0 8px 24px -4px #dc262673}}.rec-timer{font-size:1.3rem;font-weight:800;font-variant-numeric:tabular-nums;margin-top:.75rem}.audio-tabs{display:flex;gap:.3rem;padding:4px;background:var(--bg-softer);border-radius:12px;margin-bottom:1rem}.audio-tabs button{flex:1;padding:.55rem .75rem;border:none;background:transparent;border-radius:8px;font-weight:600;font-size:.85rem;color:var(--ink-soft);cursor:pointer;transition:all .15s ease}.audio-tabs button.active{background:#fff;color:var(--primary-dark);box-shadow:0 2px 6px #0f172a0f}.skeleton{background:linear-gradient(90deg,#94a3b81a,#94a3b838,#94a3b81a);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:8px;display:inline-block}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sk-line{display:block;height:12px;border-radius:6px}.sk-line+.sk-line{margin-top:.5rem}.sk-num-card{min-height:140px;padding:1rem 1.1rem}.sk-num-card .sk-line{height:14px}.sk-call-row{display:grid;grid-template-columns:42px 1fr 90px 100px 90px 40px;gap:.5rem;align-items:center;padding:.8rem 1rem;border-top:1px solid var(--border)}.sk-call-row:first-child{border-top:none}.sk-circle{width:38px;height:38px;border-radius:50%}@media (max-width: 720px){.sk-call-row{grid-template-columns:42px 1fr auto}.sk-call-row>:nth-child(3),.sk-call-row>:nth-child(4),.sk-call-row>:nth-child(5){display:none}}.loading-page{min-height:60vh;display:grid;place-items:center}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-wrap{position:fixed;bottom:1.25rem;right:1.25rem;display:flex;flex-direction:column;gap:.5rem;z-index:999}.toast{background:#fff;padding:.7rem 1rem;border-radius:10px;border-left:4px solid var(--primary);box-shadow:var(--shadow);font-size:.88rem;font-weight:600;animation:slide-in .25s ease-out;max-width:340px}.toast-success{border-left-color:#10b981}.toast-error{border-left-color:#ef4444}.empty{padding:3rem 1rem;text-align:center;color:var(--ink-soft)}.empty-title{font-size:1.1rem;font-weight:700;color:var(--ink);margin:0 0 .4rem}.empty-sub{font-size:.9rem;margin:0 0 1rem}@media (max-width: 900px){.app-shell{grid-template-columns:1fr;grid-template-areas:"topbar" "main"}.sidebar{display:none}}
