/* starfishbook.com — Konsensus booking. Modern three-pane scheduling UI. */

/* ---------- fonts (self-hosted, same files as konsensus.net) ---------- */
@font-face{font-family:'Inter';font-style:normal;font-weight:300 700;font-display:swap;src:url(fonts/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:300 700;font-display:swap;src:url(fonts/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:400 800;font-display:swap;src:url(fonts/nuFiD-vYSZviVYUb_rj3ij__anPXDTLYgFE_.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:400 800;font-display:swap;src:url(fonts/nuFiD-vYSZviVYUb_rj3ij__anPXDTzYgA.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400 600;font-display:swap;src:url(fonts/fraunces-latin-var.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400 600;font-display:swap;src:url(fonts/fraunces-latinext-var.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

/* ---------- theme tokens ---------- */
:root{--radius:16px;--ease:cubic-bezier(.4,0,.2,1)}
[data-theme="light"]{--bg:#FAFAF8;--bg-elevated:#FFFFFF;--bg-card:#FFFFFF;--bg-sunken:#F4F2EE;--text:#16130F;--text-secondary:#6B6256;--text-dim:#9A9183;--orange:#F7931A;--orange-press:#E0850F;--purple:#7C4DBA;--border:#ECE8E1;--border-strong:#DED8CE;--bg-nav:rgba(250,250,248,.8);--shadow-card:0 1px 2px rgba(20,16,12,.04),0 12px 32px -12px rgba(20,16,12,.12);--orange-tint:rgba(247,147,26,.10)}
[data-theme="dark"]{--bg:#0E0C0A;--bg-elevated:#171310;--bg-card:#1A1613;--bg-sunken:#120F0C;--text:#F3F0EB;--text-secondary:#A39A8D;--text-dim:#6B6256;--orange:#F7931A;--orange-press:#FFA733;--purple:#B98BE6;--border:#2A241E;--border-strong:#352D25;--bg-nav:rgba(14,12,10,.8);--shadow-card:0 1px 2px rgba(0,0,0,.3),0 18px 50px -18px rgba(0,0,0,.7);--orange-tint:rgba(247,147,26,.14)}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--orange);text-decoration:none}
h1,h2,h3{margin:0;font-weight:600}
button{font-family:inherit}
::selection{background:var(--orange-tint)}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;height:58px;background:var(--bg-nav);backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6);border-bottom:1px solid var(--border);z-index:50;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(16px,4vw,40px)}
.nav-brand{display:flex;align-items:center;gap:8px;color:var(--text)}
.nav-brand img{width:26px;height:26px}
.nav-brand-text{font-family:'Fraunces','Playfair Display',serif;font-size:1.1rem;font-weight:400;font-variation-settings:'opsz' 40;text-transform:lowercase;letter-spacing:-.4px}
.theme-toggle{width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;position:relative;overflow:hidden;transition:border-color .2s}
.theme-toggle:hover{border-color:var(--orange)}
.icon-sun,.icon-moon{position:absolute;transition:all .4s var(--ease)}
[data-theme="dark"] .icon-sun{transform:rotate(90deg) scale(0);opacity:0}
[data-theme="light"] .icon-moon{transform:rotate(-90deg) scale(0);opacity:0}

/* ---------- background wash (subtle, contained — no bleed-through) ---------- */
.bg-wash{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(1100px 620px at 50% -8%, var(--orange-tint), transparent 60%),
    radial-gradient(800px 500px at 110% 110%, rgba(124,77,186,.06), transparent 55%);}

/* ---------- page + card ---------- */
.page{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:84px clamp(12px,3vw,24px) 28px}
.bk-card{width:100%;max-width:560px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-card);padding:clamp(22px,3vw,38px);transition:max-width .35s var(--ease)}
.bk-card.wide{max-width:940px}
.step{display:none}
.step.active{display:block;animation:rise .4s var(--ease)}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.bk-intro{text-align:center;margin-bottom:24px}
.bk-intro.tight{margin-bottom:18px}
.eyebrow{display:inline-block;font-size:11px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--orange);margin-bottom:10px}
.bk-intro h1{font-family:'Fraunces','Playfair Display',serif;font-weight:400;font-variation-settings:'opsz' 40;font-size:clamp(30px,5vw,40px);letter-spacing:-.5px}
.bk-intro h1 .hero-star{width:.82em;height:.82em;vertical-align:-.09em;margin-right:.32em;display:inline-block}
.bk-intro h2{font-family:'Playfair Display',serif;font-size:clamp(21px,3vw,26px);font-weight:600}
.bk-intro p{color:var(--text-secondary);margin:8px 0 0;font-size:15px}

.loading{display:flex;justify-content:center;padding:40px 0}
.spin{display:inline-block;width:18px;height:18px;border:2px solid var(--border-strong);border-top-color:var(--orange);border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* ---------- service list ---------- */
.services{display:flex;flex-direction:column;gap:10px}
.svc{display:flex;align-items:center;gap:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;cursor:pointer;text-align:left;width:100%;color:inherit;transition:border-color .2s,transform .15s,box-shadow .2s}
.svc:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-card)}
.svc:focus-visible{outline:2px solid var(--orange);outline-offset:2px}
.svc-dot{width:38px;height:38px;border-radius:11px;background:var(--accent,var(--orange));flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#000;font-size:18px;opacity:.92}
.svc-body{flex:1;min-width:0}
.svc-name{font-family:'Playfair Display',serif;font-size:17px;font-weight:600;margin-bottom:3px}
.svc-desc{font-size:13px;color:var(--text-secondary);line-height:1.45}
.svc-meta{display:flex;gap:7px;align-items:center;margin-top:9px}
.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;background:var(--bg-sunken);color:var(--text-secondary)}
.chip.accent{background:var(--accent,var(--orange));color:#000}
.svc-arrow{color:var(--text-dim);font-size:18px;transition:transform .2s,color .2s}
.svc:hover .svc-arrow{transform:translateX(3px);color:var(--orange)}

/* ---------- schedule: 3-pane ---------- */
.sched{display:grid;grid-template-columns:240px 1fr 224px;gap:clamp(16px,2.4vw,30px);align-items:start;min-height:392px}
.sched-info{display:flex;flex-direction:column}
.back{align-self:flex-start;background:none;border:none;color:var(--text-secondary);cursor:pointer;font:inherit;font-size:13.5px;font-weight:500;padding:4px 0;margin-bottom:16px;transition:color .2s}
.back:hover{color:var(--orange)}
.info-hosts{display:flex;align-items:center;margin-bottom:12px}
.av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;background:var(--purple);border:2px solid var(--bg-elevated);object-fit:cover}
.av+.av{margin-left:-10px}
.info-hosts .av:nth-child(1){background:var(--orange);color:#000}
.sched-info h2{font-family:'Playfair Display',serif;font-size:21px;font-weight:600;line-height:1.2;margin-bottom:10px}
.info-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.info-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0 0 18px}
.info-field span{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.select-wrap{position:relative}
.select-wrap::after{content:"▾";position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-dim);font-size:12px}
.info-field select{width:100%;appearance:none;-webkit-appearance:none;padding:10px 30px 10px 12px;background:var(--bg-sunken);color:var(--text);border:1px solid var(--border);border-radius:10px;font:inherit;font-size:14px;font-weight:500;cursor:pointer;outline:none}
.info-field select:focus{border-color:var(--orange)}
.info-tz{font-size:12px;color:var(--text-dim);margin-top:16px;line-height:1.5}

/* calendar */
.sched-cal{border-left:1px solid var(--border);border-right:1px solid var(--border);padding:0 clamp(8px,1.6vw,22px)}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-month{font-size:15px;font-weight:600}
.cal-arrow{width:32px;height:32px;border-radius:9px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);cursor:pointer;font-size:17px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .18s}
.cal-arrow:hover:not(:disabled){border-color:var(--orange);color:var(--orange)}
.cal-arrow:disabled{opacity:.3;cursor:default}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.cal-dow span{text-align:center;font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-earliest{margin-top:12px;padding:9px 12px;background:var(--bg-sunken);border:1px solid var(--border);border-radius:10px;font-size:12.5px;line-height:1.5;color:var(--text-secondary);display:flex;gap:8px;align-items:flex-start}
.cal-earliest .ce-ic{flex-shrink:0;line-height:1.4}
.cal-earliest b{color:var(--text);font-weight:600}
.cal-cell{aspect-ratio:1/1;border:none;background:none;border-radius:10px;font:inherit;font-size:14px;font-weight:500;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:background .15s,color .15s,transform .12s}
.cal-cell.blank{visibility:hidden}
.cal-cell.disabled{color:var(--text-dim);opacity:.4;cursor:default;font-weight:400}
.cal-cell.avail{background:var(--orange-tint);color:var(--text);font-weight:600}
.cal-cell.avail:hover{background:var(--orange);color:#000;transform:scale(1.04)}
.cal-cell.sel{background:var(--orange);color:#000;font-weight:700}
.cal-cell.today::after{content:"";position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.6}

/* times rail */
.sched-times{display:flex;flex-direction:column;min-width:0}
.times-head{font-size:14px;font-weight:600;margin-bottom:12px;min-height:20px;color:var(--text)}
.times-list{display:flex;flex-direction:column;gap:8px;max-height:344px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}
.times-list::-webkit-scrollbar{width:6px}
.times-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:6px}
.times-list::-webkit-scrollbar-track{background:transparent}
.tslot{padding:12px;border:1px solid var(--border-strong);border-radius:11px;background:var(--bg-elevated);color:var(--text);font:inherit;font-size:15px;font-weight:600;cursor:pointer;text-align:center;letter-spacing:.3px;transition:border-color .15s,background .15s,color .15s;animation:slotin .25s var(--ease) backwards}
.tslot:hover{border-color:var(--orange);color:var(--orange)}
.tslot.sel{background:var(--orange);border-color:var(--orange);color:#000}
@keyframes slotin{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.times-empty{color:var(--text-dim);font-size:13.5px;padding:24px 0;text-align:center;line-height:1.6}

/* ---------- details + recap ---------- */
.recap{background:var(--bg-sunken);border:1px solid var(--border);border-radius:14px;padding:6px 16px;margin-bottom:20px}
.recap .row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;font-size:14px;border-bottom:1px solid var(--border)}
.recap .row:last-child{border-bottom:none}
.recap .row span{color:var(--text-secondary)}
.recap .row b{text-align:right;font-weight:600}
.field{display:block;margin-bottom:15px}
.field>span,.field-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}
.field em,.field-label em{font-style:normal;font-weight:400;color:var(--text-dim)}
input[type=text],input[type=email],textarea{width:100%;padding:12px 14px;background:var(--bg-elevated);color:var(--text);border:1px solid var(--border-strong);border-radius:11px;font:inherit;font-size:15px;outline:none;transition:border-color .2s,box-shadow .2s}
input:focus,textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-tint)}
input::placeholder,textarea::placeholder{color:var(--text-dim)}
textarea{resize:vertical;min-height:76px}
.pay-block{margin:4px 0 16px}
.payopts{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.payopt{display:flex;align-items:center;gap:10px;padding:14px;border:1px solid var(--border-strong);border-radius:12px;background:var(--bg-elevated);cursor:pointer;font-weight:600;font-size:14px;transition:border-color .15s,box-shadow .15s}
.payopt:hover{border-color:var(--orange)}
.payopt.sel{border-color:var(--orange);box-shadow:0 0 0 2px var(--orange-tint) inset}
.payopt .ico{font-size:18px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;border-radius:12px;font:inherit;font-size:15px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .18s,color .18s,border-color .18s,opacity .18s,transform .1s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--orange);color:#000}
.btn-primary:hover{background:var(--orange-press)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--border-strong)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.btn-block{width:100%}
.err{color:#c0392b;font-size:13px;margin:0 0 12px;min-height:0}
[data-theme="dark"] .err{color:#ff8b7a}

/* ---------- result / manage ---------- */
.result{text-align:center}
.result-mark{width:60px;height:60px;border-radius:50%;background:var(--orange-tint);color:var(--orange);font-size:30px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.result h2{font-family:'Playfair Display',serif;font-size:24px;font-weight:600;margin-bottom:18px}
.result .recap{text-align:left}
.result-note{font-size:13.5px;color:var(--text-secondary);margin-top:14px;line-height:1.6}
.manage-actions{display:flex;gap:10px;flex-wrap:wrap}

footer{position:relative;z-index:1;text-align:center;color:var(--text-dim);font-size:.72rem;margin-top:24px;padding:14px}

/* ---------- responsive ---------- */
@media(max-width:780px){
  .bk-card.wide{max-width:560px}
  .sched{grid-template-columns:1fr;gap:20px;min-height:0}
  .sched-cal{border-left:none;border-right:none;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
  .times-list{max-height:none;overflow:visible}
  .cal-grid{gap:5px}
}
