@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Playfair+Display:ital,wght@1,700;1,800&family=Bodoni+Moda:ital,wght@1,700;1,800;1,900&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}:root{--sb-bg: #5B21B6;--sb-hover: rgba(255,255,255,.07);--sb-active: rgba(255,255,255,.14);--sb-border: rgba(255,255,255,.09);--sb-label: #C4B5FD;--sb-text: rgba(255,255,255,.62);--sb-text-on: #ffffff;--main-bg: #F0EFFF;--surface: #ffffff;--border: #E5E7EB;--border-focus: #7C3AED;--accent: #7C3AED;--accent-dark: #6D28D9;--accent-light: #EDE9FE;--accent-faint: rgba(124,58,237,.08);--success: #059669;--success-bg: #D1FAE5;--error: #DC2626;--error-bg: #FEE2E2;--error-border: rgba(220,38,38,.2);--text: #1E1B4B;--text-muted: #6B7280;--text-light: #9CA3AF;--shadow-card: 0 1px 4px rgba(0,0,0,.06), 0 6px 20px rgba(124,58,237,.07);--shadow-modal: 0 20px 60px rgba(0,0,0,.25);--shadow-toast: 0 4px 24px rgba(0,0,0,.18)}body{font-family:DM Sans,Segoe UI,system-ui,sans-serif;font-size:14px;color:var(--text);background:var(--main-bg);-webkit-font-smoothing:antialiased}input,select,button{font-family:inherit}input,select{width:100%;padding:9px 11px;border:1.5px solid var(--border);border-radius:7px;font-size:13.5px;color:var(--text);background:var(--surface);outline:none;transition:border-color .14s,box-shadow .14s;-webkit-appearance:none;-moz-appearance:none;appearance:none}input:focus,select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-faint)}input::placeholder{color:#d1d5db}input[type=date]::-webkit-calendar-picker-indicator{opacity:.4;cursor:pointer}@media (max-width: 768px){input,select{font-size:16px;padding:11px 12px;min-height:44px}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;border-radius:50%;animation:spin .55s linear infinite}.spinner-sm{width:15px;height:15px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff}.spinner-md{width:26px;height:26px;border:3px solid rgba(124,58,237,.15);border-top-color:var(--accent)}.state-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 32px;text-align:center;gap:10px}.state-box svg{opacity:.2;color:var(--accent);width:44px;height:44px}.state-box h3{font-size:15px;font-weight:600}.state-box p{font-size:12.5px;color:var(--text-muted);max-width:280px;line-height:1.5}.badge{display:inline-flex;padding:4px 10px;border-radius:6px;font-size:11.5px;font-weight:700;background:var(--accent-light);color:var(--accent);white-space:nowrap;letter-spacing:.01em}.toast{position:fixed;bottom:22px;right:22px;padding:12px 18px;border-radius:10px;font-size:13.5px;font-weight:500;color:#fff;display:flex;align-items:center;gap:9px;box-shadow:var(--shadow-toast);transform:translateY(72px);opacity:0;transition:transform .32s cubic-bezier(.34,1.4,.64,1),opacity .32s ease;z-index:9000;max-width:340px;pointer-events:none}.toast.show{transform:translateY(0);opacity:1;pointer-events:auto}.toast.t-success{background:var(--success)}.toast.t-error{background:var(--error)}.toast svg{flex-shrink:0;width:15px;height:15px}.app{display:flex;height:100dvh;overflow:hidden}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:199}@media (max-width: 768px){.sidebar-overlay{display:block}}.sidebar{width:268px;flex-shrink:0;height:100dvh;background:var(--sb-bg);display:flex;flex-direction:column;transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:200}.sb-close{display:none;position:absolute;top:14px;right:14px;width:30px;height:30px;border:none;background:#ffffff1f;border-radius:6px;cursor:pointer;color:#fff;align-items:center;justify-content:center}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;transform:translate(-100%);box-shadow:4px 0 24px #0000004d}.sidebar.sidebar-open{transform:translate(0)}.sb-logo{position:relative}.sb-close{display:flex}}.sb-logo{padding:32px 24px 28px;border-bottom:1px solid var(--sb-border);flex-shrink:0;display:flex;align-items:center;justify-content:center}.sb-logo img{width:100%;max-width:200px;height:auto;display:block;object-fit:contain;filter:brightness(0) invert(1)}.sb-logo .logo-text{color:#fff;text-align:center}.sb-logo .logo-text .lt-name{font-size:26px;font-weight:700;letter-spacing:.12em}.sb-logo .logo-text .lt-tag{font-size:9px;letter-spacing:.22em;opacity:.45;margin-top:4px}.sb-nav{padding:20px 10px;flex:1}.sb-nav-label{display:block;font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--sb-label);padding:0 10px;margin-bottom:6px}.nav-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;color:var(--sb-text);font-size:13.5px;font-weight:500;cursor:pointer;border-radius:8px;text-align:left;transition:background .14s,color .14s;margin-bottom:2px}.nav-btn:hover{background:var(--sb-hover);color:#ffffffe6}.nav-btn.active{background:var(--sb-active);color:var(--sb-text-on)}.nav-btn svg{width:15px;height:15px;flex-shrink:0;opacity:.7;transition:opacity .14s}.nav-btn.active svg,.nav-btn:hover svg{opacity:1}.sb-logout{padding:10px 10px 4px;flex-shrink:0}.logout-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;color:#ffffff80;font-size:13.5px;font-weight:500;cursor:pointer;border-radius:8px;text-align:left;transition:background .14s,color .14s}.logout-btn svg{width:16px;height:16px;flex-shrink:0;opacity:.6}.logout-btn:hover{background:#ffffff12;color:#ffffffe6}.logout-btn:hover svg{opacity:1}.sb-footer{padding:14px 20px;border-top:1px solid var(--sb-border);font-size:10.5px;color:#ffffff47;flex-shrink:0}.main{flex:1;display:flex;flex-direction:column;height:100dvh;overflow:hidden;min-width:0}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px 0 28px;height:58px;display:flex;align-items:center;gap:12px;flex-shrink:0}.topbar-title{font-size:16px;font-weight:600;line-height:1.2}.topbar-sub{font-size:11.5px;color:var(--text-muted);margin-top:1px}.hamburger{display:none;flex-shrink:0;width:36px;height:36px;border:none;background:transparent;border-radius:8px;cursor:pointer;color:var(--text-muted);align-items:center;justify-content:center;transition:background .13s}.hamburger:hover{background:var(--accent-light);color:var(--accent)}.content{flex:1;overflow-y:auto;padding:28px 32px}@media (max-width: 768px){.hamburger{display:flex}.topbar{padding:0 16px}.topbar-sub{display:none}.content{padding:16px}}.form-card{background:var(--surface);border-radius:14px;padding:28px 32px;box-shadow:var(--shadow-card);max-width:900px;margin:0 auto}.form-step{padding-bottom:24px;margin-bottom:24px}.form-step-last{padding-bottom:0;margin-bottom:20px}.step-header{display:flex;align-items:center;justify-content:center;margin-bottom:14px}.step-header-pill{display:inline-flex;align-items:center;gap:8px;background:var(--accent);padding:6px 18px 6px 8px;border-radius:999px}.step-num{width:22px;height:22px;border-radius:50%;background:#ffffff40;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-title{font-size:14px;font-weight:800;color:#fff;letter-spacing:.02em}.building-pills{display:flex;gap:8px;flex-wrap:wrap}.building-pills--centered{justify-content:center}.building-pill{padding:8px 18px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .13s}.building-pill:hover:not(.active){border-color:var(--accent);color:var(--accent);background:var(--accent-faint)}.building-pill.active{background:#dcfce7;border-color:#86efac;color:#15803d;font-weight:600}.when-grid{display:flex;gap:20px}.when-cal{flex:0 0 auto;width:280px}.when-time{flex:1;min-width:0;display:flex;flex-direction:column;gap:12px}.time-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 16px;border:1.5px dashed var(--border);border-radius:10px;color:var(--text-light);text-align:center}.time-placeholder p{font-size:13px;line-height:1.5}.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px}.details-stack{display:flex;flex-direction:column;gap:16px}.cal-centered{display:flex;justify-content:center}.cal-centered .calendar{width:300px;flex-shrink:0}.fg{display:flex;flex-direction:column;gap:5px}.fg-full{grid-column:1 / -1}textarea{width:100%;padding:9px 11px;border:1.5px solid var(--border);border-radius:7px;font-size:13.5px;color:var(--text);background:var(--surface);outline:none;resize:vertical;font-family:inherit;transition:border-color .14s,box-shadow .14s}textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-faint)}textarea::placeholder{color:#d1d5db}.fg label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);-webkit-user-select:none;user-select:none}.sel-wrap{position:relative}.sel-wrap:after{content:"";position:absolute;right:11px;top:50%;transform:translateY(-50%);border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text-muted);pointer-events:none}.form-alert{display:none;align-items:flex-start;gap:9px;padding:11px 14px;border-radius:8px;font-size:13px;font-weight:500;line-height:1.45}.form-alert.show{display:flex;background:var(--error-bg);color:var(--error);border:1px solid var(--error-border)}.form-alert svg{flex-shrink:0;margin-top:1px}.submit-btn{width:100%;padding:11px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14.5px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .14s,transform .1s}.submit-btn:hover:not(:disabled){background:var(--accent-dark)}.submit-btn:active:not(:disabled){transform:scale(.993)}.submit-btn:disabled{opacity:.58;cursor:not-allowed}@media (max-width: 768px){.form-card{padding:20px 16px;border-radius:12px}.when-grid{flex-direction:column}.when-cal{width:100%}.details-grid,.time-row{grid-template-columns:1fr}.building-pill{font-size:12.5px;padding:7px 14px}}.ev-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px;flex-wrap:wrap}@media (max-width: 768px){.ev-header{margin-bottom:12px}.pill{font-size:11.5px;padding:5px 11px}.refresh-btn{padding:6px 10px;font-size:12px}}.pills{display:flex;gap:6px;flex-wrap:wrap}.pill{padding:6px 14px;border-radius:20px;font-size:12.5px;font-weight:500;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);transition:all .13s}.pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.pill:hover:not(.active){border-color:var(--accent);color:var(--accent)}.refresh-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:7px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:12.5px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .13s}.refresh-btn:hover{border-color:var(--accent);color:var(--accent)}.refresh-btn svg{width:13px;height:13px}.events-container{width:100%}.events-container .state-box{background:var(--surface);border-radius:14px;box-shadow:var(--shadow-card)}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:4px}.event-card{background:var(--surface);border-radius:12px;padding:18px 20px;box-shadow:var(--shadow-sm);border:1px solid var(--border);border-left:4px solid var(--accent);display:flex;flex-direction:column;gap:10px;transition:transform .15s ease,box-shadow .15s ease}.event-card.next-event-card{grid-column:1 / -1;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);border:none;border-left:none;padding:24px 30px;box-shadow:0 10px 30px -8px #6d28d980;color:#fff}.next-event-card .event-card-title{font-size:22px;color:#fff;margin-top:4px}.next-event-card .event-card-date,.next-event-card .event-card-time,.next-event-card .event-card-detail{color:#ffffffe6}.next-event-card .event-card-date{font-size:17px;font-weight:800;color:#fff}.next-event-card .event-card-time{font-size:15px;font-weight:800;background:#ffffff2e;color:#fff;border:1px solid rgba(255,255,255,.28);padding:8px 16px}.next-event-card .event-card-detail svg,.next-event-card .event-card-time svg{color:#ffffffd9}.next-event-card .badge{background:#fff3;color:#fff}.next-event-card .badge.badge-up-next{background:#fff;color:var(--accent);box-shadow:0 2px 8px #0000001a}.next-event-card .event-card-details{border-top:none;margin-top:16px;display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;padding:0;background:transparent}.next-event-card .event-card-detail{background:#ffffff26;padding:10px 16px;border-radius:8px;font-size:14.5px;color:#fff;display:flex;align-items:center;gap:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1)}.next-event-card .event-card-detail svg{width:16px;height:16px;color:#ffffffe6}.next-event-card .event-card-actions{border-top-color:#fff3;margin-top:20px}.next-event-card .edit-btn{background:#ffffff26;border-color:#ffffff40;color:#fff}.next-event-card .edit-btn:hover{background:#fff;color:var(--accent);border-color:#fff}.event-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}.event-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.event-card-date{font-size:16px;color:var(--text);font-weight:800;letter-spacing:-.02em;line-height:1.2;white-space:nowrap}.event-card-title{font-size:15.5px;font-weight:600;color:var(--text-muted);margin:0;line-height:1.4}.event-card-time{display:inline-flex;align-items:center;gap:7px;font-size:14.5px;color:var(--accent);font-weight:700;background:var(--accent-light);padding:7px 13px;border-radius:8px;align-self:flex-start}.event-card-time svg{width:15px;height:15px;flex-shrink:0}.event-card-details{display:flex;flex-direction:column;gap:6px;margin-top:2px;padding-top:12px;border-top:1px solid var(--border)}.event-card-detail{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-muted)}.event-card-detail svg{width:13px;height:13px;color:var(--text-light)}.tel-link{color:var(--accent);text-decoration:none;font-weight:500}.tel-link:hover{text-decoration:underline}.next-event-card .tel-link{color:#ffffffe6}.event-card-actions{display:flex;justify-content:flex-end;border-top:1px solid var(--border);padding-top:12px;margin-top:auto}.edit-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);background:var(--surface);border-radius:6px;font-size:12.5px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.edit-btn svg{width:14px;height:14px}.edit-btn:hover{background:var(--accent-faint);color:var(--accent);border-color:var(--accent)}.calendar{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:14px;-webkit-user-select:none;user-select:none;width:100%}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cal-month-label{font-size:13px;font-weight:600;color:var(--text)}.cal-nav{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:6px;cursor:pointer;color:var(--text-muted);transition:background .12s,color .12s}.cal-nav:hover:not(:disabled){background:var(--accent-light);color:var(--accent)}.cal-nav:disabled{opacity:.3;cursor:not-allowed}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.cal-weekdays span{text-align:center;font-size:10px;font-weight:700;letter-spacing:.05em;color:var(--text-light);padding:4px 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:6px;font-size:12.5px;font-weight:500;color:var(--text);cursor:pointer;transition:background .12s,color .12s;width:100%}.cal-day:hover:not(:disabled):not(.selected){background:var(--accent-light);color:var(--accent)}.cal-day.today:not(.selected){color:var(--accent);font-weight:700}.cal-day.selected{background:#dcfce7;border:1.5px solid #86efac;color:#15803d;font-weight:700}.cal-day.past{color:var(--text-light);cursor:not-allowed;opacity:.5}.slot-grid-wrap{position:relative;flex:1;display:flex;flex-direction:column}.slot-grid-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.sg-legend{display:flex;align-items:center;gap:10px;font-size:10px;font-weight:500;letter-spacing:0;text-transform:none;color:var(--text-muted)}.sg-dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:3px}.sg-dot.free{background:#e5e7eb}.sg-dot.booked{background:#fca5a5}.sg-dot.selected{background:#86efac}.sg-dot.in-range{background:#f0fdf4;border:1.5px solid #86efac}.sg-dot.end{background:#86efac}.slot-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(4,1fr);gap:4px;flex:1}@media (max-width: 768px){.slot-grid{grid-template-columns:repeat(4,1fr);gap:3px}.sg-slot{font-size:9px;padding:5px 2px}}.sg-slot{padding:6px 4px;border:1.5px solid var(--border);border-radius:6px;font-size:9.5px;font-weight:500;line-height:1.3;text-align:center;white-space:pre-line;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.sg-free{background:var(--surface);color:var(--text-muted);border-color:var(--border)}.sg-free:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.sg-booked{background:#fee2e2;color:#ef4444;border-color:#fecaca;cursor:not-allowed;opacity:.75}.sg-past{background:#f3f4f6;color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed;opacity:.6}.sg-start,.sg-end{background:#dcfce7;color:#15803d;border-color:#86efac;font-weight:700}.sg-in-range{background:#f0fdf4;color:#16a34a;border-color:#bbf7d0}.sg-hint{margin-top:8px;font-size:11.5px;color:var(--accent);font-weight:500}.sg-loading{opacity:.4;pointer-events:none}.sg-loader{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:8000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade-in .18s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:16px;width:100%;max-width:460px;box-shadow:var(--shadow-modal);animation:slide-up .22s cubic-bezier(.34,1.3,.64,1);max-height:90vh;overflow-y:auto}@media (max-width: 768px){.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:20px 20px 0 0;max-width:100%;max-height:92vh;animation:slide-up-mobile .28s cubic-bezier(.34,1.2,.64,1)}@keyframes slide-up-mobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.confirm-row{flex-direction:column;gap:2px}.confirm-row dd{text-align:left}}@keyframes slide-up{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:flex-start;gap:14px;padding:22px 24px 18px;border-bottom:1px solid var(--border)}.modal-icon{width:42px;height:42px;flex-shrink:0;background:var(--accent-light);color:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center}.modal-title{font-size:16px;font-weight:700;color:var(--text)}.modal-subtitle{font-size:12.5px;color:var(--text-muted);margin-top:2px}.modal-close{margin-left:auto;flex-shrink:0;width:30px;height:30px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.modal-close:hover{background:var(--error-bg);color:var(--error)}.modal-body{padding:18px 24px}.confirm-list{display:flex;flex-direction:column;gap:0}.confirm-row{display:flex;align-items:baseline;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);gap:16px}.confirm-row:last-child{border-bottom:none}.confirm-row dt{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);flex-shrink:0}.confirm-row dd{font-size:13.5px;font-weight:500;color:var(--text);text-align:right}.modal-footer{display:flex;gap:10px;padding:16px 24px 22px}.modal-cancel{flex:1;padding:10px;border:1.5px solid var(--border);border-radius:8px;background:transparent;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;transition:border-color .12s,color .12s}.modal-cancel:hover:not(:disabled){border-color:var(--text-muted);color:var(--text)}.modal-cancel:disabled{opacity:.5;cursor:not-allowed}.modal-confirm{flex:2;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .12s}.modal-confirm:hover:not(:disabled){background:var(--accent-dark)}.modal-confirm:disabled{opacity:.58;cursor:not-allowed}.login-page{min-height:100dvh;background:var(--main-bg);display:flex;align-items:center;justify-content:center;padding:24px 16px}.login-card{background:var(--surface);border-radius:16px;box-shadow:var(--shadow-modal);padding:40px 36px;width:100%;max-width:400px}.login-logo{display:flex;justify-content:center;margin-bottom:28px}.login-logo img{height:48px;width:auto;object-fit:contain}.login-header{text-align:center;margin-bottom:28px}.login-header h1{font-size:20px;font-weight:700;color:var(--text);margin-bottom:6px}.login-header p{font-size:13px;color:var(--text-muted)}.login-field{margin-bottom:16px}.login-field label{display:block;font-size:12.5px;font-weight:600;color:var(--text);margin-bottom:6px}.login-error{display:flex;align-items:flex-start;gap:8px;background:var(--error-bg);border:1px solid var(--error-border);color:var(--error);border-radius:8px;padding:10px 12px;font-size:12.5px;margin-bottom:16px;line-height:1.4}.login-error svg{flex-shrink:0;margin-top:1px}.login-btn{width:100%;padding:11px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s;margin-top:4px}.login-btn:hover:not(:disabled){background:var(--accent-dark)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-note{text-align:center;font-size:11.5px;color:var(--text-light);margin-top:20px}@media (max-width: 480px){.login-card{padding:32px 24px}}.hero-wrapper{display:flex;flex-direction:column}.hero-nav{width:100%;height:90px;background:#f4f3ff;display:flex;align-items:center;justify-content:space-between;padding:0 48px;flex-shrink:0}.hero-nav-logo{height:160px;width:auto;object-fit:contain}.hero-nav-btn{padding:12px 32px;background:#60f;color:#fff;border:none;border-radius:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:background .18s;flex-shrink:0}.hero-nav-btn:hover{background:#50d}.hero{min-height:calc(100dvh - 90px);background:#f4f3ff;display:flex;flex-direction:column;padding:20px 48px 48px;gap:28px;overflow:hidden}.hero-body{display:grid;grid-template-columns:.6fr 2fr;gap:20px;flex:1}.venues-row{display:flex;flex-direction:column;align-items:center;gap:12px;background:#5b21b6;border:none;border-radius:20px;padding:28px 20px;justify-content:flex-start}.venue-label{font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:700;letter-spacing:.18em;color:#ffffff80;text-transform:uppercase;align-self:center;margin-bottom:0}.venue-hint{font-family:Plus Jakarta Sans,sans-serif;font-size:11px;font-weight:500;color:#fff6;align-self:center;margin-bottom:6px;font-style:italic}.venue-tab{width:100%;padding:14px 18px;border-radius:12px;border:1.5px solid rgba(255,255,255,.2);background:#ffffff14;font-family:Plus Jakarta Sans,sans-serif;cursor:pointer;transition:all .15s;text-align:left;display:flex;flex-direction:column;gap:3px}.venue-tab-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.venue-tab-name{font-size:14px;font-weight:800;color:#ffffffb3}.venue-tab-addr{font-size:11px;font-weight:600;color:#ffffff73;margin-top:2px}.venue-tab-badge{font-size:10px;font-weight:700;letter-spacing:.06em;padding:2px 8px;border-radius:20px;background:#60f;color:#fff;flex-shrink:0}.venue-tab-badge--idle{background:#ffffff26;color:#fff9}.venue-tab.active{background:#fff;border-color:#fff;box-shadow:0 4px 16px #00000026}.venue-tab.active .venue-tab-name{color:#5b21b6;font-weight:800}.venue-tab.active .venue-tab-addr{color:#7c3aed;opacity:.8}.venue-tab.active .venue-tab-badge{background:#5b21b6;color:#fff}.venue-tab:hover:not(.active){background:#ffffff26;border-color:#ffffff59}.venue-tab:hover:not(.active) .venue-tab-name{color:#fff}.photo-area{display:flex;flex-direction:column;gap:12px;flex:1;background:#5b21b6;border:none;border-radius:20px;padding:16px}.map-link{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;background:#ffffff26;border:1.5px solid rgba(255,255,255,.25);border-radius:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:700;color:#fff;text-decoration:none;align-self:center;transition:background .15s}.map-link:hover{background:#ffffff40}.map-link--disabled{opacity:.45;cursor:default;pointer-events:none}.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;flex:1}.photo{border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden;aspect-ratio:380 / 260;min-height:0}.photo span{font-family:Plus Jakarta Sans,sans-serif;font-size:12px;font-weight:600;color:#ffffff80}.photo img{width:100%;height:100%;object-fit:cover;display:block}.photo-1{background:#ffffff2e}.photo-2{background:#ffffff1f}.photo-3{background:#ffffff26}.photo-4{background:#fff3}.hero-heading{margin:0;line-height:1.05;text-align:center}.hero-heading-black{font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(32px,5vw,72px);font-weight:800;color:#0d0d0d}.hero-heading-canvas{font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(32px,5vw,72px);font-weight:800;color:#60f}@media (max-width: 768px){.hero-nav{padding:0 20px;height:68px}.hero-nav-logo{height:80px}.hero-nav-btn{padding:9px 20px;font-size:13px}.hero{min-height:auto;padding:20px 16px 32px;gap:16px}.hero-heading-black,.hero-heading-canvas{font-size:clamp(28px,8vw,48px)}.hero-body{grid-template-columns:1fr;gap:14px}.venues-row{padding:20px 16px;gap:10px;border-radius:16px}.venues-row .venue-label{display:none}.venues-row{flex-direction:column}.venue-tab{padding:12px 14px;flex-direction:row;align-items:center;gap:8px}.venue-tab-name{font-size:13px}.venue-tab-addr{font-size:10px}.photo-area{padding:12px;border-radius:16px}.photo-grid{grid-template-columns:1fr;gap:8px}.photo{aspect-ratio:4 / 3;min-height:unset}}.public-page{min-height:100dvh;background:#f4f3ff;display:flex;flex-direction:column;overflow-y:auto}.section-heading{font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(18px,2.2vw,26px);font-weight:800;color:#0d0d0d;text-align:center;margin:0 auto 40px;letter-spacing:-.02em;display:block;width:fit-content;padding:10px 28px;background:#6600ff14;border:1.5px solid rgba(102,0,255,.15);border-radius:999px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.section-heading-wrap{width:100%}.past-events{padding:72px 0 76px;overflow:hidden}.marquee-wrapper{overflow:hidden;width:100%;cursor:default}.marquee-track{display:flex;gap:18px;width:max-content;animation:marquee-scroll 28s linear infinite}.marquee-wrapper:hover .marquee-track{animation-play-state:paused}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.marquee-photo{width:380px;height:260px;border-radius:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.marquee-photo span{font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:600;color:#60f;opacity:.55}.marquee-photo img{width:100%;height:100%;object-fit:cover;display:block}.mp-1{background:#c4b5fd}.mp-2{background:#ddd6fe}.mp-3{background:#ede9fe}.mp-4{background:#d8b4fe}.mp-5{background:#e9d5ff}.mp-6{background:#f3e8ff}.offerings{padding:72px 48px 80px}.offerings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:900px;margin:0 auto}.offering-right{display:flex;flex-direction:column;gap:20px}.offering-card{background:#5b21b6;border-radius:20px;padding:32px 28px;display:flex;flex-direction:column;gap:20px}.offering-card-title{font-family:Plus Jakarta Sans,sans-serif;font-size:17px;font-weight:800;color:#fff;margin:0;letter-spacing:-.01em}.offering-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}.offering-item{font-family:Plus Jakarta Sans,sans-serif;font-size:14.5px;font-weight:500;color:#ffffffd9;display:flex;align-items:center;gap:10px;line-height:1.4}.offering-dot{width:5px;height:5px;border-radius:50%;background:#ffffff73;flex-shrink:0}.offering-dash{color:#ffffff73;font-weight:700;flex-shrink:0}.offering-card--pricing{gap:24px}.pricing-rows{display:flex;flex-direction:column}.pricing-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0}.pricing-divider{height:1px;background:#ffffff1f}.pricing-day{font-family:Plus Jakarta Sans,sans-serif;font-size:15px;font-weight:600;color:#fffc}.pricing-amount{font-family:Plus Jakarta Sans,sans-serif;font-size:20px;font-weight:800;color:#fff}.pricing-per{font-size:12px;font-weight:500;color:#ffffff8c}.public-main{flex:1;padding:72px 24px 80px;display:flex;flex-direction:column;align-items:center}.booking-section-header{text-align:center;margin-bottom:36px;width:100%;max-width:860px}.booking-section-header .section-heading-wrap{margin-bottom:8px}.booking-section-sub{font-family:Plus Jakarta Sans,sans-serif;font-size:15px;color:#6b7280;margin:0;font-weight:400}.public-main .form-card{width:100%;max-width:860px}.celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:9000;padding:24px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.celebration-card{background:var(--surface);border-radius:20px;padding:40px 36px;max-width:380px;width:100%;text-align:center;box-shadow:var(--shadow-modal);animation:popUp .35s cubic-bezier(.34,1.56,.64,1)}@keyframes popUp{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.celebration-icon{font-size:56px;line-height:1;margin-bottom:16px;animation:bounce .6s ease .2s both}@keyframes bounce{0%{transform:scale(.5) rotate(-10deg)}60%{transform:scale(1.2) rotate(5deg)}to{transform:scale(1) rotate(0)}}.celebration-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:10px}.celebration-msg{font-size:14px;color:var(--text-muted);line-height:1.6;margin-bottom:28px}.celebration-btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:11px 36px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.celebration-btn:hover{background:var(--accent-dark)}@media (max-width: 640px){.offerings{padding:56px 20px 60px}.offerings-grid{grid-template-columns:1fr}.public-main{padding:48px 16px 64px}.past-events{padding:56px 0 60px}}
