:root{--background: #fde8d8;--background-deep: #f8d5c0;--surface: rgba(255, 255, 255, .75);--surface-strong: rgba(255, 255, 255, .9);--text: #2d1a00;--muted: rgba(45, 26, 0, .6);--link: #7b2fd4;--secondary: #f5b027;--accent: rgb(225, 241, 72);--error: #f54927;--shadow: 0 18px 60px rgba(120, 60, 0, .15);--radius: 24px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{height:100%;background:var(--background-deep);-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;height:100%;color:var(--text);font-family:Quicksand,sans-serif}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:linear-gradient(180deg,var(--background) 0%,var(--background-deep) 100%)}button,input,textarea,a{font:inherit;touch-action:manipulation}button{border:0;cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}a{color:var(--link)}#root{min-height:100vh}.app-shell{position:relative;width:100%;min-height:100vh}.app-shell.is-home{display:flex;flex-direction:column}.app-shell.is-home .app-content{flex:1;display:flex;flex-direction:column}.app-content{width:min(100%,720px);margin:0 auto;padding:0 16px}.app-shell:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;min-height:100vh;z-index:-1;background-image:url(../static/background.png);background-size:cover;background-repeat:no-repeat;background-position:top center}@media (min-width: 781px){.app-shell:before{background-image:url(../static/background-desktop.png)}}.app-shell:not(.is-home):before{opacity:.25;mix-blend-mode:multiply}.app-footer{display:flex;justify-content:center;padding:32px 16px 48px;margin-top:40px}.footer-logo{height:84px;width:auto}.footer-logo-splash{height:320px;margin-top:48px;opacity:.5}.footer-logo-splash:hover{opacity:1}.brand{display:flex;align-items:center;gap:10px;color:#2d1a00b3;margin-bottom:20px;text-decoration:none}.home-logo{height:48px;width:auto;filter:invert(1)}.brand span{font-size:1.4rem;font-weight:700;letter-spacing:-.01em}.screen{display:grid;gap:0}.request-card{background:var(--surface);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid rgba(0,0,0,.1);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.screen-header,.hero-card,.stack-card{padding:24px 0}.panel-card{border-left:3px solid rgba(0,0,0,.15);padding:4px 0 4px 14px}.stack-card{display:flex;flex-direction:column;gap:36px}.hero-card{display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--link)}.hero-card.compact{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}.landing-screen,.host-page-screen,.host-setup-screen{padding-top:0}@keyframes splash-fade-in{0%{opacity:.5}to{opacity:1}}@keyframes content-fade-in{0%{opacity:0}to{opacity:1}}.host-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.host-loading-splash{width:min(80%,400px);height:auto;animation:splash-fade-in 1s ease forwards}.host-page-screen{animation:content-fade-in .25s ease forwards}.home-v2{position:relative;width:100%;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding-top:0}.home-splash{position:relative;z-index:1;width:min(90%,420px);height:auto;margin-bottom:16px}@keyframes cta-bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.1)}}.home-cta{position:relative;z-index:1;background:none;border:none;cursor:pointer;padding:0;display:flex;justify-content:center;align-items:center;animation:cta-bounce 6s ease-in-out infinite}.home-cta img{width:min(60%,280px);height:auto;display:block}.eyebrow,.day-label{text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--text);margin:0 0 10px}.day-label{font-size:1rem;font-weight:700;letter-spacing:.05em}h1,h2,h3{margin:0;font-family:Happy Monkey,cursive}h1{font-size:clamp(2.4rem,5vw,4rem);line-height:1.05}h2{font-size:1.5rem}.lede{margin:14px 0 0;color:var(--muted);font-size:1.25rem;line-height:1.5;max-width:34rem}.inline-note{text-align:center}.lede.small,.support-copy,.panel-card p,.section-heading p,.booking-box p,.inline-note,.request-card p{color:var(--muted);font-weight:600;line-height:1.45;margin:8px 0 0}.action-row,.panel-grid{display:flex;gap:12px;flex-wrap:wrap}.action-row{justify-content:center}.primary-button,.secondary-button,.ghost-button,.ghost-link{min-height:48px;border-radius:999px;padding:0 18px;transition:transform .14s ease,background .14s ease}.primary-button{background:var(--secondary);color:#111;font-weight:700;font-size:1.5rem}.secondary-button{background:#ffffffb3;color:var(--text);border:1px solid rgba(0,0,0,.15);font-weight:600}.auxiliary-button{background:transparent;color:var(--text);opacity:.5;font-weight:500;font-size:1rem;border:none;min-height:36px}.auxiliary-button:hover{opacity:.8}.ghost-button,.ghost-link{background:transparent;color:var(--muted);font-weight:600}.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.ghost-link:hover,.slot-pill:hover,.calendar-card:hover{transform:translateY(-1px)}.small{min-height:42px}.panel-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.panel-card h2{font-size:1.4rem}.availability-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}.day-column{display:grid;gap:8px;background:#ffffff80;padding:10px;border-radius:20px}.slot-pill{display:grid;place-items:center;width:100%;min-height:44px;padding:0;border-radius:16px;background:#ffffff8c;color:var(--muted)}.slot-icon,.badge-icon{width:24px;height:24px;object-fit:contain;filter:brightness(0)}.slot-pill.active{background:var(--accent)}.status-chip.confirmed{background:#0003}.badge.active{background:var(--accent);color:var(--secondary)}.calendar-card.selected{background:var(--secondary)}.calendar-card.selected .badge.active{background:#0003}.field{display:grid;gap:8px}.field.centered{text-align:center;justify-items:center}.field.centered input{text-align:center;width:66%;font-size:1.75rem;font-weight:700}.field span{font-size:.92rem;font-weight:600;color:var(--text)}.field input,.field textarea{width:100%;border:1px solid rgba(0,0,0,.15);border-radius:16px;padding:14px 16px;background:#ffffffb3;color:var(--text)}.field input::placeholder,.field textarea::placeholder{color:#2d1a0066}.section-heading{display:grid;gap:4px;text-align:center}.share-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.share-header h2{margin:0}.share-box{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:18px;background:#fff9}.share-url{flex:1;font-size:.9em;opacity:.7;background:transparent;border:none;outline:none;padding:0;min-width:0;cursor:text}.share-actions{display:flex;gap:8px;flex-shrink:0}.share-instructions{margin-top:12px;font-size:.9em;opacity:.7;text-align:center}.request-list{display:grid;gap:12px;margin-top:12px}.request-head{display:flex;justify-content:space-between;gap:12px;align-items:center}.status-chip{padding:6px 10px;border-radius:999px;background:#00000014;font-size:.82rem}.status-chip.suggested{background:var(--secondary);color:#281600}.status-chip.declined{background:var(--error)}.suggest-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}.field.compact input{padding:12px 14px}.calendar-board{display:grid;gap:10px;overflow-x:auto;padding-bottom:4px}.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.calendar-weekday{text-align:center;font-size:.88rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text)}.calendar-spacer{min-height:120px;border-radius:20px;background:#00000008;border:1px dashed rgba(0,0,0,.1)}.calendar-month-block{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.calendar-month-label{font-size:1.3rem;font-weight:700;margin:0;text-align:center}.expand-calendar-button{width:100%;padding:16px;border-radius:999px;background:var(--secondary);border:none;color:#281600;font-size:1.2rem;font-weight:700;cursor:pointer;transition:transform .14s ease,background .14s ease}.expand-calendar-button:hover{transform:translateY(-1px);background:var(--secondary)}.calendar-card{position:relative;display:grid;align-content:space-between;padding:8px;border-radius:20px;color:var(--text);background:#ffffffa6;min-height:120px;text-align:left}.calendar-card.closed{opacity:.45}.calendar-card-head{display:grid;gap:2px}.calendar-card strong,.calendar-card span,.month-chip{display:block}.calendar-card strong{font-size:1.8rem;line-height:1}.month-chip{position:absolute;top:8px;right:8px;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--secondary)}.slot-badges{display:flex;flex-direction:column;gap:4px;margin-top:12px}.badge{display:flex;align-items:center;justify-content:center;width:100%;height:30px;border-radius:999px;background:#0000000f;color:var(--muted)}.badge-icon{width:18px;height:18px}.booking-panel{position:fixed;bottom:0;left:0;right:0;background:var(--background-deep);border-top:1px solid rgba(0,0,0,.1);padding:20px 24px;z-index:100;transform:translateY(100%);transition:transform .25s ease}.booking-panel.visible{transform:translateY(0)}.has-booking-panel{padding-bottom:140px}.booking-box{display:grid;gap:14px;max-width:800px;margin:0 auto;text-align:center}.screen-header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px}.setup-share-url{margin:4px 0 0;font-size:.78rem;color:var(--muted);word-break:break-all}.screen-header-row{display:flex;align-items:center;justify-content:center;gap:12px;color:var(--link)}.icon-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:#ffffffb3;color:var(--text);flex-shrink:0}.icon-button:hover{color:var(--link)}@keyframes copy-flash{0%{transform:scale(1)}30%{transform:scale(1.12);background:var(--secondary);color:#fff;border-color:transparent}to{transform:scale(1)}}.btn-copied{animation:copy-flash .55s ease forwards}.edit-fab{position:fixed;top:16px;right:16px;z-index:100;box-shadow:0 2px 8px #00000026}.mobile-only{display:none}@media (max-width: 780px){.mobile-only{display:flex}}.empty-state{place-items:center;text-align:center;padding-top:80px}@media (max-width: 780px){.panel-grid,.availability-grid,.suggest-grid,.hero-card.compact,.share-box{grid-template-columns:1fr;flex-direction:column}.availability-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.availability-grid .day-column:nth-child(-n+3){grid-column:span 2}.availability-grid .day-column:nth-child(n+4){grid-column:span 3}.calendar-weekdays{display:grid;gap:3px}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:3px}.calendar-card{padding:4px;min-height:80px;border-radius:10px}.calendar-card strong{font-size:1rem}.calendar-card span{display:none}.month-chip{font-size:.55rem;top:4px;right:4px}.badge{height:18px;font-size:.6rem}.badge-icon{display:flex}.slot-badges{gap:2px;margin-top:6px}.calendar-spacer{min-height:80px;border-radius:10px;background:#00000008;border:1px dashed rgba(0,0,0,.1)}.share-box{display:grid}}
