@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&display=swap";:root{--bg:#000;--surface:#111;--surface-2:#1e1e1e;--surface-3:#2a2a2a;--border:#ffffff14;--text:#fff;--text-muted:#9ca3af;--accent:#ef7d00;--accent-blue:#00adef;--accent-dark:#004f9f;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--radius:2px;--radius-lg:4px;--font:"Montserrat", "Inter", -apple-system, sans-serif;--touch-target:56px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{overscroll-behavior:none}.screen{background:var(--bg);flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.screen-pc{max-width:100%!important}@media (width>=1024px){.screen-pc{max-width:1400px!important}.screen-pc .screen-content{padding:24px 40px}.matrix-wrapper{max-height:70vh}}.timer-portable{max-width:400px;margin:0 auto}.screen-header{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;align-items:center;gap:12px;padding:20px 16px 12px;display:flex;position:sticky;top:0}.screen-content{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}h1{letter-spacing:-.03em;font-size:1.5rem;font-weight:800}h2{font-size:1.25rem;font-weight:700}h3{font-size:1.1rem;font-weight:700}p,span,li{font-size:.95rem}@media (width>=1024px){h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p,span,li{font-size:1.05rem}.matrix-table{font-size:.95rem}.matrix-table th{padding:12px 16px;font-size:.8rem}.matrix-table td{padding:10px 16px}}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;padding:16px;box-shadow:0 4px 20px #0003}.card-title{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);opacity:.8;margin-bottom:12px;font-size:.7rem;font-weight:800}.btn{min-height:var(--touch-target);border-radius:var(--radius);width:100%;font-family:var(--font);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:8px;padding:0 20px;font-size:1rem;font-weight:700;transition:all .2s;display:flex}.btn:active{opacity:.85;transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff}.btn-blue{background:var(--accent-blue);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#000}.btn-surface{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-ghost{color:var(--text);border:1px solid var(--border);background:0 0}.btn-sm{border-radius:8px;min-height:40px;padding:0 14px;font-size:.875rem}.btn-pulse{animation:2s infinite pulse-glow;box-shadow:0 0 #ef7d00b3}@keyframes pulse-glow{0%{transform:scale(.95);box-shadow:0 0 #ef7d00b3}70%{transform:scale(1);box-shadow:0 0 0 10px #ef7d0000}to{transform:scale(.95);box-shadow:0 0 #ef7d0000}}.input{width:100%;min-height:var(--touch-target);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);outline:none;padding:0 16px;font-size:1rem;transition:border-color .15s}@media (width>=1024px){.input{min-height:44px;font-size:.95rem}}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}.progress-bar-bg{background:var(--surface-2);border-radius:100px;height:10px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--accent), var(--accent-blue));border-radius:100px;height:100%;transition:width .4s}.badge{border-radius:100px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-accent{color:var(--accent);background:#3b82f633}.badge-success{color:var(--success);background:#22c55e33}.badge-warning{color:var(--warning);background:#f59e0b33}.badge-danger{color:var(--danger);background:#ef444433}.badge-muted{color:var(--text-muted);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff0d;border:1px solid #ffffff1a}.divider{background:var(--border);height:1px;margin:4px 0}.back-btn{color:var(--accent);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:4px;font-size:1.5rem;line-height:1}.matrix-wrapper{border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}.matrix-table{border-collapse:collapse;min-width:600px;font-size:.8rem}.matrix-table th,.matrix-table td{border:1px solid var(--border);text-align:left;white-space:nowrap;padding:6px 10px}.matrix-table th{background:var(--surface-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:600}.matrix-table td{background:var(--surface);color:var(--text);transition:background .2s,color .2s}.matrix-table td:hover{background:var(--surface-2);filter:brightness(1.2)}.matrix-table .cell-done{color:var(--success);background:#22c55e1f}.matrix-table .cell-active{color:var(--accent);border:1px solid var(--accent);background:#ef7d0026;font-weight:800}.matrix-table .cell-pending{color:var(--text-muted)}.message-bubble{border-radius:12px;max-width:80%;padding:10px 14px;font-size:.9rem;line-height:1.4}.message-bubble.from-me{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.message-bubble.from-them{color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff0d;border-bottom-left-radius:4px;align-self:flex-start}.message-meta{color:var(--text-muted);margin-top:2px;font-size:.7rem}.modal-overlay{z-index:100;background:#000000d9;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--surface);border-radius:20px 20px 0 0;flex-direction:column;gap:12px;width:100%;max-width:480px;padding:24px 16px 36px;display:flex}.modal-title{text-align:center;margin-bottom:8px;font-size:1.1rem;font-weight:700}.list-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.list-item:last-child{border-bottom:none}.avatar{background:var(--surface-2);width:40px;height:40px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.station-grid{grid-template-columns:repeat(2,1fr);gap:10px;max-height:50vh;padding:4px;display:grid;overflow-y:auto}.station-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);text-align:left;cursor:pointer;flex-direction:column;gap:4px;padding:12px;transition:all .2s;display:flex}.station-item:hover{border-color:var(--accent);background:#ef7d000d}.station-item.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);background:#ef7d001a}.station-item .st-name{color:var(--text);text-transform:uppercase;font-size:.85rem;font-weight:800}.station-item .st-meta{color:var(--text-muted);font-size:.7rem}.station-item.st-cours{border-left:3px solid var(--warning)}.station-item.st-atelier{border-left:3px solid var(--accent-blue)}.logo-container{align-items:center;gap:8px;display:flex}.logo-circle{border:2px solid var(--accent);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:relative}.logo-circle:after{content:"";border:1.5px solid var(--accent-blue);border-radius:50%;width:12px;height:12px}.logo-text{color:#fff;letter-spacing:-.01em;font-size:1.2rem;font-weight:900}.logo-text span{color:var(--accent)}
