:root{--bg: #f7fbfd;--paper: #ffffff;--paper-soft: #f2f8fb;--ink: #172431;--muted: #687789;--line: #dbe7ee;--line-strong: #c9d9e2;--teal: #087f8c;--teal-soft: #e6f7f8;--coral: #ff675c;--gold: #d99a13;--shadow: 0 24px 70px rgba(23, 36, 49, .11);--soft-shadow: 0 12px 34px rgba(23, 36, 49, .07);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{cursor:pointer}button:disabled,input:disabled{cursor:not-allowed;opacity:.58}h1,h2,h3,p,figure{margin:0}.app-shell{min-height:100vh;padding:18px;background:radial-gradient(circle at 8% 0%,rgba(217,154,19,.12),transparent 28%),linear-gradient(145deg,#fff,#f3fbfe 52%,#fff)}.workspace{width:min(100%,520px);margin:0 auto;padding-bottom:30px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 2px 18px}.brand{display:flex;align-items:center;min-width:0;gap:13px}.brand-mark{display:grid;place-items:center;flex:0 0 auto;width:50px;height:50px;border-radius:18px;color:#fff;background:linear-gradient(140deg,rgba(255,255,255,.26),transparent 45%),linear-gradient(135deg,#087f8c,#ff675c);box-shadow:0 18px 36px #087f8c3b}h1{font-size:clamp(1.7rem,7vw,2.28rem);line-height:.98;letter-spacing:0}.brand p{margin-top:5px;color:var(--muted);font-size:clamp(.92rem,3vw,1.02rem);line-height:1.35}.icon-button,.secondary-action,.inline-form button,.song-copy,.play-button{border:1px solid var(--line);background:var(--paper);color:var(--ink)}.icon-button{display:grid;place-items:center;flex:0 0 auto;width:48px;height:48px;border-radius:18px;box-shadow:var(--soft-shadow)}.surface{margin-bottom:14px;padding:18px;border:1px solid rgba(219,231,238,.92);border-radius:18px;background:#fffffff0;box-shadow:var(--soft-shadow)}.photo-surface{background:linear-gradient(135deg,#f2f8fbdb,#fffffff5),var(--paper)}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.section-heading span{display:inline-flex;align-items:center;gap:10px;color:#314555;font-size:.92rem;font-weight:850;letter-spacing:.03em;text-transform:uppercase}.section-heading svg{color:var(--teal);stroke-width:2.35}.section-heading small{color:var(--muted);font-size:.82rem;font-weight:800}.upload-target{display:flex;align-items:center;justify-content:center;gap:10px;min-height:70px;border:1.5px dashed rgba(8,127,140,.33);border-radius:14px;background:#ffffffb8;color:var(--teal);font-weight:900}.upload-target.compact{min-height:46px;margin-bottom:12px;border-style:solid;background:#fff;box-shadow:inset 0 0 0 1px #087f8c08}.upload-target input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.photo-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:8px;margin-bottom:12px}.photo-actions .upload-target{margin-bottom:0}.photo-actions .upload-target:first-child:last-child{grid-column:1 / -1}.clear-photos,.remove-photo{display:inline-grid;place-items:center;border:1px solid var(--line);background:#ffffffe0;color:#4a5a69}.clear-photos{grid-template-columns:auto auto;align-items:center;justify-content:center;gap:6px;min-width:82px;border-radius:8px;font-size:.86rem;font-weight:900}.photo-grid{display:grid;gap:8px}.photo-grid.count-1{grid-template-columns:1fr}.photo-grid.count-2,.photo-grid.count-4{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-grid.count-3{grid-template-columns:1.08fr .92fr;grid-template-rows:auto auto}.photo-grid.count-3 .photo-tile:first-child{grid-row:span 2}.photo-tile{position:relative;display:grid;place-items:center;min-height:150px;aspect-ratio:var(--photo-aspect);overflow:hidden;border:1px solid rgba(211,226,235,.94);border-radius:8px;background:#eef6f9;box-shadow:0 14px 28px #17243114}.photo-grid.count-3 .photo-tile,.photo-grid.count-4 .photo-tile{width:100%;height:100%;min-height:0}.photo-grid.count-3 .photo-tile:first-child{aspect-ratio:auto}.photo-grid.count-4 .photo-tile{aspect-ratio:1 / .72}.photo-tile:before{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background-image:var(--photo-bg);background-position:center;background-size:cover;filter:blur(16px) saturate(1.1);opacity:.34;transform:scale(1.08)}.photo-tile img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;filter:saturate(1.03)}.remove-photo{position:absolute;top:8px;right:8px;z-index:2;width:32px;height:32px;border-radius:999px;color:#fff;background:#1724318f;border-color:#ffffff47;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.country-picker{position:relative;z-index:4}.country-input-shell{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;min-height:54px;padding:0 14px;border:1px solid var(--line);border-radius:14px;background:var(--paper)}.country-input-shell:focus-within{border-color:#087f8c8c;box-shadow:0 0 0 4px #087f8c1a}.country-input-shell input{width:100%;min-width:0;border:0;outline:none;color:var(--ink);background:transparent;font-size:1rem;font-weight:650}.country-input-shell svg{color:var(--muted)}.country-flag{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;background:var(--paper-soft);font-size:1.28rem}.country-menu{position:absolute;top:calc(100% + 8px);right:0;left:0;z-index:6;max-height:310px;overflow:auto;padding:6px;border:1px solid var(--line);border-radius:8px;background:#fffffffa;box-shadow:var(--shadow)}.country-menu button{display:grid;grid-template-columns:34px 1fr;align-items:center;width:100%;min-height:43px;border:0;border-radius:7px;background:transparent;color:var(--ink);text-align:left}.country-menu button:hover{background:var(--teal-soft)}.country-menu span{font-size:1.15rem}.country-menu strong{font-size:.94rem}.controls-surface{display:grid;gap:18px}.slider-block{display:block}.slider-title,.slider-title span,.slider-labels{display:flex;align-items:center}.slider-title{justify-content:space-between;gap:12px;font-weight:900}.slider-title span{gap:10px}.slider-title svg{color:var(--teal);stroke-width:2.45}.slider-title strong{color:var(--teal);font-size:1.06rem}.slider-labels{justify-content:space-between;color:var(--muted);font-size:.78rem;font-weight:650}input[type=range]{width:100%;height:22px;margin:6px 0 2px;border:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent}input[type=range]::-webkit-slider-runnable-track{height:7px;border-radius:999px;background:linear-gradient(90deg,var(--teal) 0 var(--value, 50%),#dfe7eb var(--value, 50%) 100%)}input[type=range]::-webkit-slider-thumb{width:22px;height:22px;margin-top:-7.5px;border:4px solid #fff;border-radius:999px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--teal);box-shadow:0 6px 18px #087f8c52}input[type=range]::-moz-range-track{height:7px;border-radius:999px;background:#dfe7eb}input[type=range]::-moz-range-progress{height:7px;border-radius:999px;background:var(--teal)}input[type=range]::-moz-range-thumb{width:16px;height:16px;border:4px solid #fff;border-radius:999px;background:var(--teal);box-shadow:0 6px 18px #087f8c52}.tier-range{margin-top:12px}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:0 12px;border:1px solid rgba(8,127,140,.28);border-radius:999px;background:#f2fbfb;color:var(--teal);font-size:.86rem;font-weight:850}.inline-form{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:12px}.inline-form input{width:100%;min-height:48px;border:1px solid var(--line);border-radius:12px;background:var(--paper);color:var(--ink);padding:0 13px;outline:none}.notes-surface{padding-top:15px;padding-bottom:15px}.notes-surface .section-heading{margin-bottom:10px}.notes-surface input{width:100%;min-height:46px;border:1px solid var(--line);border-radius:12px;background:var(--paper);color:var(--ink);padding:0 13px;outline:none}.notes-surface input::placeholder{color:#8a97a6}.inline-form input:focus,.notes-surface input:focus,button:focus-visible{border-color:var(--teal);box-shadow:0 0 0 4px #087f8c1f;outline:none}.inline-form button{min-width:70px;border-radius:12px;font-weight:900}.segment{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;border:1px solid var(--line);border-radius:14px;background:#f5f8fa}.segment button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:47px;border:0;border-radius:7px;background:transparent;color:var(--ink);font-weight:900}.segment button.active{color:#fff;background:linear-gradient(135deg,#098896,#08717d);box-shadow:0 10px 24px #087f8c42}.secondary-action,.primary-action{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;min-height:48px;border-radius:14px;font-weight:900}.secondary-action{margin-top:12px}.primary-action{position:sticky;bottom:12px;z-index:5;min-height:60px;margin-top:18px;border:0;border-radius:18px;color:#fff;font-size:1.05rem;background:linear-gradient(135deg,#098896,#08717d);box-shadow:0 18px 38px #087f8c52}.mood-strip{display:grid;gap:3px;margin-top:12px;padding:12px;border:1px solid rgba(217,154,19,.22);border-radius:8px;background:#fffaf0}.mood-strip span{color:var(--muted);font-size:.88rem}.status{min-height:22px;padding:10px 4px 0;color:var(--muted);text-align:center;font-size:.9rem;line-height:1.4}.songs{margin:8px 0 14px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#ffffff94}.song-list{display:grid}.song-row{position:relative;display:grid;grid-template-columns:50px minmax(0,1fr);gap:13px;align-items:center;padding:13px 0;border-bottom:1px solid rgba(219,231,238,.92)}.song-row:last-child{border-bottom:0}.play-button{display:grid;place-items:center;width:48px;height:48px;border-radius:999px;color:var(--teal);box-shadow:0 10px 24px #17243114}.song-row.playing .play-button{color:#fff;border-color:transparent;background:var(--coral);box-shadow:0 14px 30px #ff675c4d}.song-main{min-width:0}.song-line{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:9px}.song-text{min-width:0}.song-text h3{overflow:hidden;color:var(--ink);font-size:.98rem;line-height:1.2;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.song-text p{margin-top:2px;overflow:hidden;color:var(--muted);font-size:.86rem;text-overflow:ellipsis;white-space:nowrap}.song-tags{display:flex;flex-wrap:wrap;justify-content:flex-end;max-width:126px;gap:5px}.song-tag{padding:4px 8px;border:1px solid #ffd5d1;border-radius:999px;color:#ee5146;background:#fff5f3;font-size:.72rem;font-weight:900;line-height:1}.song-tag:nth-child(2){border-color:#bfe8ee;color:var(--teal);background:#eefafb}.song-copy{display:grid;place-items:center;width:38px;height:38px;border-radius:999px;color:#4a5a69;background:#f7fafb}.timeline-row{display:grid;grid-template-columns:34px 1fr 38px;align-items:center;gap:8px;height:0;overflow:hidden;opacity:0;transition:height .18s ease,opacity .18s ease,margin-top .18s ease}.song-row.active .timeline-row,.song-row.playing .timeline-row{height:30px;margin-top:8px;opacity:1}.timeline-row span{color:var(--muted);font-size:.72rem;font-weight:750;font-variant-numeric:tabular-nums}.timeline-row input[type=range]{height:18px;margin:0}.timeline-row input[type=range]::-webkit-slider-runnable-track{height:5px}.timeline-row input[type=range]::-webkit-slider-thumb{width:17px;height:17px;margin-top:-6px;border-width:3px}.audio-note{margin-top:4px;color:var(--muted);font-size:.78rem;font-weight:650}.youtube-audio{position:absolute;right:0;bottom:0;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:760px){.app-shell{padding:36px 20px}.workspace{width:min(100%,680px)}.surface{padding:20px}}@media(max-width:420px){.app-shell{padding:14px}.surface{padding:15px}.photo-grid.count-3,.photo-grid.count-4{gap:6px}.song-line{grid-template-columns:minmax(0,1fr) auto}.song-tags{grid-row:2;grid-column:1 / 2;justify-content:flex-start;margin-top:5px}.song-copy{grid-row:1 / span 2;grid-column:2}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
