:root{--primary: #4f46e5;--primary-dark: #4338ca;--bg: #f5f6fc;--card: #ffffff;--surface: #f6f7fb;--input-bg: #ffffff;--chip-bg: #ffffff;--text: #1e1b3a;--muted: #6b7280;--border: #e6e7f2;--ok: #16a34a;--danger: #dc2626;--radius: 14px;--brand: #e8531c;--brand-accent: #e8531c;--glow: rgba(232, 83, 28, .14);--link: #2563eb;--link-hover: #1d4ed8}a,a:visited{color:var(--link)}a:hover{color:var(--link-hover)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--primary: #22d3ee;--primary-dark: #06b6d4;--bg: #0b1220;--card: #131c2e;--surface: #1b2740;--input-bg: #1b2740;--chip-bg: #1b2740;--text: #e6edf6;--muted: #93a4bd;--border: #26344f;--brand-accent: #ff6a36;--glow: rgba(232, 83, 28, .22);--link: #6cb6ff;--link-hover: #9ccbff}}:root[data-theme=dark]{--primary: #22d3ee;--primary-dark: #06b6d4;--bg: #0b1220;--card: #131c2e;--surface: #1b2740;--input-bg: #1b2740;--chip-bg: #1b2740;--text: #e6edf6;--muted: #93a4bd;--border: #26344f;--brand-accent: #ff6a36;--glow: rgba(232, 83, 28, .22);--link: #6cb6ff;--link-hover: #9ccbff}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.wrap{max-width:880px;margin:0 auto;padding:24px 16px 64px}.wrap.wide{max-width:1120px}.layout{display:grid;grid-template-columns:1fr;gap:16px;align-items:start}.col-main,.col-side{min-width:0}@media (min-width: 920px){.layout{grid-template-columns:380px minmax(0,1fr)}.col-side{position:sticky;top:20px}}.slots{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:0 1px 2px #0f172a0a}h1{font-size:1.5rem;margin:0 0 4px}h2{font-size:1.05rem;margin:0 0 12px}.muted{color:var(--muted)}.subtitle{color:var(--muted);margin:0 0 20px}.day-group{margin-bottom:18px}.day-title{font-weight:600;text-transform:capitalize;margin:0 0 8px;color:var(--text)}.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.slot{border:1px solid var(--border);background:var(--card);border-radius:10px;padding:12px 10px;cursor:pointer;text-align:center;transition:all .12s ease}.slot:hover{border-color:var(--primary);transform:translateY(-1px)}.slot.selected{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 2px #6366f140}.slot .time{font-weight:600;font-size:1.05rem}.slot .left{font-size:.8rem;color:var(--muted)}label{display:block;font-size:.9rem;font-weight:500;margin:12px 0 4px}input[type=text],input[type=email],input[type=tel],input[type=number],input[type=date],input[type=password],input[type=search],textarea,select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:1rem;font-family:inherit;background:var(--input-bg);color:var(--text)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}textarea{min-height:80px;resize:vertical}.checkbox{display:flex;align-items:center;gap:8px;margin-top:8px}.checkbox input{width:auto}.btn{display:inline-block;background:var(--primary);color:#fff;border:none;border-radius:10px;padding:12px 18px;font-size:1rem;font-weight:600;cursor:pointer;width:100%;margin-top:16px}.btn:hover{background:var(--primary-dark)}.btn:disabled{opacity:.6;cursor:default}.btn.secondary{background:var(--card);color:var(--text);border:1px solid var(--border)}.btn.danger{background:var(--card);color:var(--danger);border:1px solid var(--border)}.btn-row{display:flex;gap:10px}.btn-row .btn{margin-top:0}.alert{padding:12px 14px;border-radius:10px;margin:12px 0;font-size:.95rem}.alert.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert.ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.8rem;font-weight:600}.badge.confirmed,.badge.modified{background:#dcfce7;color:#166534}.badge.cancelled,.badge.no_show{background:#fee2e2;color:#991b1b}@media (min-width: 760px){.manage-layout{grid-template-columns:1fr 1fr;align-items:start}}.booking-card{border-left:4px solid var(--primary)}.booking-card h1{font-size:1.55rem}.manage-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.manage-actions .btn{width:auto;flex:0 1 auto;margin-top:0}.link-box{background:var(--surface);border:1px dashed var(--border);border-radius:10px;padding:12px;word-break:break-all;font-size:.9rem}.center{text-align:center}.spinner{text-align:center;color:var(--muted);padding:40px 0;font-size:1.5rem}.brandbar{display:flex;align-items:center;justify-content:center;gap:26px;padding:16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:18px}.brandbar-side{display:flex;align-items:center}.brandbar-side.right{justify-content:center}.brandbar-sep{width:1px;height:66px;background:var(--border);flex:0 0 auto}.brand-logo{max-height:78px;max-width:min(300px,44vw);object-fit:contain}.brand-word{font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--primary)}.brand-company{font-weight:600;color:var(--muted)}.hero h1{font-size:1.7rem}.success-check{width:64px;height:64px;border-radius:50%;background:var(--ok);color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.intervention>h2{margin:0 0 12px}.bento{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:stretch}.bento.single{grid-template-columns:1fr}@media (max-width: 680px){.bento{grid-template-columns:1fr}}.bento-cell{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px}.bento-cell h3{font-size:.78rem;margin:0 0 10px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}.bento-cell p{margin:0;color:var(--text)}.modality-badge{display:inline-flex;align-items:center;gap:8px;background:var(--card);color:var(--primary);border:1px solid var(--border);padding:6px 12px;border-radius:999px;font-weight:600;margin-bottom:10px}.modality-icon{font-size:1.1rem}.btn.small{width:auto;padding:8px 14px;font-size:.9rem;margin-top:0}.btn.small.secondary{background:var(--card);color:var(--text);border:1px solid var(--border)}.day-chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}.day-chip{flex:0 0 auto;border:1px solid var(--border);background:var(--chip-bg);border-radius:999px;padding:9px 16px;font-weight:600;font-size:.9rem;cursor:pointer;white-space:nowrap;color:var(--text);text-transform:capitalize;transition:all .12s ease}.day-chip:hover{border-color:var(--primary)}.day-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.selected-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.selected-bar .sel-when{font-weight:700;font-size:1.05rem}.selected-bar .check{color:var(--ok);font-weight:800;margin-right:8px}.booking-grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:start}@media (min-width: 720px){.booking-grid{grid-template-columns:300px minmax(0,1fr)}}.times{align-content:start}.hero>p{max-width:760px}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cal-title{font-weight:700;text-transform:capitalize}.cal-nav{width:32px;height:32px;border:1px solid var(--border);background:var(--card);border-radius:8px;cursor:pointer;font-size:1.1rem;line-height:1;color:var(--text)}.cal-nav:disabled{opacity:.35;cursor:default}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-dow{text-align:center;font-size:.7rem;color:var(--muted);font-weight:700;padding:4px 0}.cal-empty{aspect-ratio:1}.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:.9rem;color:#cbd5e1}.cal-day.avail{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;font-weight:600}.cal-day.avail:hover{border-color:var(--primary)}.cal-day.selected{background:var(--primary);color:#fff;border-color:var(--primary)}.theme-toggle{position:fixed;top:14px;right:14px;z-index:50;display:inline-flex;background:var(--card);border:1px solid var(--border);border-radius:999px;padding:3px;box-shadow:0 2px 10px #0f172a2e}.tt-indicator{position:absolute;top:3px;left:3px;width:44px;height:30px;background:var(--primary);border-radius:999px;transition:transform .24s cubic-bezier(.4,0,.2,1)}.tt-btn{position:relative;z-index:1;border:none;background:transparent;color:var(--muted);width:44px;height:30px;border-radius:999px;cursor:pointer;font-size:.82rem;font-weight:700;line-height:1}.tt-btn.on{color:#fff}.login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden;background:var(--bg)}.login-glow{position:absolute;top:-120px;left:50%;transform:translate(-50%);width:520px;height:340px;pointer-events:none;background:radial-gradient(circle,var(--glow),transparent 70%)}.login-box{position:relative;width:100%;max-width:380px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 28px 34px;background:var(--card);border:1px solid var(--border);border-radius:20px;box-shadow:0 16px 48px #00000029}.login-logo{width:72px;height:72px;object-fit:cover;border-radius:18px;box-shadow:0 10px 28px #e8531c59}.login-title{font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin-top:18px;color:var(--text)}.login-sub{font-size:.95rem;color:var(--muted);margin-top:4px}.login-form{width:100%;display:flex;flex-direction:column;gap:10px;margin-top:26px}.login-screen .login-input{width:100%;padding:12px 14px;font-size:.95rem;border:1px solid var(--border);border-radius:10px;background:var(--input-bg);color:var(--text);font-family:inherit}.login-screen .login-input:focus{outline:none;border-color:var(--brand-accent);box-shadow:0 0 0 3px #e8531c2e}.login-btn{width:100%;background:var(--brand);color:#fff;border:none;border-radius:10px;padding:13px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:2px;transition:filter .12s ease}.login-btn:hover{filter:brightness(.94)}.login-btn:disabled{opacity:.6;cursor:default}.login-form .alert{width:100%;margin:0;text-align:left}.login-hint{font-size:.88rem;color:var(--muted);line-height:1.45;margin:0 0 4px;text-align:center}.login-otp{text-align:center;font-size:1.5rem;letter-spacing:.4em;font-weight:700;font-variant-numeric:tabular-nums;padding-left:.4em}.login-qr{width:200px;height:200px;align-self:center;border-radius:12px;background:#fff;padding:10px;box-shadow:0 2px 10px #0000001f}.login-secret{font-size:.82rem;color:var(--muted);text-align:center}.login-secret summary{cursor:pointer}.login-secret code{display:inline-block;margin-top:8px;padding:6px 10px;border-radius:8px;background:var(--surface-2, rgba(127,127,127,.12));font-size:.95rem;letter-spacing:.08em;word-break:break-all}.login-link{background:none;border:none;color:var(--muted);font-size:.86rem;cursor:pointer;padding:6px;margin-top:2px}.login-link:hover{color:var(--brand)}.pw-reqs{list-style:none;margin:2px 0;padding:0;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:5px 14px;text-align:left}.pw-req{display:flex;align-items:center;gap:7px;font-size:.8rem;color:var(--muted);transition:color .15s ease}.pw-req-ico{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:16px;height:16px;border-radius:50%;font-size:.68rem;font-weight:800;background:var(--surface-2, rgba(127,127,127,.14));color:var(--muted);transition:all .15s ease}.pw-req.ok{color:#16a34a}.pw-req.ok .pw-req-ico{background:#16a34a29;color:#16a34a}.pw-req.bad{color:#dc2626}.pw-req.bad .pw-req-ico{background:#dc262624;color:#dc2626}.pw-mismatch{font-size:.8rem;color:#dc2626;text-align:left;margin:-2px 0 2px}.login-stage{display:flex;gap:20px;align-items:stretch;justify-content:center;width:100%;flex-wrap:wrap}.tfa-help-toggle{display:inline-flex;align-items:center;gap:8px;align-self:center;margin-top:2px;background:#e8531c1a;color:var(--brand);border:1px solid rgba(232,83,28,.25);border-radius:999px;padding:8px 15px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .12s ease}.tfa-help-toggle:hover{background:#e8531c2b}.tfa-help-toggle .i{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--brand);color:#fff;font-family:Georgia,serif;font-style:italic;font-weight:700;font-size:.78rem}.tfa-help-card{position:relative;width:100%;max-width:350px;box-sizing:border-box;display:flex;flex-direction:column;text-align:left;padding:22px 22px 24px;background:var(--card);border:1px solid var(--border);border-radius:20px;box-shadow:0 16px 48px #00000029;animation:tfaHelpIn .28s ease}@keyframes tfaHelpIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:none}}.tfa-help-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.tfa-help-title{font-size:1.05rem;font-weight:700;color:var(--text);line-height:1.25}.tfa-help-close{background:none;border:none;color:var(--muted);font-size:1.3rem;line-height:1;cursor:pointer;padding:0 2px;flex:0 0 auto}.tfa-help-close:hover{color:var(--text)}.tfa-help-intro{font-size:.84rem;color:var(--muted);line-height:1.45;margin:8px 0 4px}.tfa-anim{width:100%;height:116px;margin:6px 0 10px}.tfa-anim .scanline{animation:tfaScan 2.2s ease-in-out infinite;transform-origin:center}@keyframes tfaScan{0%,to{transform:translateY(0);opacity:.9}50%{transform:translateY(34px);opacity:.5}}.tfa-anim .check{animation:tfaPop 2.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center}@keyframes tfaPop{0%,56%{opacity:0;transform:scale(.7)}70%{opacity:1;transform:scale(1.04)}82%,to{opacity:1;transform:scale(1)}}.tfa-anim .ping{animation:tfaPing 2.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center}@keyframes tfaPing{0%,58%{opacity:0;transform:scale(.85)}70%{opacity:.35}to{opacity:0;transform:scale(1.6)}}.tfa-stores{display:flex;gap:12px;margin:6px 0 12px}.tfa-store{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;text-decoration:none;padding:11px 8px;border:1px solid var(--border);border-radius:13px;background:var(--input-bg);transition:border-color .12s ease,transform .12s ease}.tfa-store:hover{border-color:var(--brand);transform:translateY(-1px)}.tfa-store img{width:78px;height:78px;border-radius:8px;background:#fff;padding:4px}.tfa-store-label{font-size:.78rem;font-weight:600;color:var(--text);text-align:center;line-height:1.2}.tfa-store-label span{display:block;font-size:.68rem;font-weight:500;color:var(--muted)}.tfa-app-name{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:2px}.tfa-steps{list-style:none;counter-reset:s;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}.tfa-step{counter-increment:s;display:flex;align-items:flex-start;gap:10px;font-size:.83rem;color:var(--text);line-height:1.4}.tfa-step:before{content:counter(s);flex:0 0 auto;width:21px;height:21px;border-radius:50%;background:#e8531c1f;color:var(--brand);font-size:.76rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;margin-top:1px}.welcome-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative;overflow:hidden;background:var(--bg)}.welcome-glow{position:absolute;top:-140px;left:50%;transform:translate(-50%);width:620px;height:380px;pointer-events:none;background:radial-gradient(circle,var(--glow),transparent 70%)}.welcome-wrap{position:relative;width:100%;max-width:720px}.welcome-stack{margin-bottom:16px}.bento-pair{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 560px){.bento-pair{grid-template-columns:1fr}}.bento-ico{display:inline-flex;width:30px;height:30px;color:var(--brand)}.bento-ico svg{width:100%;height:100%}.bento-box.bento-row-cta{flex-direction:row;align-items:center;gap:18px;padding:18px 24px}.bento-row-cta .bento-ico{flex-shrink:0}.bento-row-text{flex:1}.bento-row-cta .bento-row-text h3{margin:0}.bento-row-cta .bento-row-text p{margin:3px 0 0}.bento-row-cta .bento-btn{margin-top:0;align-self:center;flex-shrink:0}@media (max-width: 560px){.bento-box.bento-row-cta{flex-direction:column;align-items:flex-start}.bento-row-cta .bento-btn{align-self:stretch;text-align:center}}.welcome-head{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:30px}.welcome-logo{width:76px;height:76px;border-radius:18px;object-fit:cover;box-shadow:0 12px 30px #e8531c61}.welcome-title{font-size:2rem;font-weight:800;letter-spacing:-.02em;margin:16px 0 0;color:var(--text)}.welcome-sub{color:var(--muted);margin:6px 0 0;font-size:1rem}.bento{display:grid;grid-template-columns:1fr 1fr;gap:16px}.bento-box{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:24px;display:flex;flex-direction:column;gap:9px;box-shadow:0 10px 32px #00000014}.bento-box.wide{grid-column:1 / -1}.bento-box.primary{border-color:var(--brand-accent);background:linear-gradient(180deg,rgba(232,83,28,.06),var(--card) 60%)}.bento-icon{font-size:1.9rem;line-height:1}.bento-box h3{margin:4px 0 0;font-size:1.18rem;color:var(--text)}.bento-box p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.5}.bento-btn{margin-top:auto;align-self:flex-start;display:inline-block;text-decoration:none;background:var(--brand);color:#fff;padding:11px 18px;border-radius:10px;font-weight:600;font-size:.95rem;transition:filter .12s ease}.bento-btn:hover{filter:brightness(.94)}.bento-btn.secondary{background:transparent;color:var(--brand);border:1px solid var(--border)}.bento-btn.secondary:hover{filter:none;border-color:var(--brand-accent)}.bento-locked{margin-top:auto!important;font-size:.85rem!important;color:var(--muted)!important;background:var(--surface);border:1px dashed var(--border);border-radius:10px;padding:10px 12px;line-height:1.4}.welcome-foot{text-align:center;color:var(--muted);font-size:.82rem;margin-top:22px;opacity:.8}@media (max-width: 640px){.bento{grid-template-columns:1fr}.bento-box.wide{grid-column:auto}.welcome-title{font-size:1.7rem}}.staff-login-logo{text-align:center;font-weight:800;font-size:1.5rem;letter-spacing:-.02em;color:var(--primary);margin:32px 0 4px}.staff-page{padding-bottom:48px}.staff-content{width:100%;padding:18px 28px 56px}@media (max-width: 640px){.staff-content{padding:14px 14px 40px}}.staff-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 165px 12px 20px;background:var(--card);border-bottom:1px solid var(--border)}.staff-header-l{display:flex;align-items:center;gap:12px;min-width:0}.staff-header-r{display:flex;align-items:center;gap:12px}.staff-logo{width:34px;height:34px;object-fit:contain;flex:0 0 auto}@media (max-width: 640px){.staff-header{padding-right:150px}.staff-user{display:none}}.staff-back{width:34px;height:34px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:1.2rem;cursor:pointer;flex:0 0 auto}.staff-brand{font-weight:800;color:var(--primary);font-size:1.05rem;letter-spacing:-.01em}.staff-sub{color:var(--muted);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52vw}.staff-user{color:var(--muted);font-size:.9rem;font-weight:600}.badge.st-draft{background:var(--surface);color:var(--muted)}.badge.st-published{background:#dcfce7;color:#166534}.badge.st-closed{background:#fee2e2;color:#991b1b}.badge.st-archived{background:#ede9fe;color:#5b21b6}.camp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:18px;margin-top:8px}.camp-card{text-align:left;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease;color:var(--text);font-family:inherit;display:flex;flex-direction:column}.camp-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 6px 20px #0f172a1a}.camp-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.camp-id{display:flex;align-items:center;gap:12px;min-width:0}.camp-logo{width:50px;height:50px;object-fit:contain;background:#fff;border:1px solid var(--border);border-radius:11px;padding:5px;flex:0 0 auto}.camp-logo.placeholder{display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.4rem;color:var(--primary);background:var(--surface)}.camp-titles{min-width:0}.camp-company{font-weight:800;font-size:1.12rem;color:var(--text);line-height:1.2}.camp-loc{font-size:.82rem;color:var(--muted);margin-top:3px}.camp-desc{font-size:.98rem;color:var(--text);margin-bottom:16px;line-height:1.4;flex:1}.camp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.camp-stats .cs{text-align:center;background:var(--surface);border-radius:9px;padding:8px 4px}.camp-stats .cs b{display:block;font-size:1.2rem;color:var(--text)}.camp-stats .cs span{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.02em}.camp-stats .cs.free b{color:#2563eb}.camp-stats .cs.mine b{color:#b45309}.camp-stats .cs.done b{color:#16a34a}.filter-tabs{display:flex;gap:8px;margin:8px 0 18px}.ft{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:999px;padding:8px 16px;font-weight:600;font-size:.9rem;cursor:pointer;display:inline-flex;align-items:center;gap:7px}.ft span{background:var(--surface);border-radius:999px;padding:1px 8px;font-size:.78rem;color:var(--muted)}.ft.on{background:var(--primary);color:#fff;border-color:var(--primary)}.ft.on span{background:#ffffff40;color:#fff}.appt-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--card)}.appt-table{width:100%;border-collapse:collapse;font-size:.9rem}.appt-table thead th{text-align:left;padding:11px 14px;border-bottom:2px solid var(--border);color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;background:var(--surface)}.appt-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.appt-table th.sortable:hover{color:var(--primary)}.appt-table tbody td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.appt-table tbody tr:hover,.appt-table tr.row-open{background:var(--surface)}.appt-table tr.notes-row:hover,.appt-table tr.notes-row{background:transparent}.appt-table tr.notes-row td{padding:0 14px 14px}.col-when{white-space:nowrap}.col-when .when-date{font-size:.72rem;color:var(--muted);text-transform:capitalize}.col-when .when-time{font-weight:800;color:var(--primary);font-size:1rem}.col-when .when-dur{font-size:.72rem;color:var(--muted);margin-top:2px}.col-cust{font-weight:600;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.col-contacts{max-width:260px}.col-contacts a{color:var(--muted);text-decoration:none;font-size:.85rem;display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom}.col-contacts a:hover{color:var(--primary)}.col-tech{white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}.actions-col,.col-actions{width:1%}.row-actions{display:flex;flex-wrap:nowrap;gap:6px;justify-content:flex-end}.row-actions .btn.small{width:auto;padding:6px 11px;font-size:.8rem;white-space:nowrap}.row-actions .btn.small.danger{background:#ef4444;color:#fff;border:1px solid #ef4444}.row-actions .btn.small.danger:hover{background:#dc2626;border-color:#dc2626}.row-actions .btn.small.danger:disabled{opacity:.6}.btn.small.on{background:var(--primary);color:#fff;border-color:var(--primary)}.op{display:inline-block;padding:2px 9px;border-radius:999px;font-size:.74rem;font-weight:700;white-space:nowrap}.op-unassigned{background:var(--surface);color:var(--muted)}.op-assigned{background:#dbeafe;color:#1e40af}.op-in_progress{background:#fef3c7;color:#92400e}.op-completed{background:#dcfce7;color:#166534}.op-noshow{background:#fee2e2;color:#991b1b}.op-cancelled{background:var(--surface);color:var(--muted);text-decoration:line-through}.col-device{white-space:nowrap}.dev-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:999px;font-size:.76rem;font-weight:700;border:1px solid transparent}button.dev-badge{cursor:pointer}button.dev-badge:hover{filter:brightness(.96)}.dev-ok{background:#dcfce7;color:#166534}.dev-no{background:#fee2e2;color:#991b1b}.dev-pending{background:#fef3c7;color:#92400e}.device-choices{display:flex;flex-direction:column;gap:8px;margin-top:4px}.device-choices .btn.small{width:100%}.btn.small.dev-ok-btn{background:#16a34a;color:#fff;border-color:#16a34a}.ref-toolbar{display:flex;justify-content:flex-end;margin-bottom:14px}.ref-filter{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--muted)}.ref-filter select{padding:7px 10px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:.88rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.modal{background:var(--card);border-radius:16px;padding:24px;max-width:440px;width:100%;box-shadow:0 18px 50px #0000004d}.modal-title{font-size:1.12rem;font-weight:700;color:var(--text);margin-bottom:10px}.modal-body{font-size:.92rem;line-height:1.5;color:var(--muted);margin-bottom:16px}.modal-body b{color:var(--text)}.modal textarea{width:100%;min-height:84px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;resize:vertical;box-sizing:border-box}.modal-check{display:flex;align-items:flex-start;gap:9px;font-size:.9rem;color:var(--text);margin:14px 0 4px;cursor:pointer}.modal-check input{margin-top:2px;flex:0 0 auto}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}.modal-actions .btn{width:auto;flex:0 0 auto}.appt-notes{padding-top:12px}.note{background:var(--surface);border-radius:9px;padding:9px 12px;margin-bottom:8px}.note-head{display:flex;justify-content:space-between;font-size:.78rem;color:var(--muted);margin-bottom:3px}.note-body{color:var(--text);font-size:.9rem;white-space:pre-wrap}.note-add{display:flex;gap:8px;align-items:flex-start;margin-top:6px}.note-add textarea{min-height:44px}.note-add .btn.small{width:auto;flex:0 0 auto}.note-actions{display:flex;gap:14px;margin-top:6px}.note-link{background:none;border:none;padding:0;font-size:.78rem;font-weight:600;color:var(--primary);cursor:pointer}.note-link.danger{color:var(--danger)}.note-link:hover{text-decoration:underline}.note-edit textarea{width:100%}.note-edit-actions{display:flex;gap:8px;margin-top:6px}.note-edit-actions .btn.small{width:auto}.sv-preview{background:var(--bg);border:1px solid var(--vborder);border-radius:20px;padding:22px;color:var(--text);font-family:var(--font-body, inherit)}.sv-logos{display:flex;align-items:center;justify-content:center;gap:22px;background:#fff;border-radius:var(--radius);padding:14px;margin-bottom:14px;border:1px solid #eef1f5}.sv-logos img{height:36px;max-width:40%;object-fit:contain}.sv-sep{width:1px;height:38px;background:#cbd5e1;display:inline-block}.sv-card{background:var(--card);color:var(--text);border:1px solid var(--vborder);border-radius:var(--radius);padding:18px;margin-bottom:14px}.sv-hero h3{margin:0 0 4px;font-size:1.25rem;font-family:var(--font-head, inherit)}.sv-muted{color:var(--muted);font-size:.88rem}.sv-badge{display:inline-block;background:var(--primary);color:#fff;border-radius:999px;padding:4px 12px;font-size:.8rem;font-weight:600}.sv-book{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media (max-width: 560px){.sv-book{grid-template-columns:1fr}}.sv-cal-head{text-align:center;margin-bottom:8px;font-weight:700;text-transform:capitalize}.sv-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.sv-dow{text-align:center;font-size:.62rem;color:var(--muted);font-weight:700}.sv-cd{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.72rem;border-radius:6px;color:var(--disabled)}.sv-cd.av{background:var(--card);border:1px solid var(--vborder);color:var(--text);font-weight:600}.sv-cd.se{background:var(--primary);color:#fff;border-color:var(--primary)}.sv-times{display:flex;flex-direction:column;gap:8px}.sv-slot{border:1px solid var(--vborder);border-radius:calc(var(--radius) - 4px);padding:9px 12px;display:flex;justify-content:space-between;align-items:center;background:var(--card)}.sv-slot b{font-size:.95rem}.sv-slot span{font-size:.72rem;color:var(--muted)}.sv-btn{display:inline-block;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);padding:12px 20px;font-weight:700;margin-top:14px;cursor:default}.sv-preview{--primary: #2563eb;--bg: #f1f5f9;--card: #fff;--text: #0f172a;--muted: #64748b;--vborder: #e2e8f0;--disabled: #cbd5e1;--radius: 14px}.sv1 .sv-preview{--primary: #4f46e5;--bg: #f6f6fe;--card: #fff;--text: #1e1b4b;--muted: #6b7280;--vborder: #e7e7f5;--radius: 14px}.sv2 .sv-preview{--primary: #22d3ee;--bg: #0b1220;--card: #131c2e;--text: #e2e8f0;--muted: #94a3b8;--vborder: #243049;--disabled: #3b4a66;--radius: 10px}.sv2 .sv-badge,.sv2 .sv-cd.se{color:#06121f}.sv2 .sv-btn{color:#06121f;box-shadow:0 0 0 1px #22d3ee,0 0 18px #22d3ee66}.sv3 .sv-preview{--primary: #f97316;--bg: #fff7ed;--card: #fff;--text: #7c2d12;--muted: #b07a5b;--vborder: #fde6cf;--disabled: #f3d9c2;--radius: 24px;--font-head: "Trebuchet MS", "Segoe UI", sans-serif}.sv4 .sv-preview{--primary: #1e3a8a;--bg: #f8fafc;--card: #fff;--text: #0f172a;--muted: #64748b;--vborder: #d6dde6;--disabled: #cbd5e1;--radius: 4px;--font-head: Georgia, "Times New Roman", serif}.sv4 .sv-card{box-shadow:none}.sv4 .sv-hero h3{font-size:1.45rem;letter-spacing:-.01em}.sv5 .sv-preview{--primary: #7c3aed;--bg: #faf5ff;--card: #fff;--text: #2e1065;--muted: #8b7aa8;--vborder: #ece3fb;--disabled: #ddd2f0;--radius: 18px}.sv5 .sv-hero{background:linear-gradient(135deg,#7c3aed,#ec4899);color:#fff;border:none}.sv5 .sv-hero .sv-muted{color:#ffffffd9}.sv5 .sv-hero h3{font-size:1.5rem;font-weight:800}.sv5 .sv-badge{background:#ffffff40}.sv5 .sv-btn{background:linear-gradient(135deg,#7c3aed,#ec4899)}.sv6 .sv-preview{--primary: #0d9488;--bg: #f0fdfa;--card: #fff;--text: #134e4a;--muted: #5e8a85;--vborder: #cdeee9;--disabled: #c3e3de;--radius: 20px}.variant-head{margin:32px 0 12px}.variant-head h2{margin:0}.variant-head .vn{color:#64748b;font-size:.95rem}
