:root{--bg:#0c0c0f;--surface:#14141a;--surface2:#1c1c26;--border:#2a2a38;--accent:#6c63ff;--accent2:#ff6b6b;--accent3:#43e97b;--text:#e8e8f0;--muted:#6b6b88;--font:'Syne',sans-serif;--mono:'DM Mono',monospace}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

header{position:relative;z-index:10;padding:22px 40px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.beta-bar{display:flex;align-items:center;gap:12px}
.beta-badge{background:var(--accent2);color:#fff;font-family:var(--mono);font-size:.65rem;font-weight:700;letter-spacing:.1em;padding:4px 9px;border-radius:5px}
.beta-txt{font-family:var(--mono);font-size:.72rem;color:var(--muted)}
.beta-back{font-family:var(--mono);font-size:.72rem;color:var(--muted);border:1px solid var(--border);padding:5px 12px;border-radius:7px;text-decoration:none;transition:all .2s;white-space:nowrap}
.beta-back:hover{border-color:var(--accent);color:var(--text)}
.logo{font-size:1.1rem;font-weight:800;letter-spacing:-.02em}.logo span{color:var(--accent)}
.api-bar{display:flex;align-items:center;gap:10px}
.api-bar label{font-size:.7rem;color:var(--muted);white-space:nowrap}
.api-bar input{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:.75rem;padding:8px 14px;border-radius:8px;width:280px;outline:none;transition:border-color .2s}
.api-bar input:focus{border-color:var(--accent)}

.tabs{position:relative;z-index:10;display:flex;gap:4px;padding:28px 40px 0}
.tab-btn{background:none;border:1px solid transparent;color:var(--muted);font-family:var(--font);font-size:.85rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:10px 22px;border-radius:8px 8px 0 0;cursor:pointer;transition:all .2s}
.tab-btn.active{background:var(--surface);border-color:var(--border);border-bottom-color:var(--surface);color:var(--text)}
.tab-btn:not(.active):hover{color:var(--text)}

.container{position:relative;z-index:10;margin:0 40px 40px;background:var(--surface);border:1px solid var(--border);border-radius:0 12px 12px 12px;padding:36px;min-height:70vh}
.panel{display:none}.panel.active{display:block}

.reunion-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.correcteur-layout{display:grid;grid-template-columns:1fr 1fr;gap:32px}

.sec{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.sec::before{content:'';display:inline-block;width:20px;height:2px;background:currentColor}

.recorder-box{display:flex;flex-direction:column;align-items:center;gap:18px;background:var(--surface2);border:1px solid var(--border);border-radius:16px;padding:30px 20px}
.rec-timer{font-family:var(--mono);font-size:2rem;font-weight:500;letter-spacing:.05em}
.rec-btn{width:84px;height:84px;border-radius:50%;border:3px solid var(--accent);background:none;cursor:pointer;position:relative;transition:all .3s;outline:none}
.rec-btn::before{content:'';position:absolute;inset:10px;border-radius:50%;background:var(--accent);transition:all .3s}
.rec-btn.recording{border-color:var(--accent2);animation:pulse 1.2s ease-out infinite}
.rec-btn.recording::before{background:var(--accent2);border-radius:6px;inset:22px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,107,107,.5)}70%{box-shadow:0 0 0 18px rgba(255,107,107,0)}100%{box-shadow:0 0 0 0 rgba(255,107,107,0)}}
.rec-status{font-family:var(--mono);font-size:.82rem;color:var(--muted);text-align:center}.rec-status.on{color:var(--accent2)}
.viz{width:100%;height:44px}.viz canvas{width:100%;height:100%;display:block}

.upload-lbl{border:1.5px dashed var(--border);border-radius:10px;padding:14px;text-align:center;cursor:pointer;transition:border-color .2s;font-size:.8rem;color:var(--muted);display:block;width:100%}
.upload-lbl:hover{border-color:var(--accent);color:var(--text)}.upload-lbl input{display:none}

.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:10px 18px;border-radius:8px;border:none;cursor:pointer;transition:all .2s;outline:none;white-space:nowrap}
.btn-p{background:var(--accent);color:#fff}.btn-p:hover{background:#7c74ff;transform:translateY(-1px)}.btn-p:disabled{opacity:.4;cursor:default;transform:none}
.btn-g{background:none;border:1px solid var(--border);color:var(--muted)}.btn-g:hover{border-color:var(--accent);color:var(--text)}.btn-g:disabled{opacity:.4;cursor:default}
.btn-gr{background:none;border:1px solid var(--accent3);color:var(--accent3)}.btn-gr:hover{background:var(--accent3);color:#000}.btn-gr:disabled{opacity:.4;cursor:default}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}

.lbl{font-size:.7rem;color:var(--muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:6px}
.inp{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:.82rem;padding:10px 14px;border-radius:8px;outline:none;transition:border-color .2s}
.inp:focus{border-color:var(--accent)}
.big-ta{width:100%;height:300px;padding:16px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;resize:vertical;outline:none;font-family:var(--mono);font-size:.85rem;line-height:1.75;color:var(--text);transition:border-color .2s}
.big-ta:focus{border-color:var(--accent)}
.res-ta{width:100%;min-height:160px;padding:16px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;resize:none;outline:none;font-family:var(--mono);font-size:.82rem;line-height:1.7;color:var(--text);transition:border-color .2s}
.res-ta:focus{border-color:var(--accent)}

.chips{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.chip{padding:7px 15px;border-radius:20px;cursor:pointer;font-family:var(--font);font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1.5px solid var(--border);color:var(--muted);background:none;transition:all .2s}
.chip.on{border-color:var(--accent);color:var(--accent)}.chip:hover{border-color:var(--accent);color:var(--text)}
.cr-chip{background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-family:var(--font);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:7px 14px;border-radius:6px;cursor:pointer;transition:all .2s}
.cr-chip.sel{background:var(--accent);border-color:var(--accent);color:#fff}

.prog{display:none;margin:10px 0}.prog-lbl{font-family:var(--mono);font-size:.75rem;color:var(--muted);margin-bottom:5px}
.prog-bar{background:var(--surface2);border:1px solid var(--border);border-radius:6px;height:8px;overflow:hidden}
.prog-fill{height:100%;background:var(--accent);width:0%;transition:width .3s;border-radius:6px}

.div{height:1px;background:var(--border);margin:18px 0}

.cbtn{background:none;border:1px solid var(--border);color:var(--muted);font-family:var(--mono);font-size:.72rem;padding:6px 12px;border-radius:6px;cursor:pointer;transition:all .2s}
.cbtn:hover{border-color:var(--accent);color:var(--text)}

.res-box{width:100%;min-height:280px;padding:18px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;font-family:var(--mono);font-size:.85rem;line-height:1.75;color:var(--text);overflow-y:auto;white-space:pre-wrap}
.res-box.ph{color:var(--muted);font-style:italic;font-size:.8rem}

.ld{display:none;align-items:center;gap:8px;font-family:var(--mono);font-size:.8rem;color:var(--muted);margin-top:10px}
.ld.on{display:flex}
.sp{width:15px;height:15px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

.toast{position:fixed;bottom:28px;right:28px;z-index:999;background:var(--surface2);border:1px solid var(--border);padding:13px 20px;border-radius:10px;font-size:.82rem;transform:translateY(16px);opacity:0;transition:all .3s;pointer-events:none}
.toast.on{transform:translateY(0);opacity:1}.toast.ok{border-left:3px solid var(--accent3)}.toast.err{border-left:3px solid var(--accent2)}

.fi{font-family:var(--mono);font-size:.75rem;color:var(--muted);margin-top:8px;min-height:1.2em}
.rcol{display:flex;flex-direction:column;gap:20px}
.tw{position:relative}.cc{position:absolute;bottom:10px;right:12px;font-family:var(--mono);font-size:.68rem;color:var(--muted)}

.srv-box{margin-top:14px;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:10px}

@media(max-width:900px){
  header,.tabs,.container{padding-left:20px;padding-right:20px}
  header{flex-wrap:wrap;gap:12px}.container{margin:0 16px 32px}
  .reunion-grid,.correcteur-layout{grid-template-columns:1fr}
}
