@import url("https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f6f9;--surface:#fff;--surface-2:#f8f9fb;--border:#e9ebf0;--text:#0d1117;--text-muted:#8891a4;--accent:#4f6ef7;--accent-soft:rgba(79,110,247,.07);--green:#12b76a;--green-bg:#f0fdf6;--green-border:rgba(18,183,106,.22);--orange:#f79009;--orange-bg:#fffaeb;--orange-border:rgba(247,144,9,.25);--red:#f04438;--red-bg:#fef3f2;--red-border:rgba(240,68,56,.22);--blue:#4f6ef7;--blue-bg:#eff3ff;--blue-border:rgba(79,110,247,.3);--shadow-sm:0 1px 3px rgba(13,17,23,.06),0 1px 2px rgba(13,17,23,.04);--shadow-md:0 4px 16px rgba(13,17,23,.07),0 2px 6px rgba(13,17,23,.05)}body,html{height:100%;background:var(--bg);color:var(--text);font-family:Inter,sans-serif;-webkit-font-smoothing:antialiased;font-size:14px}.page{min-height:100vh;display:flex;flex-direction:column}.page-header{background:hsla(0,0%,100%,.9);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 36px;height:62px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.header-inner{max-width:1360px;margin:0 auto;height:100%;justify-content:space-between}.header-inner,.header-right,.logo{display:flex;align-items:center}.header-right{gap:20px}.user-name{font-size:13px;color:var(--text-muted);font-weight:500}.admin-badge{font-size:11px;font-weight:600;background:var(--accent-soft);color:var(--accent);padding:3px 10px;border-radius:6px;text-decoration:none;border:1px solid rgba(79,110,247,.18);letter-spacing:.02em}.sign-out{font-size:13px;color:var(--text-muted);text-decoration:none;font-weight:500;transition:color .15s}.sign-out:hover{color:var(--text)}.content{max-width:1360px;margin:32px auto;padding:0 36px;grid-template-columns:1fr 272px;grid-gap:20px}.calendar-layout,.content{display:grid;gap:20px;align-items:start}.calendar-layout{grid-template-columns:228px 1fr;grid-gap:20px}.calendar-wrapper{align-self:start;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px 28px 24px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.month-label{font-size:18px;font-weight:700;letter-spacing:-.4px;text-transform:capitalize;color:var(--text)}.nav-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1}.nav-btn:hover{background:var(--text);color:#fff;border-color:var(--text)}.day-names{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:6px;gap:6px;margin-bottom:6px}.day-name{text-align:center;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:6px 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:90px;grid-gap:6px;gap:6px}.loading-bar{position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:slide 1.2s ease-in-out infinite}@keyframes slide{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.day-cell{position:relative;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);transition:border-color .15s,box-shadow .15s,background .15s;overflow:hidden}.day-inner{width:100%;height:100%;border:none;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:6px 2px;border-radius:10px}.day-inner:disabled{cursor:not-allowed}.day-number{font-size:16px;font-weight:600;line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;margin-bottom:4px}.spot-label{font-weight:500;line-height:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;padding:0 4px}.spot-label,.spot-reserved{font-size:10px;letter-spacing:-.2px}.spot-full,.spot-reserved{font-weight:600}.spot-full{font-size:10px;letter-spacing:-.2px}.day-available{background:var(--green-bg);border-color:var(--green-border)}.day-available .day-number{color:#0a7a47}.day-available .spot-label{color:var(--green)}.day-available:hover{border-color:var(--green)}.day-almost{background:var(--orange-bg);border-color:var(--orange-border)}.day-almost .day-number{color:#9a5c00}.day-almost .spot-label{color:var(--orange)}.day-almost:hover{border-color:var(--orange)}.day-full{background:var(--red-bg);border-color:var(--red-border)}.day-full .day-number{color:#b42318}.day-full .spot-label{color:var(--red)}.day-full .day-inner{cursor:not-allowed}.day-reserved{background:var(--blue-bg);border-color:var(--blue-border)}.day-reserved .day-number,.day-reserved .spot-label{color:var(--blue)}.day-reserved:hover{background:var(--red-bg)!important;border-color:var(--red-border)!important}.day-reserved:hover .day-number,.day-reserved:hover .spot-label{color:var(--red)!important}.day-today{box-shadow:inset 0 0 0 1.5px var(--accent)!important}.day-today .day-number{background:var(--accent);color:#fff}.day-selected{box-shadow:inset 0 0 0 1.5px var(--accent)!important}.day-past{opacity:.18;pointer-events:none}.day-reservations{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:22px 18px;position:-webkit-sticky;position:sticky;top:82px;box-shadow:var(--shadow-sm);height:500px;overflow-y:auto}.upcoming-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:14px}.day-res-date{font-size:13px;font-weight:600;color:var(--text);text-transform:capitalize;margin-bottom:4px;line-height:1.5}.day-res-count{font-size:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border)}.count-ok{color:var(--green);font-weight:700}.count-full{color:var(--red);font-weight:700}.count-max,.upcoming-empty{color:var(--text-muted)}.upcoming-empty{font-size:12px;line-height:1.7}.upcoming-list{list-style:none;display:flex;flex-direction:column;gap:5px}.upcoming-item{display:flex;align-items:center;justify-content:space-between;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 11px;transition:border-color .15s}.upcoming-item:hover{border-color:rgba(79,110,247,.25)}.upcoming-date{font-size:12px;font-weight:500}.cancel-btn{width:20px;height:20px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.cancel-btn:hover{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.modal-num{width:18px;height:18px;border-radius:50%;background:var(--blue-bg);color:var(--blue);font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar{position:-webkit-sticky;position:sticky;top:82px}.upcoming{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:22px 18px;box-shadow:var(--shadow-sm)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:url(/fond.png) 50%/cover no-repeat;position:relative}.login-page:before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.48)}.login-card{position:relative;z-index:1;background:#fff;border-radius:20px;padding:44px 40px;width:100%;max-width:400px;box-shadow:0 24px 64px rgba(0,0,0,.22);margin:16px}.login-sub{font-size:14px;color:#6b7280;margin-bottom:28px;text-align:center}.form-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.form-label{font-size:11px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.07em}.form-input{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:10px 13px;font-size:14px;color:#0d1117;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,110,247,.1)}.form-error{font-size:12px;color:var(--red);margin-bottom:10px}.submit-btn{width:100%;padding:12px;background:var(--text);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s;margin-top:6px}.submit-btn:hover{background:var(--accent)}.submit-btn:disabled{opacity:.45;cursor:not-allowed}@media (max-width:1100px){.calendar-layout{flex-direction:column}.calendar-layout>.day-reservations{width:100%;height:auto;position:static}}@media (max-width:800px){.content{grid-template-columns:1fr;margin:16px auto;padding:0 12px;gap:12px}.page-header{padding:0 16px}.sidebar{position:static}.calendar-wrapper{padding:16px 14px 14px;border-radius:14px}.cal-header{margin-bottom:16px}.cal-grid{gap:4px;grid-auto-rows:70px}.day-names{gap:4px}.day-name{font-size:9px;padding:4px 0}.day-number{font-size:11px;width:22px;height:22px}.spot-label{font-size:6.5px;padding:0 2px}.day-inner{padding:5px 2px;gap:3px}.month-label{font-size:15px}.nav-btn{width:28px;height:28px;font-size:14px}}@media (max-width:480px){.cal-grid{gap:3px;grid-auto-rows:58px}.day-names{gap:3px}.day-number{font-size:10px;width:20px;height:20px}.spot-label{font-size:5.5px}}@media (max-width:800px){.sidebar{display:none}}