:root{--indigo: #6366f1;--indigo-600: #4f46e5;--radius: 14px;--shadow: 0 4px 24px rgba(0, 0, 0, .08);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}:root[data-theme=light]{--bg: #f3f4f8;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--fg: #1e293b;--fg-muted: #64748b;--accent: #6366f1;--accent-soft: #eef2ff;--danger: #ef4444;--success: #16a34a}:root[data-theme=dark]{--bg: #0b1120;--surface: #151c2c;--surface-2: #1c2436;--border: #2a3450;--fg: #e2e8f0;--fg-muted: #94a3b8;--accent: #818cf8;--accent-soft: #1e2547;--danger: #f87171;--success: #4ade80}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--fg);transition:background .2s,color .2s;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;border-radius:10px;font-size:.92rem;transition:background .15s,transform .05s,opacity .15s}button:active{transform:scale(.97)}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font-family:inherit;font-size:.95rem;background:var(--surface-2);color:var(--fg);border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem;width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}label{display:block;font-size:.8rem;color:var(--fg-muted);margin-bottom:.3rem;font-weight:600}.btn-primary{background:var(--accent);color:#fff;padding:.6rem 1.1rem;font-weight:600}.btn-primary:hover{background:var(--indigo-600)}.btn-ghost{background:transparent;color:var(--fg);padding:.5rem .8rem;border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-2)}.btn-danger{background:transparent;color:var(--danger);border:1px solid var(--border);padding:.5rem .8rem}.app-header{display:flex;align-items:center;gap:1rem;padding:.9rem 1.4rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.logo{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.15rem}.logo img{width:30px;height:30px}.spacer{flex:1}.icon-btn{background:var(--surface-2);border:1px solid var(--border);width:40px;height:40px;display:grid;place-items:center;font-size:1.1rem;border-radius:10px}.icon-btn:hover{background:var(--accent-soft)}.tabs{display:flex;gap:.3rem}.tab{background:transparent;color:var(--fg-muted);padding:.5rem .9rem;font-weight:600;border-radius:10px}.tab.active{background:var(--accent-soft);color:var(--accent)}.badge{background:var(--danger);color:#fff;border-radius:999px;font-size:.7rem;padding:.05rem .4rem;margin-left:.3rem}.container{max-width:1100px;margin:0 auto;padding:1.4rem}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);width:100%;max-width:400px;padding:2rem}.auth-card h1{margin:.4rem 0 .2rem;font-size:1.5rem}.auth-card .sub{color:var(--fg-muted);font-size:.9rem;margin-bottom:1.4rem}.field{margin-bottom:.9rem}.switch-link{background:none;color:var(--accent);font-weight:600;padding:0}.msg{padding:.7rem .9rem;border-radius:10px;font-size:.88rem;margin-bottom:1rem}.msg.error{background:color-mix(in srgb,var(--danger) 14%,transparent);color:var(--danger)}.msg.ok{background:color-mix(in srgb,var(--success) 16%,transparent);color:var(--success)}.cal-toolbar{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}.cal-title{font-size:1.3rem;font-weight:700;text-transform:capitalize;min-width:200px}.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.cal-dow{text-align:center;font-size:.72rem;font-weight:700;color:var(--fg-muted);text-transform:uppercase;padding-bottom:.3rem}.cal-cell{background:var(--surface);border:1px solid var(--border);border-radius:12px;min-height:96px;padding:.4rem;display:flex;flex-direction:column;gap:3px;cursor:pointer;min-width:0;transition:border-color .15s}.cal-cell:hover{border-color:var(--accent)}.cal-cell.dim{opacity:.4}.cal-cell.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.cal-daynum{font-size:.8rem;font-weight:700;color:var(--fg-muted);align-self:flex-end}.cal-cell.today .cal-daynum{color:var(--accent)}.chip{font-size:.72rem;padding:.12rem .4rem;border-radius:6px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px;max-width:100%}.chip.done{opacity:.55;text-decoration:line-through}.chip .dot{width:6px;height:6px;border-radius:50%;background:#ffffffd9;flex:none}.view-switch{display:flex;gap:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:3px}.view-tab{background:transparent;color:var(--fg-muted);padding:.4rem .8rem;font-weight:600;border-radius:8px}.view-tab:hover{color:var(--fg)}.view-tab.active{background:var(--accent);color:#fff}.week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;align-items:start}.week-col{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;min-height:140px;display:flex;flex-direction:column}.week-col.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.week-col-head{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--surface-2);border:none;border-bottom:1px solid var(--border);padding:.5rem .3rem;width:100%;color:var(--fg)}.week-col-head:hover{background:var(--accent-soft)}.week-dow{font-size:.68rem;font-weight:700;color:var(--fg-muted);text-transform:uppercase}.week-num{font-size:1.15rem;font-weight:700;line-height:1}.week-num.today{color:var(--accent)}.week-col-body{display:flex;flex-direction:column;gap:4px;padding:.4rem}.week-chip{width:100%;border:none;cursor:pointer;text-align:left}.week-chip:hover{filter:brightness(1.08)}.week-empty{color:var(--fg-muted);font-size:.8rem;text-align:center;padding:.6rem 0}.day-view{max-width:720px}.day-list{display:flex;flex-direction:column;gap:.6rem}.occ-row{display:flex;align-items:center;gap:.8rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.7rem .9rem;border-left:4px solid var(--accent)}.occ-check{width:26px;height:26px;border-radius:8px;border:2px solid var(--border);display:grid;place-items:center;background:var(--surface-2);flex:none;font-size:.9rem}.occ-check.done{background:var(--success);border-color:var(--success);color:#fff}.occ-main{flex:1;min-width:0}.occ-title{font-weight:600}.occ-title.done{text-decoration:line-through;color:var(--fg-muted)}.occ-meta{font-size:.8rem;color:var(--fg-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:grid;place-items:center;z-index:50;padding:1rem}.modal{background:var(--surface);border-radius:18px;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow);border:1px solid var(--border)}.modal-head{display:flex;align-items:center;padding:1.1rem 1.3rem;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:1.15rem}.modal-body{padding:1.3rem;display:flex;flex-direction:column;gap:.9rem}.modal-foot{display:flex;gap:.6rem;justify-content:flex-end;padding:1rem 1.3rem;border-top:1px solid var(--border)}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}.weekday-picker{display:flex;gap:.3rem;flex-wrap:wrap}.weekday-picker button{width:38px;height:38px;border-radius:9px;border:1px solid var(--border);background:var(--surface-2);color:var(--fg);font-weight:600}.weekday-picker button.on{background:var(--accent);color:#fff;border-color:var(--accent)}.color-picker{display:flex;gap:.4rem}.color-picker button{width:28px;height:28px;border-radius:50%;border:2px solid transparent}.color-picker button.on{border-color:var(--fg)}.voice-btn{position:relative}.voice-btn.listening{background:var(--danger);color:#fff;border-color:var(--danger);animation:pulse 1.2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--danger) 50%,transparent)}50%{box-shadow:0 0 0 8px transparent}}.voice-fab{position:fixed;right:22px;bottom:22px;z-index:40;display:flex;align-items:center;gap:.5rem;height:60px;padding:0 1.3rem;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--indigo-600));color:#fff;font-weight:700;font-size:.95rem;box-shadow:0 10px 28px color-mix(in srgb,var(--accent) 45%,transparent);animation:fab-bob 2.6s ease-in-out infinite}.voice-fab:hover{filter:brightness(1.06)}.voice-fab-icon{font-size:1.5rem;line-height:1}.voice-fab.listening{background:var(--danger);animation:fab-pulse 1.1s infinite;box-shadow:0 0 color-mix(in srgb,var(--danger) 55%,transparent)}@keyframes fab-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes fab-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--danger) 55%,transparent)}50%{box-shadow:0 0 0 14px transparent}}@media (prefers-reduced-motion: reduce){.voice-fab{animation:none}}@media (max-width: 620px){.voice-fab{right:16px;bottom:16px;height:58px;width:58px;padding:0;justify-content:center}.voice-fab-label,.voice-fab.listening .voice-fab-label{display:none}}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1rem 1.2rem;margin-bottom:.8rem}.list-row{display:flex;align-items:center;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.pill{font-size:.72rem;padding:.15rem .55rem;border-radius:999px;font-weight:700}.pill.pending{background:#fef3c7;color:#92400e}.pill.approved{background:#dcfce7;color:#166534}.pill.rejected{background:#fee2e2;color:#991b1b}.pill.admin{background:var(--accent-soft);color:var(--accent)}.empty{text-align:center;color:var(--fg-muted);padding:3rem 1rem}h2.section{font-size:1.2rem;margin:0 0 1rem}.muted{color:var(--fg-muted);font-size:.85rem}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--fg);color:var(--bg);padding:.7rem 1.2rem;border-radius:999px;font-size:.9rem;z-index:100;box-shadow:var(--shadow)}@media (max-width: 820px){.cal-title{min-width:auto}.week-col{min-height:110px}}@media (max-width: 620px){.container{padding:.7rem}.app-header{gap:.4rem;padding:.7rem .8rem;flex-wrap:wrap}.logo{font-size:1rem}.logo img{width:26px;height:26px}.tabs{gap:.15rem;order:3;width:100%;justify-content:space-around}.tab{padding:.45rem .5rem;font-size:.8rem}.tab-label{display:none}.tab.active .tab-label{display:inline}.icon-btn{width:36px;height:36px}.btn-ghost{padding:.45rem .6rem}.cal-toolbar{gap:.4rem}.cal-title{font-size:1rem;flex:1;text-align:center}.view-switch{order:5;width:100%}.view-tab{flex:1;padding:.5rem 0}.cal-toolbar .btn-primary{order:6;width:100%}.cal-grid{gap:3px}.cal-cell{min-height:58px;border-radius:9px;padding:.25rem;gap:2px}.cal-daynum{font-size:.72rem}.chip{font-size:.6rem;padding:.08rem .25rem;border-radius:4px;gap:2px}.chip .dot{width:5px;height:5px}.week-grid{grid-template-columns:1fr;gap:6px}.week-col{flex-direction:row;min-height:0;align-items:stretch}.week-col-head{flex-direction:row;gap:.5rem;justify-content:flex-start;align-items:center;width:96px;min-width:96px;border-bottom:none;border-right:1px solid var(--border)}.week-num{font-size:1rem}.week-col-body{flex:1}.week-empty{text-align:left;padding:.5rem .2rem}.modal{max-width:100%;border-radius:16px}.row-2{grid-template-columns:1fr}.modal-foot{position:sticky;bottom:0;background:var(--surface)}}
