:root{color-scheme:light;font-family:Manrope,Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{background:radial-gradient(circle at 20% 20%,#f8f6ef,#ece9df 45%,#e2e0d8);color:#172028}h1,h2,h3{font-family:Cormorant Garamond,"Noto Serif SC",serif;letter-spacing:.02em;margin:0}p{margin:0}.primary-btn,.ghost-btn,.controls-grid button{border:0;border-radius:999px;font-family:inherit;font-size:14px;font-weight:600;line-height:1;cursor:pointer;transition:transform .2s ease,opacity .2s ease,background-color .2s ease}.primary-btn:hover,.ghost-btn:hover,.controls-grid button:hover{transform:translateY(-1px)}.primary-btn:disabled,.ghost-btn:disabled,.controls-grid button:disabled{opacity:.5;cursor:not-allowed;transform:none}.intro-page{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 80% 20%,rgba(247,221,177,.45),transparent 45%),radial-gradient(circle at 20% 80%,rgba(205,230,255,.45),transparent 42%),linear-gradient(140deg,#f6f4ef,#e7e4da)}.intro-card{max-width:760px;padding:40px;border-radius:24px;background:#fafaf8d1;box-shadow:0 28px 80px #2c2b231f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.intro-eyebrow{margin-bottom:12px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#5b6675}.intro-card h1{font-size:clamp(34px,6vw,56px);margin-bottom:16px}.intro-card p{max-width:58ch;font-size:16px;line-height:1.7;color:#2e3a46}.primary-btn{margin-top:24px;padding:14px 22px;background:linear-gradient(120deg,#1f3746,#2b5367);color:#f3f6fb}.gallery-page{position:relative;width:100%;height:100%;overflow:hidden}.gallery-canvas{position:absolute!important;top:0;right:0;bottom:0;left:0}.ui-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:space-between;padding:18px;pointer-events:none}.overlay-top,.overlay-bottom{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.overlay-bottom{align-items:flex-end}.ghost-btn,.controls-panel,.info-panel,.modal-card,.status-chip{pointer-events:auto}.ghost-btn{padding:10px 16px;background:#ffffffd1;color:#2d3a42}.status-chip{padding:10px 14px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.06em;color:#2f3f4a;background:#ffffffd6}.controls-panel,.info-panel{width:min(360px,calc(100vw - 36px));padding:16px;border-radius:20px;background:#ffffffd1;box-shadow:0 12px 30px #1e1e181f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.panel-title{margin-bottom:10px;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#566273;font-weight:700}.controls-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.controls-grid button{padding:12px;background:#f0eee7;color:#1e2933}.panel-hint,.panel-state,.artist-name{margin-top:10px;font-size:13px;color:#4a5865}.panel-state{font-weight:600}.info-panel{opacity:.72;transform:translateY(6px);transition:opacity .25s ease,transform .25s ease}.info-panel.visible{opacity:1;transform:translateY(0)}.info-panel h3{margin-bottom:4px;font-size:30px}.info-panel p{line-height:1.6;color:#27333e}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#090e12b3;z-index:12}.modal-card{width:min(920px,calc(100vw - 32px));max-height:calc(100vh - 32px);overflow:auto;border-radius:20px;background:#fbfaf6;box-shadow:0 28px 90px #0a0c0e66;position:relative}.modal-card img{display:block;width:100%;max-height:62vh;object-fit:cover}.modal-content{padding:18px 20px 24px}.modal-content h3{font-size:38px}.modal-content p{line-height:1.75;color:#27323c}.modal-artist{margin:6px 0 10px;font-weight:600}.modal-close{position:absolute;top:10px;right:10px;width:32px;height:32px;border:0;border-radius:50%;background:#ffffffe6;font-size:22px;line-height:1;cursor:pointer}@media (max-width: 780px){.ui-overlay{padding:12px}.overlay-bottom{flex-direction:column-reverse;align-items:stretch}.controls-panel,.info-panel{width:100%}.intro-card{padding:26px;border-radius:18px}.modal-content h3{font-size:30px}}
