:root{--radius-lg:1.5rem;--radius-md:1rem;--radius-sm:.75rem;--mint:#a8e6cf;--lavender:#c9bdf2;--peach:#ffd3b6;--bg:#16171f;--glow-1:#a8e6cf12;--glow-2:#c9bdf217;--surface:#1e2029;--surface-2:#272a36;--text:#eef0f7;--text-muted:#9aa0b5;--accent:var(--mint);--on-accent:#1c2d25;--danger:#f2a6a6;--danger-bg:#f2a6a61f;--border:#ffffff17;--ring:#a8e6cf59;--shadow:0 10px 36px #00000059;--shadow-soft:0 4px 16px #00000038;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}[data-theme=light]{--bg:#f7f5fb;--glow-1:#a8e6cf59;--glow-2:#c9bdf259;--surface:#fff;--surface-2:#f1eef9;--text:#2c2f3d;--text-muted:#6f7488;--accent:#8fd9ba;--on-accent:#1c2d25;--danger:#d97c7c;--danger-bg:#d97c7c1f;--border:#2c2f3d1f;--ring:#8fd9ba73;--shadow:0 10px 36px #5f588629;--shadow-soft:0 4px 16px #5f58861f}*{box-sizing:border-box}body{background-color:var(--bg);background-image:radial-gradient(40rem 28rem at 12% -8%, var(--glow-1), transparent 60%), radial-gradient(36rem 26rem at 105% 110%, var(--glow-2), transparent 60%);background-attachment:fixed;min-height:100dvh;margin:0;transition:background-color .25s,color .25s}h1,h2,h3{letter-spacing:-.02em;line-height:1.2}input,button{font:inherit}button{cursor:pointer}.icon-btn{border:1px solid var(--border);background:var(--surface);width:2.5rem;height:2.5rem;box-shadow:var(--shadow-soft);border-radius:999px;justify-content:center;align-items:center;font-size:1.1rem;transition:transform .15s;display:inline-flex}.icon-btn:active{transform:scale(.92)}.lang-switch{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:999px;padding:.2rem;display:inline-flex}.lang-switch-btn{color:var(--text-muted);letter-spacing:.04em;background:0 0;border:none;border-radius:999px;padding:.3rem .65rem;font-size:.78rem;font-weight:600;transition:background .2s,color .2s}.lang-switch-btn.is-active{background:var(--accent);color:var(--on-accent)}.btn-primary{background:var(--accent);width:100%;color:var(--on-accent);box-shadow:var(--shadow-soft);border:none;border-radius:999px;padding:.85rem 1.5rem;font-size:1rem;font-weight:700;transition:filter .2s,transform .15s}.btn-primary:hover:not(:disabled){filter:brightness(1.06)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{border:1px solid var(--border);color:var(--text);background:0 0;border-radius:999px;padding:.45rem 1rem;font-size:.875rem;font-weight:600;transition:background .2s}.btn-ghost:hover{background:var(--surface-2)}:focus-visible{outline:3px solid var(--ring);outline-offset:2px}.auth-layout{min-height:100dvh;padding:1.25rem;padding-top:calc(.9rem + env(safe-area-inset-top));padding-bottom:calc(1.25rem + env(safe-area-inset-bottom));flex-direction:column;display:flex}.auth-controls{justify-content:flex-end;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.build-version{color:var(--text-muted);opacity:.6;font-variant-numeric:tabular-nums;pointer-events:none;font-size:.7rem;position:fixed;bottom:.4rem;right:.6rem}.auth-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);width:100%;max-width:26rem;box-shadow:var(--shadow);margin:auto;padding:2rem 1.5rem}.brand{align-items:center;gap:.6rem;margin-bottom:1.75rem;display:flex}.brand-logo{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--mint), var(--lavender));width:2.75rem;height:2.75rem;box-shadow:var(--shadow-soft);justify-content:center;align-items:center;font-size:1.4rem;display:inline-flex}.brand-name{letter-spacing:-.01em;font-size:1.15rem;font-weight:800}.auth-title{margin:0 0 .25rem;font-size:1.75rem}.auth-subtitle{color:var(--text-muted);margin:0 0 1.75rem}.field{margin-bottom:1.1rem;display:block}.field-label{color:var(--text-muted);margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.field input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);width:100%;color:var(--text);padding:.8rem 1rem;transition:border-color .2s}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring);outline:none}.form-error{border-radius:var(--radius-md);background:var(--danger-bg);color:var(--danger);margin:0 0 1rem;padding:.65rem 1rem;font-size:.9rem}.page{flex-direction:column;min-height:100dvh;display:flex}.topbar{padding:.8rem 1rem;padding-top:calc(.8rem + env(safe-area-inset-top));border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--surface) 75%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.6rem;display:flex;position:sticky;top:0}.brand-inline{white-space:nowrap;font-size:1.05rem;font-weight:800}.topbar-controls{align-items:center;gap:.5rem;display:flex}.empty-state{text-align:center;padding:2rem 1.5rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom));flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.9rem;display:flex}.empty-state h1{margin:0;font-size:clamp(1.6rem,5vw,2.2rem)}.role-badge{letter-spacing:.03em;border-radius:999px;padding:.3rem .9rem;font-size:.8rem;font-weight:700}.role-owner{background:var(--peach);color:#4a3324}.role-client{background:var(--lavender);color:#322a4d}.empty-hint{max-width:26rem;color:var(--text-muted);margin:0}.splash{min-height:100dvh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.spinner{border:3px solid var(--surface-2);border-top-color:var(--accent);border-radius:50%;width:2.2rem;height:2.2rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.shell{min-height:100dvh;display:flex}.sidebar{display:none}.shell-main{flex-direction:column;flex:1;min-width:0;display:flex}.content{width:100%;max-width:60rem;padding:1.25rem 1rem;padding-bottom:calc(5.5rem + env(safe-area-inset-bottom));flex:1;margin:0 auto}.tabbar{z-index:20;padding:.4rem .5rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:color-mix(in srgb, var(--surface) 88%, transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-link{border-radius:var(--radius-md);color:var(--text-muted);flex-direction:column;align-items:center;gap:.15rem;padding:.35rem .9rem;font-size:.72rem;font-weight:600;text-decoration:none;transition:background .2s,color .2s;display:flex}.nav-link .nav-icon{font-size:1.25rem;line-height:1}.nav-link.is-active{color:var(--text);background:var(--surface-2)}@media (width>=48rem){.mobile-only{display:none!important}.sidebar{border-right:1px solid var(--border);background:color-mix(in srgb, var(--surface) 60%, transparent);flex-direction:column;gap:1.5rem;width:15rem;height:100dvh;padding:1.5rem 1rem;display:flex;position:sticky;top:0}.sidebar .brand-inline{padding:0 .5rem;font-size:1.15rem}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.sidebar-nav .nav-link{flex-direction:row;gap:.6rem;padding:.6rem .75rem;font-size:.95rem}.sidebar-footer{flex-direction:column;display:flex}.content{padding:2rem}}.page-section{flex-direction:column;gap:1.1rem;display:flex}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.page-head h1{margin:0;font-size:clamp(1.4rem,4vw,1.9rem)}.back-link{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-block}.back-link:hover{color:var(--text)}@media (width<=47.99rem){.desktop-only{display:none!important}}.card-block{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-soft);padding:1.25rem}.card-block h2{margin:0 0 .9rem;font-size:1.1rem}.block-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.block-head h2{margin-bottom:0}.card-grid{grid-template-columns:1fr;gap:.9rem;display:grid}@media (width>=48rem){.card-grid{grid-template-columns:repeat(auto-fill,minmax(17rem,1fr))}.card-grid-span{grid-column:1/-1}}.entity-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-soft);flex-direction:column;transition:transform .15s;display:flex;overflow:hidden}.entity-card-link{color:inherit;text-decoration:none}.entity-card:hover{transform:translateY(-2px)}.entity-card-main{color:inherit;flex:1;padding:1.1rem 1.2rem;text-decoration:none;display:block}.entity-card-main h3{margin:0 0 .3rem;font-size:1.05rem}.entity-card-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:.4rem;padding:.5rem .9rem;display:flex}.muted{color:var(--text-muted);margin:.2rem 0}.hint{color:var(--text-muted);margin:0 0 .75rem;font-size:.85rem}.badge-row{flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:.6rem;display:flex}.chip{background:var(--surface-2);color:var(--text-muted);border-radius:999px;align-items:center;padding:.35rem .65rem;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.chip-accent{background:color-mix(in srgb, var(--accent) 25%, transparent);color:var(--text)}.chip-soft{background:color-mix(in srgb, var(--lavender) 22%, transparent);color:var(--text)}.entity-form{flex-direction:column;gap:.4rem;display:flex}.field select{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);width:100%;color:var(--text);padding:.8rem 1rem}.field-row{grid-template-columns:1fr;gap:0 .9rem;display:grid}@media (width>=36rem){.field-row{grid-template-columns:repeat(auto-fit,minmax(9rem,1fr))}}.form-actions{justify-content:flex-end;align-items:center;gap:.6rem;margin-top:.5rem;display:flex}.btn-inline{width:auto;padding:.6rem 1.4rem;font-size:.9rem}.btn-small{padding:.3rem .75rem;font-size:.8rem}.btn-danger-ghost{border:1px solid color-mix(in srgb, var(--danger) 40%, transparent);color:var(--danger);background:0 0;border-radius:999px;padding:.45rem 1rem;font-size:.875rem;font-weight:600;transition:background .2s}.btn-danger-ghost:hover{background:var(--danger-bg)}.saved-note{color:var(--accent);font-size:.85rem;font-weight:600}.type-choice{border:none;grid-template-columns:1fr;gap:.5rem;margin:0 0 .6rem;padding:0;display:grid}@media (width>=36rem){.type-choice{grid-template-columns:1fr 1fr}}.type-choice legend{margin-bottom:.4rem}.type-option{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);cursor:pointer;align-items:flex-start;gap:.6rem;padding:.75rem .9rem;transition:border-color .2s;display:flex}.type-option.is-selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--ring)}.type-option input{accent-color:var(--accent);margin-top:.2rem}.type-option span{flex-direction:column;gap:.1rem;display:flex}.type-option small{color:var(--text-muted)}.check-list{flex-direction:column;gap:.35rem;display:flex}.check-item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);cursor:pointer;align-items:center;gap:.6rem;padding:.55rem .75rem;display:flex}.check-item input{accent-color:var(--accent);width:1.05rem;height:1.05rem}.restrict-box{border:1px solid var(--border);border-radius:var(--radius-md);margin:0 0 .5rem;padding:.9rem}.day-picker{border:none;margin:0 0 .6rem;padding:0}.day-picker legend{margin-bottom:.3rem}.day-toggles{flex-wrap:wrap;gap:.4rem;display:flex}.day-toggle{border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);border-radius:999px;padding:.45rem .7rem;font-size:.82rem;font-weight:700;transition:background .15s,color .15s}.day-toggle.is-active{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.day-group{margin-top:.9rem}.day-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 .4rem;font-size:.85rem}.slot-row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.4rem;padding:.6rem .75rem;display:flex}.slot-time{font-variant-numeric:tabular-nums;font-weight:700}.slot-plans{flex-wrap:wrap;flex:1;align-items:center;gap:.3rem;display:flex}.slot-actions{align-items:center;gap:.3rem;margin-left:auto;display:flex}.slot-form-wrap{border:1px dashed var(--border);border-radius:var(--radius-md);margin-bottom:.6rem;padding:.9rem}.splash-inline{justify-content:center;padding:3rem;display:flex}.search-bar{align-items:center;display:flex;position:relative}.search-icon{opacity:.6;pointer-events:none;font-size:.95rem;position:absolute;left:.9rem}.search-input{border:1px solid var(--border);background:var(--surface-2);width:100%;color:var(--text);border-radius:999px;padding:.7rem 1rem .7rem 2.4rem}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring);outline:none}.scroll-sentinel{height:1px}.status-active{background:color-mix(in srgb, var(--accent) 30%, transparent);color:var(--text)}.status-expired{background:var(--danger-bg);color:var(--danger)}.status-exhausted{background:color-mix(in srgb, var(--peach) 35%, transparent);color:var(--text)}.status-future{background:color-mix(in srgb, var(--lavender) 30%, transparent);color:var(--text)}.status-suspended{background:var(--surface);border:1px dashed var(--border);color:var(--text-muted)}.entries-warn{background:color-mix(in srgb, var(--peach) 30%, transparent);color:#ffbd8a}[data-theme=light] .entries-warn{background:color-mix(in srgb, var(--peach) 55%, transparent);color:#9c4f1b}.entries-alert{background:var(--danger-bg);color:var(--danger);font-weight:700}.renew-hint{color:var(--danger);flex-basis:100%;margin:.3rem 0 0;font-size:.82rem}.client-head{flex-direction:column;align-items:flex-start;gap:.25rem;margin-bottom:.9rem;display:flex}.client-head h2{overflow-wrap:anywhere;margin:0}.client-head .btn-primary{margin-top:.5rem}.client-email{overflow-wrap:anywhere;margin:0;font-size:.85rem}.sub-row{flex-direction:column;align-items:flex-start;gap:.45rem}.sub-row-head{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.sub-row-head .slot-time{overflow-wrap:anywhere}.sub-row .slot-actions{align-self:flex-end;margin-left:0}.block-head h2{margin:0}.home-hero{flex:0;padding-bottom:0}.my-subs h2{margin-bottom:.75rem}.date-field{margin-bottom:0}.date-input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-2);cursor:pointer;align-items:center;gap:.5rem;padding:.55rem .85rem;display:inline-flex;position:relative}.date-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}.date-input-native{opacity:0;cursor:pointer;border:none;width:100%;height:100%;position:absolute;inset:0}.date-input-text{font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:600}.date-input-icon{font-size:.95rem;line-height:1}.slot-row-error{flex-basis:100%;margin:.3rem 0 0}.booking-room-link{color:var(--text);text-decoration:none}.booking-room-link:hover{color:var(--accent)}.profile-link{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);align-items:center;gap:.6rem;padding:.6rem .75rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .2s;display:flex}.profile-link:hover,.profile-link.is-active{background:var(--surface-2)}.profile-link-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.settings-account{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.profile-avatar{background:linear-gradient(135deg, var(--mint), var(--lavender));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:3.25rem;height:3.25rem;font-size:1.5rem;display:inline-flex}.settings-account-info{flex:1;min-width:0}.settings-account-info h2{margin:0}.settings-account-info p{text-overflow:ellipsis;margin:.15rem 0 0;overflow:hidden}.settings-row{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem 0;display:flex}.settings-row:first-of-type{border-top:none}.settings-label{font-weight:600}.settings-logout{justify-content:center;display:flex}.settings-logout .btn-danger-ghost{width:100%;max-width:20rem;padding:.7rem 1rem}@media (width>=48rem){.auth-card{padding:2.75rem 2.5rem}.topbar{padding-left:2rem;padding-right:2rem}}
