:root{--bg: #0a0a0b;--surface: #121215;--surface-2: #18181d;--border: rgba(255,255,255,.08);--text: #f4f4f5;--muted: #9b9ba4;--accent: #d83b32;--accent-soft: rgba(216, 59, 50, .14);--success: #34d399;--shadow: 0 25px 50px rgba(0,0,0,.35);--radius: 22px}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:320px;min-height:100vh;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top,rgba(216,59,50,.1),transparent 28%),linear-gradient(180deg,#0d0d10,#080809);color:var(--text)}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{border:0}ul{padding:1rem}li{line-height:1.25rem}.app-loading,.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(480px,100%);background:#121215eb;border:1px solid var(--border);border-radius:28px;padding:28px;box-shadow:var(--shadow)}.login-card h1,.library-header h1{margin:8px 0 10px;font-size:clamp(2rem,4vw,3rem);line-height:.96}.login-card p{color:var(--muted);margin:0 0 20px}.login-kicker,.result-label{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--muted)}.login-card label{display:grid;gap:8px;margin-bottom:16px;color:#d9d9df}.login-card input,.chat-window textarea{width:100%;border-radius:14px;border:1px solid var(--border);background:#ffffff08;color:var(--text);padding:14px 16px}.login-error,.error-text{color:#fca5a5}.button,.ghost-btn,.transport-btn{border-radius:0;transition:transform .18s ease,border-color .18s ease,background .18s ease}.ghost-btn.menu-btn{background:none;color:#fff;font-size:2rem;border:none;padding:.5rem}.button{background:linear-gradient(180deg,#e4493f,#b92f28);color:#fff;border:1px solid #b92f28;padding:13px 18px;font-weight:700;font-size:.85rem;box-shadow:0 12px 30px #d83b3247}.button:hover,.ghost-btn:hover,.transport-btn:hover{transform:translateY(-1px)}.record-page{min-height:90vh;display:grid;grid-template-rows:1fr auto;padding:24px;gap:24px}.tape-shell{min-height:65vh;display:grid;grid-template-rows:auto 1fr auto auto;gap:18px;position:relative;padding-top:9rem}.top-strip{display:flex;justify-content:space-between;align-items:center;gap:12px}.ghost-btn,.user-pill{background:#ffffff0a;border:1px solid var(--border);color:var(--text);padding:10px 14px;display:inline-flex;gap:8px;align-items:center}.user-pill{border-radius:999px;color:var(--muted)}.transcript-stage{display:grid;place-items:center;overflow:hidden;padding:20px 0}.marquee-line{width:160vw;text-align:center;white-space:nowrap;font-size:clamp(5.4rem,44vw,8rem);font-weight:800;line-height:.88;letter-spacing:-.05em;color:#f5f5f5;text-shadow:0 10px 30px rgba(0,0,0,.35)}.status-row{display:flex;align-items:center;justify-content:center;gap:12px;color:var(--muted);font-size:.95rem;max-height:30vh}.record-light{width:12px;height:12px;border-radius:999px;background:#3a1717;box-shadow:0 0 0 6px #d83b3214}.record-light.on{background:#ff3b30;box-shadow:0 0 18px #ff3b30e6,0 0 0 6px #ff3b301f}.cassette-bar{gap:14px;padding:16px;background:#121215e0;border:1px solid var(--border);border-radius:28px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow);position:fixed;width:98%;margin:0 auto;display:flex;left:1%;bottom:10px}.transport-btn{min-height:92px;background:linear-gradient(180deg,#ffffff0f,#ffffff08);border:1px solid rgba(255,255,255,.06);color:var(--text);display:grid;place-items:center;gap:8px;padding:14px;font-weight:700;min-width:30%}.transport-btn.armed{background:linear-gradient(180deg,#d83b3240,#d83b321f);border-color:#ff3b3073}.transport-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.result-stack{display:grid;grid-template-columns:1fr 1.4fr;gap:18px}.result-card{background:#121215d1;border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:var(--shadow)}.transcript-display .result-card{background:none!important;border:none!important}.result-body{margin-top:12px;min-height:180px;max-height:32vh;overflow:auto;padding:14px;border-radius:18px;background:#ffffff08;border:1px solid rgba(255,255,255,.04);color:#e7e7eb}.mono{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.95rem;line-height:1.55}.library-page{min-height:100vh;padding:24px}.library-page .entry-head{margin-bottom:1rem}.library-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px}.grid{display:grid;gap:16px}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.entry-card .transcript-box{margin-top:10px;padding:12px;border-radius:16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.05);color:#dfdfe4;white-space:pre-wrap;line-height:1.25rem;font-size:.9rem}.entry-head,.actions.compact{display:flex;justify-content:space-between;align-items:center;gap:10px}.card-title{font-weight:700}.card-sub,.helper{color:var(--muted);font-size:.75rem}.actions{display:flex;gap:10px}.icon-btn{background:transparent;color:var(--muted);padding:6px;border-radius:12px}.icon-btn.favorite.active{color:#fb7185}.icon-btn.pinned.active{color:#93c5fd}.spin{animation:spin 1s linear infinite}.marquee-line{width:190vw;font-size:clamp(5.4rem,44vw,8rem);margin-left:-50%}.transcript-stage,.result-screen{transition:opacity .24s ease,transform .28s ease}.transcript-stage.exit{opacity:0;transform:scale(.98) translateY(18px);pointer-events:none}.result-screen{min-height:100vh;opacity:0;transform:translateY(24px);pointer-events:none}.result-screen.active{display:grid;grid-template-rows:auto 1fr auto;padding:24px}.result-stack{position:absolute;z-index:999;background:#000;top:0;left:0;height:100%}.transcript-display.result-stack{top:5vh!important;background:none;height:auto}.result-screen{position:fixed;inset:0;z-index:50;display:grid;grid-template-rows:auto 1fr auto;gap:16px;padding:24px;background:var(--bg);opacity:0;transform:translateY(30px);pointer-events:none;transition:all .28s ease}.result-screen.active{opacity:1;transform:translateY(0);pointer-events:auto}.transcript-stage.exit{opacity:0;transform:scale(.95);transition:all .2s ease}.result-header{display:flex;justify-content:space-between;align-items:center}.result-actions{display:flex;justify-content:flex-end}.material-section{font-size:.9rem}.material-section h3{margin:0}.material-section ul{padding-left:15px}.material-section ul li{line-height:1.5rem}.material-result-body{max-height:46vh}.drawer-trigger{position:relative;z-index:20}.drawer-backdrop{position:fixed;inset:0;background:#0000007a;opacity:0;pointer-events:none;transition:opacity .22s ease;z-index:90}.drawer-backdrop.active{opacity:1;pointer-events:auto}.mobile-drawer{position:fixed;inset:0 auto 0 0;width:min(86vw,340px);background:#121215fa;border-right:1px solid var(--border);z-index:100;transform:translate(-105%);transition:transform .24s ease;display:grid;grid-template-rows:auto 1fr auto;padding:18px;box-shadow:var(--shadow);z-index:999999}.mobile-drawer.active{transform:translate(0)}.drawer-head,.result-topline,.result-title-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.transcript-display .ghost-btn{border:none;background:none}.transcript-display .result-topline{margin-bottom:0rem}.drawer-nav{display:grid;align-content:start;gap:8px;padding-top:18px}.drawer-link{width:100%;background:transparent;color:var(--text);border-radius:16px;padding:14px;display:flex;align-items:center;gap:12px;text-align:left}.drawer-link.active,.drawer-link:hover{background:#ffffff0f}.drawer-link.secondary{color:var(--muted)}.drawer-bottom{border-top:1px solid var(--border);padding-top:14px}.page-shell{min-height:100vh;padding:16px}.note-input{width:100%;min-height:150px;border:1px solid var(--border);background:#ffffff0a;color:var(--text);padding:14px;margin-bottom:12px}.result-screen{position:fixed;inset:0;z-index:50;padding:24px;background:var(--bg);overflow:auto}.app-shell{min-height:95vh}.app-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 10px;background-color:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:99999}.app-main{min-height:calc(100vh - 69px)}@media(min-width:768px){.drawer-trigger{display:inline-flex}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:960px){.result-stack,.grid.cols-3{grid-template-columns:1fr}.cassette-bar{grid-template-columns:repeat(3,minmax(88px,1fr))}}@media(max-width:640px){.record-page,.library-page,.login-shell{padding:14px}.marquee-line{width:190vw;font-size:clamp(5.4rem,44vw,8rem);margin-left:-50%}.top-strip,.library-header{flex-direction:row;align-items:center}.transport-btn{min-height:82px;font-size:.92rem}}.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.note-add-btn{display:inline-flex;align-items:center;gap:.45rem;font-size:1.15rem;color:#fff}.note-add-icon{font-size:1.1rem;line-height:1}.note-title-input{width:100%;margin-top:1rem;padding:.85rem 1rem;border:1px solid rgba(255,255,255,.14);background:#ffffff0f;color:inherit;font-size:1rem}.note-card{cursor:pointer}.note-card:hover{transform:translateY(-1px)}.note-card p{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.modal-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:1rem;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-card{width:min(680px,100%);max-height:88vh;overflow:auto;padding:1rem;border-radius:12px;background:#151515;box-shadow:0 24px 80px #00000073}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.note-modal-body{margin-top:1rem;white-space:pre-wrap;line-height:1.6}.button.secondary{opacity:.75}.note-title-input{margin:1rem 0}.result-card.note-card p{font-size:.85rem}.button-new{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none;border-radius:999px;padding:.25rem .65rem;font-weight:600;letter-spacing:.02em;font-size:.85rem;display:inline-flex;align-items:center;gap:.4rem;box-shadow:0 6px 18px #22c55e40;transition:all .2s ease}.button-new:hover{transform:translateY(-1px);box-shadow:0 10px 26px #22c55e59;filter:brightness(1.05)}.button-new:active{transform:translateY(0);box-shadow:0 4px 12px #22c55e33}.button-new:focus{outline:none;box-shadow:0 0 0 3px #22c55e59}.button-danger{background:#dc2626!important;color:#fff;border:none;border-radius:10px;padding:.35rem .7rem;font-weight:500;text-align:center!important;justify-content:center;font-weight:700;box-shadow:none!important;transition:all .2s ease}.button-danger.button-text{color:#ef4444;background:none!important;border:none;border-radius:10px;padding:.35rem .7rem;font-weight:500;box-shadow:none;transition:all .2s ease}.button-save{color:#fff;background:#2563eb;border:1px solid #1d4ed8;display:flex;align-items:center;padding:.5rem 1rem;gap:5px;box-shadow:0 10px 26px #4444ef59}.button-danger:hover{transform:translateY(-1px);box-shadow:0 10px 26px #ef444459;filter:brightness(1.05)}.button-danger:active{transform:translateY(0);box-shadow:0 4px 12px #ef444433}.button-danger:focus{outline:none;box-shadow:0 0 0 3px #ef444459}.recorder-chat-btn{align-self:center;margin:.75rem auto 0;display:inline-flex;align-items:center;gap:.4rem;border:1px solid rgba(34,197,94,.35);background:#22c55e1f;color:#86efac;border-radius:999px;padding:.45rem .85rem;font-size:.85rem;font-weight:700;cursor:pointer;position:absolute;top:-60px;right:10px}.recorder-chat-btn:hover{background:#22c55e2e}.image-upload-btn{margin-top:1rem;display:inline-flex;align-items:center;gap:.5rem;width:fit-content;border-radius:999px;padding:.65rem .95rem;cursor:pointer;background:#ffffff14;border:1px dashed rgba(255,255,255,.22)}.image-upload-btn:hover{background:#ffffff1f}.chat-screen{margin-top:1rem;overflow:hidden;border:none}.chat-head{display:flex;align-items:center;justify-content:space-between;padding:1rem}.chat-thread{display:flex;flex-direction:column;gap:.85rem;padding:1rem;max-height:74vh;overflow-y:auto}.chat-row{display:flex}.chat-row.from-user{justify-content:flex-end}.chat-row.from-ai{justify-content:flex-start}.chat-bubble{max-width:min(82%,720px);padding:.65rem 1rem;border-radius:20px;line-height:1.5;white-space:normal}.from-user .chat-bubble{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-bottom-right-radius:6px}.from-ai .chat-bubble{background:#ffffff1a;color:inherit;border-bottom-left-radius:6px}.error-bubble{background:#ef444429;border:1px solid rgba(239,68,68,.35)}.typing-bubble{opacity:.75;font-style:italic}.chat-image{display:block;width:100%;max-height:260px;object-fit:cover;border-radius:14px;margin-bottom:.75rem}.chat-text p{margin:0 0 .55rem}.chat-text p:last-child{margin-bottom:0}.chat-heading{font-weight:800;margin-top:.85rem!important}.chat-screen{display:flex;flex-direction:column;height:88vh}.chat-thread{flex:1;overflow-y:auto}.chat-bar-container{position:fixed;bottom:0;background-color:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;border-top:1px solid rgba(255,255,255,.1)}.chat-input-bar{display:flex;align-items:center;gap:.5rem;padding:.8rem .6rem}.chat-input{flex:1;padding:.65rem .85rem;border-radius:5px;border:none;color:inherit}.chat-input:focus{outline:none;background:#ffffff1f}.chat-send-btn{background:none;border:none;padding:.5rem .35rem;color:#16a34a;font-weight:600}.chat-image-btn{cursor:pointer;padding:.5rem .35rem;border-radius:999px;color:#aaa;background:none}.chat-image-preview{display:flex;align-items:center;gap:.5rem;padding:.5rem}.chat-image-preview img{height:50px;border-radius:8px}.chat-image-preview button{background:none;border:none;color:#ef4444;font-size:18px;cursor:pointer}.record-page.chat-open{max-height:93vh;background:none;border:none;padding:0;position:relative}.nav-chat-btn{display:inline-flex;align-items:center;gap:.45rem;border:1px solid rgba(255,255,255,.14);background:#ffffff14;color:inherit;border-radius:999px;padding:.45rem .75rem;font-size:.85rem;cursor:pointer;width:auto;height:20px;position:absolute;background:none;border:none;right:0;top:60px}.nav-chat-btn:hover{background:#ffffff21}.nav-chat-btn span{min-width:20px;height:20px;display:inline-grid;place-items:center;border-radius:999px;background:#22c55e;color:#fff;font-size:.75rem;font-weight:700}.chat-open .nav-chat-btn{display:none!important}.attach-menu-backdrop{position:fixed;inset:0;z-index:80;display:flex;align-items:flex-end;justify-content:center;background:#00000059}.attach-menu{width:min(420px,calc(100% - 1rem));margin-bottom:.5rem;padding:.5rem;border-radius:22px;background:#171717;box-shadow:0 24px 80px #00000073}.attach-menu button{width:100%;padding:.9rem 1rem;border:0;border-radius:16px;background:#ffffff14;color:inherit;font-size:1rem;text-align:left;margin-bottom:.45rem;display:flex;align-items:center;gap:12px;justify-content:center}.attach-menu button:hover{background:#ffffff21}.attach-menu .attach-cancel{text-align:center;background:transparent;opacity:.75;margin-top:.75rem}.chat-attachment-strip{display:flex;gap:.5rem;padding:.55rem .75rem .2rem;border-top:1px solid rgba(255,255,255,.08);background:#00000038}.chat-attachment-preview{position:relative;width:54px;height:54px;border-radius:12px;overflow:visible;background:#ffffff14}.chat-attachment-preview img,.chat-file-square{width:54px;height:54px;border-radius:12px;object-fit:cover}.chat-file-square{display:grid;place-items:center;font-size:1.25rem;border:1px solid rgba(255,255,255,.12)}.chat-attachment-remove{position:absolute;top:-7px;right:-7px;width:21px;height:21px;display:grid;place-items:center;border:0;border-radius:999px;background:#ef4444;color:#fff;font-size:15px;line-height:1;cursor:pointer;box-shadow:0 4px 12px #00000059}.chat-save-material-btn{margin-top:.75rem;font-size:.85rem;padding:.5rem .75rem;border-radius:5px;float:right;background:#2563eb!important;border:none!important;box-shadow:none}.typing-dots{display:inline-flex;align-items:center;gap:6px}.typing-dots span{width:6px;height:6px;border-radius:999px;background:#ffffffb3;display:block;animation:typingBounce 1.4s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}@keyframes typingBounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-4px);opacity:1}}.typing-bubble{opacity:.8}.train-page{padding-bottom:96px}.train-card{background:#fffffff0;border:1px solid rgba(20,20,24,.08);border-radius:24px;box-shadow:0 18px 50px #0f172a14;padding:20px;margin:16px 0}.train-card-head{display:flex;justify-content:space-between;gap:16px;margin-bottom:18px}.train-card h2{margin:0 0 4px;font-size:1.15rem}.train-card p{margin:0;color:#6b7280;line-height:1.45}.train-record-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.train-record-btn,.train-actions .button,.train-upload-box .button{display:inline-flex;align-items:center;gap:8px}.train-inline-status{display:inline-flex;align-items:center;gap:8px;color:#6b7280;font-weight:700}.train-confirm-box,.train-upload-box{display:grid;gap:14px;margin-top:18px}.train-confirm-box label,.train-upload-box label{display:grid;gap:6px;font-weight:800;color:#27272a}.train-confirm-box input,.train-confirm-box textarea,.train-upload-box input[type=text],.train-upload-box input:not([type]){width:100%;border:1px solid rgba(20,20,24,.12);border-radius:16px;padding:12px 14px;background:#fff;color:#18181b}.train-confirm-box textarea{resize:vertical;min-height:160px}.train-actions{display:flex;gap:10px;flex-wrap:wrap}.train-alert{border-radius:18px;padding:12px 14px;font-weight:800;margin:12px 0}.train-alert.error{background:#fee2e2;color:#991b1b}.train-alert.success{background:#dcfce7;color:#166534}.train-file-preview{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;background:#f4f4f5;color:#27272a;font-weight:800}.spin{animation:train-spin .9s linear infinite}@keyframes train-spin{to{transform:rotate(360deg)}}.estimate-section{margin-top:1.25rem}.estimate-groups{display:grid;gap:1rem}.estimate-group h4{margin:0 0 .5rem;font-size:.95rem;font-weight:700}.estimate-prices{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.estimate-price{border-radius:14px;padding:.85rem;border:1px solid rgba(0,0,0,.08)}.estimate-price span{display:block;font-size:.75rem;font-weight:700;opacity:.75;margin-bottom:.25rem}.estimate-price strong{display:block;font-size:1.1rem}.estimate-low{background:#22c55e1f;border-color:#22c55e59;color:#166534}.estimate-medium{background:#f9731621;border-color:#f9731659;color:#9a3412}.estimate-high{background:#ef44441f;border-color:#ef444459;color:#991b1b}.agreement-modal-backdrop{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:20px;background:#0f172ab8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.agreement-modal{width:min(620px,100%);max-height:86vh;overflow:auto;background:#fff;color:#111827;border-radius:22px;padding:24px;box-shadow:0 24px 80px #0000005c}.agreement-badge{display:inline-flex;align-items:center;width:fit-content;padding:5px 11px;border-radius:999px;background:#f9731624;color:#9a3412;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}.agreement-modal h2{margin:0;font-size:1.65rem;line-height:1.1}.agreement-modal-title{font-weight:800;font-size:1rem}.agreement-intro{margin:10px 0 16px;color:#4b5563;line-height:1.4}.agreement-text{border:1px solid rgba(15,23,42,.12);border-radius:16px;padding:14px;background:#f8fafc;max-height:260px;overflow:auto;font-size:.9rem;line-height:1.42}.agreement-text p{margin:0 0 9px}.agreement-check{display:flex;gap:11px;align-items:flex-start;margin:16px 0;font-weight:650;line-height:1.35}.agreement-check input{margin-top:3px;width:18px;height:18px;flex:0 0 auto}.agreement-error{margin-bottom:12px;color:#991b1b;background:#ef44441a;border:1px solid rgba(239,68,68,.25);padding:10px 12px;border-radius:12px}.agreement-accept-btn{width:100%;border:0;border-radius:15px;padding:13px 16px;font-size:1rem;font-weight:800;background:#111827;color:#fff;cursor:pointer}.agreement-accept-btn:disabled{opacity:.45;cursor:not-allowed}
