:root{color:#172f2a;background:#f7f1e4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f7f1e4}button,input,select{font:inherit}button{cursor:pointer}.auth-page{min-height:100vh;display:grid;place-items:center;padding:22px;background:linear-gradient(180deg,#12362f4d,#12362fb8),url(/site-map.jpg) center / cover}.auth-card{width:min(100%,420px);display:grid;gap:14px;border:1px solid rgba(255,255,255,.28);border-radius:8px;padding:22px;background:#fffaf0f2;box-shadow:0 24px 70px #0000003d}.brand-lockup{display:grid;gap:8px;margin-bottom:6px}.brand-lockup span,.page-title p,.app-top p{color:#b4472a;font-size:.75rem;font-weight:900;letter-spacing:0;margin:0;text-transform:uppercase}.brand-lockup h1,.page-title h1,.app-top h1{margin:0;color:#12362f;font-size:2.1rem;line-height:1.05}.brand-lockup.compact h1{font-size:1.8rem}.brand-lockup p,.state-panel p,.empty-copy{margin:0;color:#5f736a;line-height:1.45}.mobile-app{width:min(100%,860px);min-height:100vh;margin:0 auto;padding-bottom:82px}.app-top{position:sticky;top:0;z-index:5;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding:16px 14px 12px;border-bottom:1px solid rgba(18,54,47,.1);background:#f7f1e4f0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.app-top h1{font-size:1.35rem}.app-top span{flex:0 0 auto;color:#426158;font-size:.78rem;font-weight:800}.app-main{display:grid;gap:14px;padding:14px}.page-title{display:grid;gap:3px;margin-bottom:12px}.page-title h1{font-size:2rem}.primary-button,.secondary-button,.link-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border-radius:8px;padding:0 14px;font-weight:900}.primary-button{border:0;color:#fffaf0;background:#b4472a}.secondary-button{border:1px solid rgba(18,54,47,.16);color:#17322c;background:#fff}.link-button{min-height:34px;border:0;padding:0;color:#b4472a;background:transparent;text-decoration:underline;text-underline-offset:3px}.link-button.small{color:#2867a8;font-size:.86rem}.link-button.danger{color:#9d2b20}.full{width:100%}.split-actions,.inline-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.field{display:grid;gap:6px}.field span{color:#294f45;font-weight:850}.field input,.admin-row input,.admin-row select{width:100%;min-height:44px;border:1px solid rgba(18,54,47,.18);border-radius:8px;padding:0 12px;color:#17322c;background:#fff}.field small{color:#6a7f76;font-size:.78rem}.form-error,.notice{margin:0;border-radius:8px;padding:10px 12px;color:#8d2d1f;background:#fff1ec;font-size:.9rem;font-weight:800}.notice{color:#255b4f;background:#e4f2e1}.compact-notice{margin:8px 0;font-size:.84rem}.tabbar{position:fixed;right:0;bottom:0;left:0;z-index:10;display:grid;grid-template-columns:repeat(5,1fr);gap:2px;padding:8px 8px calc(8px + env(safe-area-inset-bottom));border-top:1px solid rgba(18,54,47,.14);background:#fffaf0f7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.tabbar button{display:grid;place-items:center;gap:3px;min-width:0;min-height:52px;border:0;border-radius:8px;color:#59736a;background:transparent;font-size:.68rem;font-weight:850}.tabbar button.active{color:#12362f;background:#dcebd4}.search-row,.lineup-tools,.horizontal-selector,.day-selector{display:flex;align-items:center;gap:8px;overflow-x:auto;padding-bottom:2px}.horizontal-selector span,.day-selector span{flex:0 0 auto;color:#426158;font-size:.86rem;font-weight:900}.search-input{display:flex;align-items:center;gap:8px;width:100%;min-height:44px;border:1px solid rgba(18,54,47,.15);border-radius:8px;padding:0 12px;background:#fff}.search-input input{width:100%;min-width:0;border:0;outline:0}.chip,.horizontal-selector button,.day-selector button,.filter-pills button{flex:0 0 auto;min-height:38px;border:1px solid rgba(18,54,47,.14);border-radius:999px;padding:0 12px;color:#294f45;background:#fff;font-weight:850}.chip{display:inline-flex;align-items:center;gap:6px}.chip.selected,.horizontal-selector button.active,.day-selector button.active,.filter-pills button.selected{color:#12362f;border-color:#b4472a73;background:#f5d9c8}.count-label,.section-label{margin:12px 0 8px;color:#426158;font-weight:900}.card-list,.time-list,.group-list,.admin-table{display:grid;gap:12px}.lineup-card,.form-card,.group-card,.profile-card,.state-panel,.stage-panel,.time-card,.admin-row{border:1px solid rgba(18,54,47,.12);border-radius:8px;background:#ffffffdb;box-shadow:0 12px 28px #31483514}.lineup-card{overflow:hidden;cursor:pointer}.artist-picture{height:176px;background:linear-gradient(135deg,#12362f,#b4472a)}.artist-picture img{width:100%;height:100%;object-fit:cover;display:block}.artist-picture span{display:grid;place-items:center;height:100%;color:#fff;font-size:4rem;font-weight:950}.artist-card-copy,.form-card,.group-card,.profile-card,.state-panel,.stage-panel{display:grid;gap:10px;padding:13px}.artist-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.artist-row h2,.form-card h2,.stage-panel h2,.state-panel h2{margin:0;color:#12362f;font-size:1.2rem;line-height:1.12}.heart-button,.icon-only{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;flex:0 0 40px;border:1px solid rgba(18,54,47,.12);border-radius:999px;color:#17322c;background:#fff}.heart-button.saved{color:#b4472a}.heart-button.saving{opacity:.62}.set-meta,.location-line,.bio-line,.time-card small,.group-card small,.mini-artist-row span{margin:0;color:#567168;line-height:1.42}.set-meta{color:#294f45;font-weight:850}.bio-line{max-height:6.2rem;overflow:hidden}.detail-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;overflow:auto;background:#f7f1e4}.detail-topbar{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid rgba(18,54,47,.12);background:#fffaf0f5;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.detail-hero{height:260px;background:linear-gradient(135deg,#12362f,#b4472a)}.detail-hero img{width:100%;height:100%;object-fit:cover;display:block}.detail-hero span{display:grid;place-items:center;height:100%;color:#fff;font-size:5rem;font-weight:950}.detail-body{display:grid;gap:12px;width:min(100%,720px);margin:0 auto;padding:16px 14px 28px}.detail-body h1{margin:0;color:#12362f;font-size:2rem;line-height:1.05}.full-bio{margin:0;color:#405f55;line-height:1.58}.saved-action{background:#8f3a28}.tag-wrap{display:flex;flex-wrap:wrap;gap:6px}.tag-wrap span{border-radius:999px;padding:5px 9px;color:#12362f;background:#dcebd4;font-size:.78rem;font-weight:850}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:flex-end;background:#12201d73}.drawer{width:100%;max-height:86vh;overflow:auto;display:grid;gap:16px;border-radius:8px 8px 0 0;padding:16px;background:#fffaf0}.drawer-head{display:flex;justify-content:space-between;align-items:center}.drawer-head h2,.filter-section h3{margin:0;color:#12362f}.filter-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.genre-filter-list{display:grid;gap:8px;margin-top:8px}.genre-filter-group{display:grid;gap:6px}.genre-filter-row{display:grid;grid-template-columns:1fr auto;gap:8px}.genre-filter-row button{min-height:38px;border:1px solid rgba(18,54,47,.14);border-radius:999px;padding:0 12px;color:#294f45;background:#fff;font-weight:850}.genre-filter-row button.selected{color:#12362f;border-color:#b4472a73;background:#f5d9c8}.genre-filter-row .expand-filter{color:#2867a8;font-size:.78rem}.subgenre-pills{margin-top:0;padding-left:8px}.drawer-actions{position:sticky;bottom:0;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-top:8px;background:#fffaf0}.time-card{display:grid;gap:4px;padding:12px;border-left:5px solid #7aa66a}.time-card span{color:#b4472a;font-weight:900}.time-card strong{color:#12362f}.time-card.clash{border-left-color:#d16b39;background:#fff7ed}.time-card em{color:#9d2b20;font-size:.82rem;font-style:normal;font-weight:850}.group-card strong,.profile-card strong{color:#12362f;font-size:1.05rem}.group-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.group-title-row strong{min-width:0;overflow-wrap:anywhere}.compact-button{min-height:34px;padding:0 10px;font-size:.82rem}.edit-group-name{display:grid;gap:10px}.group-card span{width:fit-content;border-radius:999px;padding:5px 9px;color:#12362f;background:#f4d35e;font-weight:900}.map-frame{position:relative;overflow:auto;border:1px solid rgba(18,54,47,.14);border-radius:8px;background:#dcebd4}.map-frame img{display:block;width:760px;max-width:none}.stage-dot{position:absolute;width:28px;height:28px;border:3px solid #fff;border-radius:999px;background:#b4472a;box-shadow:0 8px 20px #0000003d;transform:translate(-50%,-50%)}.stage-dot.active{background:#f4d35e}.map-popup{position:sticky;left:10px;bottom:10px;z-index:3;width:min(320px,calc(100vw - 48px));max-height:280px;overflow:auto;display:grid;gap:10px;margin:-290px 10px 10px;border:1px solid rgba(18,54,47,.16);border-radius:8px;padding:12px;color:#17322c;background:#fffaf0f5;box-shadow:0 18px 45px #142a2438}.map-popup-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.map-popup-head div,.map-popup-list,.map-popup-row{display:grid;gap:4px}.map-popup-head strong{color:#12362f;font-size:1.05rem}.map-popup-head span,.map-popup-row span,.map-popup-row small,.map-hint{color:#567168;font-size:.86rem;font-weight:800}.map-popup-row{border:1px solid rgba(18,54,47,.1);border-radius:8px;padding:9px;background:#fff}.map-popup-row strong{color:#12362f}.map-hint{margin:8px 2px 0}.mini-artist-row{display:grid;gap:3px;width:100%;border:1px solid rgba(18,54,47,.1);border-radius:8px;padding:10px;color:#17322c;background:#fff;text-align:left}.admin-main{padding-bottom:24px}.sticky-save{position:sticky;top:74px;z-index:2}.admin-row{display:grid;gap:10px;padding:12px}.admin-row label{display:grid;gap:5px;color:#426158;font-size:.82rem;font-weight:850}@media (min-width: 720px){.app-main{padding:20px}.card-list{grid-template-columns:repeat(2,minmax(0,1fr))}.lineup-card{display:grid;grid-template-rows:180px 1fr}.tabbar{left:50%;transform:translate(-50%);width:min(720px,calc(100% - 32px));bottom:16px;border:1px solid rgba(18,54,47,.14);border-radius:8px;box-shadow:0 18px 45px #25382f29}}
