:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0d0d0d;color:#f7f2ea;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}html{background:#0d0d0d}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(212,142,48,.16),transparent 30rem),linear-gradient(180deg,#111,#080808)}button,input,textarea{font:inherit}button{cursor:pointer}.app-shell{width:min(100%,460px);min-height:100vh;margin:0 auto;padding:max(18px,env(safe-area-inset-top)) 14px calc(120px + env(safe-area-inset-bottom))}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.studio-kicker{margin:0 0 5px;color:#d7a055;font-size:12px;font-weight:800;letter-spacing:0}h1,h2,p{margin:0}h1{font-size:28px;line-height:1.02;letter-spacing:0}h2{font-size:17px;line-height:1.2}.alert{display:flex;align-items:center;gap:8px;margin-bottom:12px;border-radius:8px;padding:11px 12px;font-size:14px;line-height:1.35}.alert-error{border:1px solid rgba(255,97,97,.3);background:#ff61611a;color:#ffd2d2}.alert-success{border:1px solid rgba(93,255,154,.28);background:#5dff9a1a;color:#d9ffe6}.date-strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:7px;scrollbar-width:none}.date-strip::-webkit-scrollbar{display:none}.date-strip button.selected,.slot-grid button.selected{border-color:#e2a148c7;background:#d8963f;color:#15100a}.panel{margin-bottom:12px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffffed;color:#171717;box-shadow:0 18px 60px #00000038}.section-heading{display:flex;align-items:center;gap:8px;padding:14px 14px 10px;color:#151515}.section-heading svg{color:#b87420}.spin{margin-left:auto;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.service-list{display:grid;gap:8px;padding:0 10px 10px;max-height:440px;overflow-y:auto}.service-group{display:grid;gap:6px;border:1px solid #e8e2d8;border-radius:8px;background:#fff;overflow:hidden}.service-group.selected{border-color:#d8963fc7}.service-group-toggle{display:flex;width:100%;align-items:center;gap:10px;min-height:58px;border:0;padding:12px;background:#fff;color:#151515;text-align:left}.service-group-toggle svg{flex:0 0 auto;color:#9d6a2b;transition:transform .18s ease}.service-group-toggle svg.expanded{transform:rotate(180deg)}.service-group-title{display:grid;min-width:0;gap:3px}.service-group-title small{color:#94611f;font-size:11px;font-weight:800}.service-group-title strong{font-size:15px;line-height:1.2}.service-group-meta{display:grid;flex:0 0 auto;margin-left:auto;gap:3px;text-align:right;white-space:nowrap}.service-group-meta small{color:#8b8176;font-size:11px;font-weight:800}.service-group-meta strong{color:#8d5416;font-size:13px}.service-group-list{display:grid;gap:8px;padding:0 8px 8px}.service-card{display:flex;width:100%;align-items:center;justify-content:space-between;gap:10px;border:1px solid #ece5dc;border-radius:8px;padding:12px;background:#fbfaf8;color:#151515;text-align:left}.service-card.selected{border-color:#c7842b;background:#fff5e7}.service-card strong{display:block;margin-bottom:4px;font-size:15px;line-height:1.2}.service-card small{display:-webkit-box;overflow:hidden;color:#746b60;font-size:12px;line-height:1.28;-webkit-box-orient:vertical;-webkit-line-clamp:2}.service-meta{display:inline-flex;flex:0 0 auto;align-items:center;gap:4px;color:#8d5416;font-size:13px;font-weight:800;white-space:nowrap}.selected-service{display:grid;gap:14px;padding:14px;background:#171717;color:#f7f2ea}.selected-service span{display:block;margin-bottom:6px;color:#d99c4c;font-size:12px;font-weight:800}.selected-service h2{margin-bottom:6px;font-size:20px}.selected-service p{color:#f7f2eac7;font-size:14px;line-height:1.35}.selected-service dl{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0}.selected-service dl div{border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px;background:#ffffff0f}.selected-service dt{color:#f7f2ea99;font-size:11px}.selected-service dd{margin:4px 0 0;font-size:14px;font-weight:800}.slot-grid button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;border:1px solid #e5ded4;border-radius:8px;background:#fff;color:#1c1c1c;font-size:13px;font-weight:800}.date-strip{padding:0 10px 12px}.date-strip button{display:grid;min-width:58px;border:1px solid #e5ded4;border-radius:8px;padding:8px 7px;background:#fff;color:#1c1c1c;text-align:center}.date-strip span,.date-strip small{color:#756d62;font-size:11px;font-weight:700}.date-strip strong{font-size:20px;line-height:1.1}.slot-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:0 10px 12px}.empty-state{grid-column:1 / -1;border:1px dashed #ded5c9;border-radius:8px;padding:16px;color:#786f64;font-size:14px;text-align:center}.booking-form{padding-bottom:0}.booking-form label,.booking-field{display:grid;gap:6px;padding:0 14px 12px;color:#5d544b;font-size:12px;font-weight:800}.field-label{display:block}.booking-form input,.booking-form textarea{width:100%;border:1px solid #e1d9cf;border-radius:8px;outline:0;background:#fff;color:#171717;font-size:15px}.booking-form input{height:44px;padding:0 12px}.booking-form textarea{resize:vertical;padding:10px 12px;line-height:1.35}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:12px;top:14px;color:#a36c2b}.input-with-icon input{padding-left:38px}.contact-request-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:100%;min-height:40px;border:1px solid rgba(216,150,63,.34);border-radius:8px;background:#fff7ea;color:#74430f;font-size:13px;font-weight:900}.contact-request-button:disabled{cursor:progress;opacity:.72}.contact-status{color:#7a7167;font-size:12px;font-weight:700;line-height:1.3}.sticky-submit{position:fixed;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:space-between;gap:12px;width:min(100%,460px);margin:0 auto;border-top:1px solid rgba(255,255,255,.12);padding:12px 14px calc(12px + env(safe-area-inset-bottom));background:#0c0c0ceb;color:#fff;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.sticky-submit div{display:grid;min-width:0}.sticky-submit strong{font-size:15px}.sticky-submit span{overflow:hidden;color:#ffffff9e;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.sticky-submit button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:150px;min-height:46px;border:0;border-radius:8px;background:#d8963f;color:#15100a;font-size:15px;font-weight:900}.sticky-submit button:disabled{cursor:not-allowed;opacity:.48}.booking-success{display:grid;grid-template-columns:auto 1fr;width:100%;align-items:flex-start;gap:10px;border:1px solid rgba(93,255,154,.22);border-radius:8px;padding:12px;background:#5dff9a1a;color:#d9ffe6}.booking-success svg{margin-top:2px;color:#5dff9a}.booking-success strong{color:#f5fff8;font-size:15px}.booking-success span{overflow:visible;margin-top:3px;color:#d9ffe6d1;font-size:13px;line-height:1.35;text-overflow:clip;white-space:normal}@media(max-width:360px){h1{font-size:24px}.slot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sticky-submit{align-items:stretch;flex-direction:column}.sticky-submit button{width:100%}}
