@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Manrope:wght@400;500;600;700&display=swap";:root{--bg: #f3f7fc;--bg-soft: #e9f0f9;--surface: #ffffff;--surface-2: #f5f9ff;--text: #10253c;--text-muted: #4e6683;--line: #d2dfef;--line-strong: #b5cae2;--primary: #003c71;--primary-strong: #002f59;--primary-soft: #e2effb;--accent: #2f71b3;--accent-soft: #dfebf9;--danger: #b42338;--danger-soft: #ffe9ec;--shadow: 0 20px 45px rgba(8, 41, 76, .16);--radius-lg: 24px;--radius-md: 14px;--radius-sm: 10px}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Manrope,Segoe UI,sans-serif;color:var(--text);background:radial-gradient(circle at 10% 8%,rgba(47,113,179,.2),transparent 42%),radial-gradient(circle at 85% 10%,rgba(0,60,113,.18),transparent 38%),linear-gradient(180deg,#f8fbff,#eef4fb)}h1,h2,h3,h4,h5,h6{margin:0;font-family:Space Grotesk,Segoe UI,sans-serif;letter-spacing:-.02em}p{margin:0;color:var(--text-muted)}button,select,input,textarea{font:inherit}button{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);padding:9px 12px;font-weight:600;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease,background .14s ease}button:hover{transform:translateY(-1px);border-color:var(--line-strong);box-shadow:0 6px 18px #10271e1a}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}main{min-height:100vh}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;gap:12px;max-width:1680px;margin:0 auto;padding:12px}.sidebar{background:linear-gradient(170deg,#003c71,#002f59 80%);color:#eff6ff;border-radius:var(--radius-lg);padding:14px 12px;display:flex;flex-direction:column;gap:6px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow);animation:fade-up .44s ease both}.brand-block{margin-bottom:10px;padding-bottom:14px;border-bottom:1px solid rgba(223,238,255,.25)}.brand-logo-frame{border-radius:12px;background:#fff;border:1px solid #bfd4ea;padding:8px}.brand-logo{display:block;width:100%;height:auto;max-height:64px;object-fit:contain;object-position:left center}.side-btn{width:100%;text-align:left;border-color:#dfeeff38;background:#ffffff0f;color:#e4f0ff;padding:11px 13px}.side-btn.active{background:linear-gradient(120deg,#2f71b3,#4f8ecb);color:#f6fbff;border-color:#b4d8fae6}.side-btn:not(.active):hover{border-color:#dfeeff70;background:#ffffff26}.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid rgba(223,238,255,.3);color:#d5e8ff}.page-main{overflow-x:hidden;animation:fade-up .52s ease both}.app-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;background:linear-gradient(135deg,#fffffff0,#eef5ffeb);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px;box-shadow:0 12px 26px #0a2c4f1c;margin-bottom:14px}.app-header h1,.admin-panel h1,.auth-card h1{font-size:clamp(1.45rem,2.2vw,2rem)}.app-header p{margin-top:7px}.active-planners{margin-top:10px;display:flex;flex-wrap:wrap;align-items:center;gap:7px}.active-planners-title{color:#36597e;font-weight:700;font-size:12px}.planner-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#174069;border:1px solid #bed1e6;background:#f2f7fe;border-radius:999px;padding:3px 9px}.planner-chip.self{border-color:#9dc4ea;background:#e8f2fd}.planner-chip.empty{font-weight:600;color:#5d7491;border-style:dashed}.planner-chip-dot{width:8px;height:8px;border-radius:50%;box-shadow:0 0 0 1px #09284833}.toolbar{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.toolbar button{border-color:#c3d5ea}.toolbar input,.toolbar select,.table-toolbar input,.table-toolbar select,.table-create input,.table-create select,.inline-form input,.inline-form select,.inline-form textarea,.log-table td input,.log-table td select,.item-editor input,.item-editor select,.item-editor textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);padding:9px 11px;transition:border-color .12s ease,box-shadow .12s ease}.toolbar input,.toolbar select{width:auto}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1a7f5a2e}.notice,.error{margin-top:12px;padding:11px 13px;border-radius:12px;border:1px solid var(--line);background:var(--surface)}.notice{color:#153a60;background:var(--primary-soft);border-color:#bcd5ee}.error{color:#8f2235;background:var(--danger-soft);border-color:#ffc6cf}.toast-stack{position:fixed;top:16px;right:16px;z-index:1200;width:min(460px,calc(100vw - 32px))}.toast{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-radius:12px;border:1px solid var(--line);box-shadow:0 12px 24px #0f231b2e;padding:12px 14px;animation:fade-up .2s ease both}.toast-notice{color:#1f4f3d;background:var(--primary-soft);border-color:#bce6d2}.toast-error{color:#8f2235;background:var(--danger-soft);border-color:#ffc6cf}.toast-close{border:1px solid transparent;background:transparent;padding:0;width:24px;height:24px;line-height:1;border-radius:6px;font-size:16px;color:inherit}.toast-close:hover{border-color:currentColor;box-shadow:none;transform:none}.auth-card{width:min(760px,96vw);margin:7vh auto;background:#fffffff2;border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px;animation:fade-up .5s ease both}.auth-logo{width:min(620px,100%);height:auto;border-radius:10px;border:1px solid #d6e4f3;padding:8px 10px;background:linear-gradient(180deg,#fff,#f7fbff)}.inline-form{display:grid;gap:10px}.admin-panel{background:#fffffff2;border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;box-shadow:0 12px 24px #0a2d521a;animation:fade-up .32s ease both}.table-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.table-toolbar input{min-width:240px}.table-create{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-bottom:12px}.log-table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.log-table{width:100%;border-collapse:collapse;min-width:620px}.log-table th,.log-table td{padding:10px 12px;border-bottom:1px solid #e6eef8;text-align:left;font-size:13px}.log-table th{position:sticky;top:0;z-index:1;background:#f2f7fe;color:#1b3f66}.log-table tr:hover td{background:#fbfdfb}.scheduler-shell{background:#fffffff2;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:0 14px 28px #082a4c1a;overflow:hidden;animation:fade-up .34s ease both}.scheduler-scroll{overflow:auto;max-height:calc(100vh - 290px)}.conflict-banner{display:flex;align-items:center;flex-wrap:wrap;gap:7px;padding:10px 14px;border-bottom:1px solid #ffd5db;background:linear-gradient(90deg,#ffecee,#fff9fa);color:#8f2235;font-weight:700;font-size:13px}.conflict-banner span{border:1px solid #ffb5c2;background:#fff;border-radius:999px;padding:2px 8px;font-weight:600}.time-header{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:230px 1fr;height:68px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#f5f9ff,#ebf2fb)}.corner{position:sticky;left:0;z-index:11;display:flex;align-items:center;padding:0 16px;height:68px;border-right:1px solid var(--line);font-weight:700;color:#174069;background:linear-gradient(180deg,#f5f9ff,#ebf2fb)}.ticks{position:relative}.tick{position:absolute;top:0;height:68px;transform:translate(-1px);border-left:1px solid #d8e6de;padding:6px 7px;display:flex;flex-direction:column;justify-content:center;gap:2px;color:#4e6683;font-size:11px;white-space:nowrap;overflow:hidden}.tick-day{font-weight:600;color:#1e406b;font-size:11px;white-space:nowrap}.tick-time{font-size:12px;font-weight:700;color:#003c71;letter-spacing:.02em;white-space:nowrap}.rows{position:relative}.row{display:grid;grid-template-columns:230px 1fr;border-bottom:1px solid #e8f0eb}.resource-label{position:sticky;left:0;z-index:2;padding:0 13px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid var(--line);border-left:8px solid #79a7d6;background:#fcfdff}.resource-label strong{font-size:14px}.resource-label span{margin-top:4px;font-size:12px;color:var(--text-muted)}.resource-label.placeholder{background:#f4f9ff}.lane{position:relative;background:linear-gradient(180deg,#fff,#f6fafe),repeating-linear-gradient(to right,transparent,transparent calc(12.5% - 1px),rgba(66,95,83,.03) calc(12.5% - 1px),rgba(66,95,83,.03) 12.5%)}.grid-line{position:absolute;top:0;bottom:0;border-left:1px solid #edf4ef}.create-preview{position:absolute;top:14px;bottom:14px;border-radius:10px;border:1px dashed var(--primary);background:#1a7f5a29;pointer-events:none}.planning-item{position:absolute;height:58px;min-width:98px;border-radius:13px;border:1px solid #bdd7f1;background:linear-gradient(180deg,#edf5fe,#deebfa);box-shadow:0 7px 16px #09386329;padding:8px 10px;display:flex;flex-direction:column;gap:2px;cursor:pointer;overflow:hidden;transition:box-shadow .14s ease,transform .14s ease}.planning-item:hover{transform:translateY(-1px);box-shadow:0 10px 22px #0839663d}.planning-item strong{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planning-item span,.planning-item em{font-size:11px;color:#36597e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-style:normal}.planning-item.maintenance{background:linear-gradient(180deg,#fff7e5,#ffefd1);border-color:#f2d396}.planning-item.vacation{background:linear-gradient(180deg,#edf6ff,#dbe9f9);border-color:#b8d4f0}.planning-item.blocked,.planning-item.note{background:linear-gradient(180deg,#f4f7fb,#e8eef6);border-color:#c7d4e2}.planning-item.has-conflict{border-color:#f2556e;box-shadow:0 10px 22px #c21a3f47}.planning-item.locked-by-other{border-color:#f3a05c;background:linear-gradient(180deg,#fff4e8,#ffe7d0);box-shadow:0 8px 18px #a5580f3d;cursor:not-allowed}.item-warning{font-size:11px;color:#8f2235;font-weight:700}.item-lock{font-size:11px;color:#8a4b1a;font-weight:700}.resize-handle{position:absolute;top:0;bottom:0;width:10px;cursor:ew-resize}.resize-handle.left{left:0}.resize-handle.right{right:0}.item-oci-btn{position:absolute;top:6px;right:6px;border-radius:999px;border:1px solid #f2d396;background:#fff4db;color:#805200;font-size:10px;font-weight:700;padding:1px 7px}.remote-cursor{position:absolute;top:0;bottom:0;width:0;pointer-events:none;z-index:8}.remote-cursor:before{content:"";position:absolute;top:0;bottom:0;left:-1px;border-left:2px solid rgba(9,40,72,.32)}.remote-cursor-pointer{position:absolute;top:2px;left:-6px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:10px solid #2f71b3}.remote-cursor-label{position:absolute;top:12px;left:8px;color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:2px 8px;box-shadow:0 6px 18px #0003;white-space:nowrap}.item-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;justify-content:center;align-items:center;padding:20px;background:#061f3a85;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.item-editor{width:min(580px,100%);max-height:min(92vh,860px);overflow:auto;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 20px 38px #081d1547;padding:16px;display:flex;flex-direction:column;gap:10px}.item-editor label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:#1f466f}.editor-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:4px}.danger-btn{border-color:#ffb5c2;background:#fff0f3;color:#9b2337}.danger-btn:hover{border-color:#ff97a9;background:#ffdfe5}.sidebar>*{animation:slide-in .42s ease both}.sidebar>*:nth-child(2){animation-delay:30ms}.sidebar>*:nth-child(3){animation-delay:60ms}.sidebar>*:nth-child(4){animation-delay:90ms}.sidebar>*:nth-child(5){animation-delay:.12s}.sidebar>*:nth-child(6){animation-delay:.15s}.sidebar>*:nth-child(7){animation-delay:.18s}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in{0%{opacity:0;transform:translate(-14px)}to{opacity:1;transform:translate(0)}}@media (max-width: 1180px){.app-shell{grid-template-columns:1fr;gap:14px;padding:14px}.sidebar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:14px}.sidebar h2,.sidebar-foot{grid-column:1 / -1}.side-btn{min-height:42px;text-align:center}.app-header{flex-direction:column;align-items:stretch}.toolbar{justify-content:flex-start}.active-planners{margin-top:8px}}@media (max-width: 900px){.time-header,.row{grid-template-columns:168px 1fr}.corner,.resource-label{padding-left:10px;padding-right:8px}.table-toolbar input{min-width:180px;flex:1}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}
