:root{color-scheme:light;--bg: #f5f5f7;--surface: rgba(255, 255, 255, .88);--surface-strong: #ffffff;--surface-muted: #f7f7fa;--ink: #111111;--muted: #6e6e73;--line: rgba(17, 17, 17, .08);--primary: #1d1d1f;--accent: #0066cc;--shadow: 0 24px 60px rgba(17, 17, 17, .08);font-family:PingFang SC,SF Pro Display,Helvetica Neue,sans-serif}*{box-sizing:border-box}body{margin:0;color:var(--ink);background:radial-gradient(circle at top,rgba(255,255,255,.95),transparent 40%),linear-gradient(180deg,#fafafa 0%,var(--bg) 100%)}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.shell{min-height:100vh;padding:clamp(16px,2vw,28px)}.publicPage,.panel{max-width:1240px;margin:0 auto}.topbar{width:min(100%,1240px);display:flex;justify-content:space-between;align-items:end;gap:24px;margin:0 auto 20px}.shellAdmin .topbar,.shellAdmin .adminLayout{width:min(100%,1720px);max-width:none;margin-left:auto;margin-right:auto}.shellAdmin .topbar{align-items:flex-start}.topbarAdmin{margin-bottom:20px}.brandBlock h1,.noticePanel h2,.heroPlain h2,.formPanel h2,.detailHeader h2,.adminPanel h2,.adminLogin h2{margin:0;font-family:SF Pro Display,PingFang SC,sans-serif;font-size:clamp(32px,4vw,50px);font-weight:600;line-height:1.05;letter-spacing:0}.formPanel h2,.detailHeader h2,.adminPanel h2,.adminLogin h2{font-size:28px}.eyebrow{margin:0 0 8px;color:var(--muted);font-size:13px;letter-spacing:0}.nav{display:flex;gap:12px;flex-wrap:wrap}.navButton,.ghostButton,.primaryButton,.linkButton{border-radius:999px;border:1px solid var(--line);padding:10px 16px;background:#ffffffb8;color:var(--ink);text-decoration:none}.navButton.active,.primaryButton{background:var(--primary);color:#fff;border-color:transparent}.primaryButton:disabled{background:#c7c7cc;color:#fff;border-color:transparent;box-shadow:none}.ghostButton:disabled,.linkButton:disabled,.navButton:disabled{opacity:.55}.ghostButton,.linkButton{background:transparent}.publicPage,.adminLayout{display:grid;gap:20px}.bookingSection,.aboutSection,.noticePanel,.formPanel,.detailPanel,.paymentPanel,.roomList,.adminPanel,.adminLogin,.noticeStrip,.heroPlain{border:1px solid var(--line);border-radius:24px;background:var(--surface);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.bookingSection,.aboutSection,.noticePanel,.formPanel,.detailPanel,.paymentPanel,.roomList,.adminPanel,.adminLogin,.heroPlain{padding:24px}.noticeStrip{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;padding:16px}.noticeCard,.notificationCard,.roommateCard,.duplicateCard,.roomCard,.roomAdminCard,.imageChip,.summaryBlock,.aboutCard{border:1px solid var(--line);border-radius:20px;background:var(--surface-strong)}.noticeCard,.notificationCard,.roommateCard,.duplicateCard,.roomAdminCard,.summaryBlock{padding:16px}.imageChip{display:grid;gap:8px;padding:8px}.noticeCard strong,.notificationCard strong,.duplicateItem strong,.roomCard h2,.roomAdminCard h3,.aboutCard strong{display:block}.noticeCard p,.notificationCard p,.notificationCard span,.noticeMeta,.hintText,.errorText,.roomCard p,.roomCard span,.roomAdminCard p,.roomAdminCard span,.detailHeader p,.heroPlain p,.duplicateItem span{margin:0;color:var(--muted)}.noticeLinkCard{width:100%;padding:16px;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:18px}.noticeLinkMain{min-width:0;flex:1;display:grid;gap:8px}.noticeLinkCard strong{font-size:24px;line-height:1.1;color:var(--text)}.noticeLinkCard.active{border-color:#0066cc47;box-shadow:0 0 0 3px #0066cc14}.noticeLinkAction{flex:0 0 auto;min-width:120px;padding:12px 18px;border-radius:999px;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:600;line-height:1;text-align:center;white-space:nowrap;box-shadow:0 12px 28px #1111111f}.noticeLinkActionLabel{color:inherit}.noticeLinkActionIcon{width:24px;height:24px;border-radius:999px;background:#ffffff2e;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:18px;line-height:1}.noticeLinkCard.active .noticeLinkAction{background:var(--accent)}.noticeStripSingle{grid-template-columns:1fr}.noticePanel{display:grid;gap:14px}.noticeContent,.historyNoticeCard{display:grid;gap:8px}.noticeMeta{font-size:13px}.bookingGrid{display:grid;grid-template-columns:300px minmax(0,1fr) 360px;gap:20px;align-items:start;margin-top:20px}.roomList{display:grid;gap:12px}.roomCard{text-align:left;padding:16px}.roomCard p{margin:0 0 4px}.roomCard span{font-size:14px;line-height:1.5}.roomCard.active{border-color:#0066cc47;box-shadow:0 0 0 3px #0066cc14}.roomCard h2,.roomAdminCard h3{margin:0 0 6px;font-size:20px}.detailPanel{display:grid;gap:16px}.detailHero,.aboutMedia{aspect-ratio:16 / 10;border-radius:20px;overflow:hidden;background:linear-gradient(135deg,#0066cc14,#0000000a)}.detailHero{position:relative}.detailHero img,.thumbRow img,.imageChip img,.aboutMedia img,.qrImage{width:100%;height:100%;object-fit:cover;display:block}.imageFallback{height:100%;display:grid;place-items:center;padding:24px;text-align:center;color:var(--muted)}.detailHeader{display:flex;justify-content:space-between;gap:18px}.detailHeader strong{font-size:26px;white-space:nowrap}.detailCarousel{display:grid;gap:12px}.detailCarouselTrack{display:flex;height:100%;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none}.detailCarouselTrack::-webkit-scrollbar,.detailThumbRow::-webkit-scrollbar{display:none}.detailCarouselSlide{min-width:100%;height:100%;scroll-snap-align:start}.detailImageButton{width:100%;height:100%;padding:0;border:0;background:transparent;display:block}.detailCarouselFooter,.detailCarouselMeta{display:grid;gap:12px}.detailCarouselMeta{gap:6px}.detailCarouselMeta p,.detailCarouselCount{margin:0}.detailCarouselCount{color:var(--muted);font-size:13px}.detailCarouselMeta p{color:var(--muted)}.detailThumbRow{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(88px,112px);gap:10px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.detailThumbButton{aspect-ratio:4 / 3;border-radius:16px;overflow:hidden;border:1px solid var(--line);padding:0;background:var(--surface-strong)}.detailThumbButton img{width:100%;height:100%;object-fit:cover;display:block}.detailThumbButton.active{border-color:#0066cc47;box-shadow:0 0 0 3px #0066cc14}.carouselNavButton{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.4);background:#1116;color:#fff;font-size:24px;line-height:1}.carouselNavButton:disabled{opacity:.35}.carouselNavPrev{left:14px}.carouselNavNext{right:14px}.roomImageCard,.roomImageEditorCard{display:grid;gap:10px}.roomImageCard{border:1px solid var(--line);border-radius:20px;background:var(--surface-strong);overflow:hidden;padding:12px}.roomImageEditorCard{border:1px solid var(--line);border-radius:20px;background:var(--surface-strong)}.roomImageMedia,.roomImageEditorPreview{aspect-ratio:4 / 3;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#0066cc14,#0000000a)}.roomImageMedia img,.roomImageEditorPreview img{width:100%;height:100%;object-fit:cover;display:block}.roomImageDescription{margin:0;color:var(--muted);font-size:14px;line-height:1.6}.thumbRow,.imageList,.aboutGallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px}.aboutTabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:20px}.aboutSelectRow{display:flex;justify-content:flex-start}.aboutSelectField{width:min(100%,360px);display:grid;gap:8px}.aboutSelectField span{color:var(--muted);font-size:13px}.aboutSelectField select{width:100%;border:1px solid var(--line);border-radius:16px;background:var(--surface-muted);color:var(--ink);padding:12px 14px}.aboutTabButton{border:1px solid var(--line);border-radius:999px;padding:12px 16px;background:var(--surface-strong);color:var(--ink);font-size:14px;font-weight:600;text-align:center}.aboutTabButton.active{border-color:#0066cc47;box-shadow:0 0 0 3px #0066cc14;background:#0066cc14}.aboutCarousel{display:grid;gap:12px;margin-top:20px}.aboutActions{display:flex;justify-content:flex-start;margin-top:20px}.aboutBackButton{width:min(100%,420px);min-height:52px;justify-content:center}.thumbRow img,.imageChip img{aspect-ratio:1;border-radius:16px}.miniPreview{width:180px;height:180px;flex:0 0 180px;border-radius:16px;overflow:hidden}.roomImageEditorList{display:grid;gap:12px}.aboutSectionEditorList{display:grid;gap:14px}.aboutEditorCollapsedState{margin-top:14px;padding:16px 18px;border:1px solid var(--line);border-radius:18px;background:var(--surface-muted)}.aboutSectionEditorCard{display:grid;gap:14px;border:1px solid var(--line);border-radius:20px;background:var(--surface-strong);padding:16px}.aboutSectionEditorHeader{align-items:flex-start}.aboutSectionEditorHeading{display:grid;gap:4px}.aboutSectionEditorCard .imageList{grid-template-columns:repeat(auto-fill,minmax(82px,82px));gap:10px}.aboutSectionEditorCard .imageChip{border-radius:16px;padding:6px;gap:6px}.aboutSectionEditorCard .imageChip img{width:100%;aspect-ratio:1;border-radius:12px;object-fit:cover}.aboutSectionEditorCard .imageChip button{padding:6px 0;font-size:12px;line-height:1}.roomImageEditorCard{padding:12px}.formPanel,.paymentPanel,.adminLogin{position:sticky;top:20px}.bookingForm{display:grid;gap:14px}.bookingForm label{display:grid;gap:8px;font-size:14px}.bookingForm input,.bookingForm textarea,.bookingForm select{width:100%;border:1px solid var(--line);border-radius:16px;background:var(--surface-muted);color:var(--ink);padding:12px 14px}.inlineLabel{grid-auto-flow:column;justify-content:start;align-items:center}.actionRow,.uploadRow,.sectionHeader,.filterRow,.statusButtons,.sectionLabel{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.aboutSectionHeader{width:100%;align-items:flex-start}.aboutSectionBackButton{margin-left:auto;font-weight:700;white-space:nowrap}.adminHeaderActions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.tableModeActions{justify-content:flex-end}.tableModeSwitch{display:flex;gap:8px;flex-wrap:wrap}.sectionLabel{justify-content:space-between}.uploadHintInline{color:var(--muted);font-size:13px}.filterRow input,.filterRow select{border:1px solid var(--line);border-radius:16px;background:var(--surface-muted);color:var(--ink);padding:10px 14px}.filterRow input{min-width:min(100%,320px);flex:1 1 280px}.bookingSummaryPanel{display:grid;gap:12px;margin:16px 0}.bookingSummaryTotalCard,.bookingStatCard{border:1px solid var(--line);border-radius:18px;background:var(--surface-muted);padding:16px 18px}.bookingSummaryTotalCard{background:var(--surface-strong)}.bookingSummaryLabel{color:var(--muted);font-size:13px}.bookingSummaryValue{font-size:30px;line-height:1.1}.bookingStatsGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.bookingStatCard,.bookingStatMeta{display:grid;gap:6px}.bookingStatCard strong{font-size:15px;line-height:1.5}.bookingStatMeta{color:var(--muted);font-size:13px}.roommateGrid,.duplicateGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.bookingCountdown{display:grid;gap:4px;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:var(--surface-muted)}.bookingCountdown strong{font-size:16px;line-height:1.4}.bookingCountdown span{color:var(--muted);font-size:13px}.preBookingActionBlock{display:grid;gap:8px}.preBookingButton{justify-self:start}.summaryBlock,.personList,.duplicateItem{display:grid;gap:4px}.personCard{border:1px solid var(--line);border-radius:16px;background:var(--surface-strong);padding:10px 12px}.personExpandButton{width:100%;border:1px solid var(--line);border-radius:16px;background:var(--surface-strong);padding:10px 12px;text-align:left}.personExpandButton.active{border-color:#0066cc47;box-shadow:0 0 0 3px #0066cc14}.personExpandHint{margin-top:4px;color:var(--accent);font-size:13px}.bookingRowExpanded td{border-bottom-color:transparent}.roommateTableRow td{background:var(--surface-muted)}.roommatePersonCard{background:var(--surface)}.roommateRowTitle{color:var(--accent);font-weight:600}.paymentPanel{margin-top:20px}.qrImage{max-width:260px;border-radius:20px;margin-top:14px}.heroPlain{padding:28px}.heroPlain p:last-child{max-width:760px;line-height:1.7}.aboutGallery{margin-top:20px}.aboutCard{overflow:hidden}.notificationList,.roomAdminList,.duplicateList{display:grid;gap:12px;margin-top:16px}.notificationCard,.roomAdminCard{display:flex;justify-content:space-between;gap:14px;align-items:center}.adminModalOverlay{position:fixed;inset:0;background:#11111147;display:grid;place-items:center;padding:24px;z-index:40}.adminModalCard{width:min(100%,560px);border:1px solid var(--line);border-radius:24px;background:var(--surface-strong);box-shadow:var(--shadow);padding:24px;display:grid;gap:16px}.duplicateModalCard{width:min(100%,920px);max-height:min(80vh,900px);overflow-y:auto}.bookingResultModalCard{width:min(100%,720px);max-height:min(85vh,900px);overflow-y:auto}.adminLayout{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.shellAdmin .adminLayout{grid-template-columns:minmax(340px,500px) minmax(0,1fr)}.adminPanel.wide{grid-column:1 / -1}.adminLogin{width:min(100%,560px)}.tableWrap{overflow-x:auto}table{width:100%;min-width:860px;border-collapse:collapse}th,td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);vertical-align:top}.panel{margin-top:20vh}.errorText{color:#c9342f}.successText{color:#247a45}.lightboxOverlay{position:fixed;inset:0;z-index:40;background:#000000eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.lightboxCard{position:relative;width:100vw;height:100vh;background:transparent}.lightboxHeader,.lightboxTitleBlock{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap}.lightboxHeader{position:absolute;inset:0 0 auto;z-index:3;padding:18px 20px;color:#fff;background:linear-gradient(180deg,#000000b3,#0000)}.lightboxTitleBlock{justify-content:flex-start}.lightboxTitleBlock strong,.lightboxTitleBlock .noticeMeta{color:#fff}.lightboxCloseButton{border:1px solid rgba(255,255,255,.24);border-radius:999px;background:#0000005c;color:#fff;padding:10px 18px;font-size:14px;font-weight:600;line-height:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightboxMedia{position:relative;width:100vw;height:100vh;overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center}.lightboxMedia img{width:100vw;height:100vh;object-fit:contain;display:block}@media(max-width:1080px){.bookingGrid,.adminLayout{grid-template-columns:1fr}.shellAdmin .topbar,.shellAdmin .adminLayout{width:100%}.shellAdmin .adminLayout{grid-template-columns:1fr}.roomList{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;padding:10px}.roomCard{padding:10px 12px;border-radius:16px}.roomCard h2{margin-bottom:4px;font-size:16px}.roomCard p,.roomCard span{font-size:12px;line-height:1.35}.formPanel,.paymentPanel,.adminLogin{position:static}}@media(max-width:720px){.shell{padding:16px}.topbar,.detailHeader,.notificationCard,.roomAdminCard,.adminModalCard .sectionHeader{flex-direction:column;align-items:stretch}.nav{width:100%;display:grid;grid-template-columns:1fr}.roomList,.roommateGrid,.duplicateGrid{grid-template-columns:1fr}.carouselNavButton{width:36px;height:36px}.noticeLinkCard{flex-direction:column;align-items:stretch}.noticeLinkAction{width:100%}.lightboxOverlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lightboxCard{width:100vw;height:100vh}table{min-width:720px}}
