:root{--parchment:#F8F5F0;--parchment-warm:#F0EBE2;--parchment-deep:#E4D8C2;--card-bg:#FFFCF7;--card-hover:#FFFFFF;--card-border:rgba(26,26,46,0.10);--ink:#1A1A2E;--ink-soft:#2A2A3E;--muted:#38333E;--dim:#58525E;--moonweed:#4A78CC;--moonweed-light:#6E9AE8;--moonweed-dim:rgba(74,120,204,0.10);--meadow:#3E7A4E;--meadow-light:#5A9A68;--meadow-dim:rgba(62,122,78,0.10);--gold:#9A7A2A;--gold-light:#C9A84C;--gold-dim:rgba(154,122,42,0.10);--rose:#A83A58;--rose-light:#D07898;--rose-dim:rgba(168,58,88,0.10);--teal:#2D5258;--teal-light:#4A7880;--teal-dim:rgba(45,82,88,0.10);--lavender:#6E6890;--border:rgba(74,120,204,0.08);--border-strong:rgba(74,120,204,0.15);--shadow-sm:0 1px 4px rgba(26,26,46,0.04);--shadow:0 4px 24px rgba(26,26,46,0.05),0 1px 3px rgba(26,26,46,0.03);--shadow-lg:0 12px 40px rgba(74,120,204,0.08),0 2px 8px rgba(26,26,46,0.04);--radius:6px;--radius-sm:4px;--ease:cubic-bezier(0.22,0.61,0.36,1);--dur:0.35s;--max:1100px}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
img,svg{display:block;max-width:100%}
body{font-family:'EB Garamond','Georgia',serif;font-size:18px;line-height:1.75;color:var(--ink);background:var(--parchment);-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
h1,h2,h3{font-family:'Cormorant Garamond','Georgia',serif;line-height:1.25;color:var(--ink)}
a{color:var(--moonweed);text-decoration:none;transition:color .3s var(--ease)}
a:hover{color:var(--teal)}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(circle .5px at 20% 30%,rgba(140,120,80,.018) 50%,transparent 50%),radial-gradient(circle .7px at 60% 70%,rgba(140,120,80,.015) 50%,transparent 50%),radial-gradient(circle .4px at 80% 20%,rgba(140,120,80,.020) 50%,transparent 50%),radial-gradient(ellipse 80% 80% at 50% 50%,transparent 50%,rgba(100,90,70,.035) 100%);background-size:4px 4px,6px 6px,5px 5px,100% 100%;pointer-events:none;z-index:0}
.golden-hour{position:fixed;inset:0;background:linear-gradient(145deg,transparent 0%,transparent 50%,rgba(201,168,76,.035) 65%,rgba(232,196,122,.05) 78%,rgba(201,168,76,.025) 88%,transparent 100%);pointer-events:none;z-index:0}
.atmosphere{position:fixed;inset:0;background:radial-gradient(ellipse 130% 130% at 50% 35%,rgba(255,255,255,.05) 0%,rgba(255,255,255,.02) 45%,transparent 75%);pointer-events:none;z-index:1}
.page-frame{position:fixed;top:16px;left:16px;right:16px;bottom:16px;border:1px solid rgba(74,120,204,.10);pointer-events:none;z-index:60;border-radius:3px;animation:frame-shimmer 30s ease-in-out infinite}
@keyframes frame-shimmer{0%,100%{border-color:rgba(74,120,204,.10)}33%{border-color:rgba(201,168,76,.12)}66%{border-color:rgba(110,104,144,.10)}}

/* ── Timeline ─── */
.timeline{max-width:var(--max);margin:0 auto;padding:12px 32px 20px;position:relative;z-index:3}
.timeline-row{display:flex;align-items:center;gap:4px;margin-bottom:10px}
.timeline-label{font-family:'Special Elite',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);width:90px;flex-shrink:0;text-align:right;padding-right:10px}
.timeline-slots{display:flex;gap:4px;flex:1;flex-wrap:wrap}
.slot{font-family:'Special Elite',monospace;font-size:13px;width:48px;height:48px;border-radius:var(--radius);border:2px solid var(--card-border);background:var(--card-bg);color:var(--dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s var(--ease);position:relative;flex-shrink:0}
.slot:hover{border-color:var(--gold);color:var(--gold);box-shadow:0 2px 8px rgba(154,122,42,.15)}
.slot--active{border-color:var(--gold);color:var(--gold);box-shadow:0 2px 12px rgba(154,122,42,.25);background:var(--gold-dim)}
.slot--filled{border-color:var(--meadow);color:var(--meadow);background:var(--meadow-dim)}
.slot--filled.slot--active{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
.slot--filled::after{content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--meadow)}
.slot--filled.slot--active::after{background:var(--gold)}

/* ── Parts Bin ─── */
.parts-bin{max-width:var(--max);margin:0 auto;padding:0 32px 20px;position:relative;z-index:3}
.parts-bin-inner{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.parts-bin-inner::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--moonweed),var(--gold-light))}
.parts-bin-header{padding:20px 24px 14px;border-bottom:1px solid var(--border)}
.parts-bin-header h3{font-weight:600;font-size:20px}
.parts-bin-header h3 span{color:var(--gold)}

/* ── Coverflow Carousel ─── */
.carousel-wrap{position:relative;padding:16px 0 32px;perspective:1200px;overflow-x:clip;overflow-y:visible}
.variants{position:relative;width:100%;height:300px;transform-style:preserve-3d}
.variant-card{position:absolute;left:50%;top:0;width:420px;margin-left:-210px;border:2px solid var(--border);border-radius:8px;padding:16px 20px;cursor:pointer;background:var(--parchment);transition:transform .45s var(--ease),opacity .45s var(--ease),box-shadow .45s var(--ease),border-color .25s var(--ease),background .25s var(--ease);transform-style:preserve-3d;backface-visibility:hidden}
.variant-card--center{z-index:10;transform:translateX(0) translateZ(0) rotateY(0) scale(1);opacity:1;box-shadow:0 8px 32px rgba(26,26,46,.1),0 2px 8px rgba(26,26,46,.06)}
.variant-card--center:hover{border-color:var(--gold-light);box-shadow:0 12px 40px rgba(154,122,42,.15),0 2px 8px rgba(26,26,46,.06);background:var(--card-hover);cursor:pointer}
.variant-card--center::before{display:none}
.variant-card--left1{z-index:5;transform:translateX(-75%) translateZ(-80px) rotateY(30deg) scale(.85);opacity:.75;pointer-events:auto}
.variant-card--right1{z-index:5;transform:translateX(75%) translateZ(-80px) rotateY(-30deg) scale(.85);opacity:.75;pointer-events:auto}
.variant-card--left2{z-index:2;transform:translateX(-130%) translateZ(-160px) rotateY(40deg) scale(.7);opacity:.4;pointer-events:none}
.variant-card--right2{z-index:2;transform:translateX(130%) translateZ(-160px) rotateY(-40deg) scale(.7);opacity:.4;pointer-events:none}
.variant-card--hidden{z-index:0;transform:translateX(0) translateZ(-200px) scale(.5);opacity:0;pointer-events:none}
.variant-card--selected{border-color:var(--meadow);background:var(--meadow-dim)}
.variant-card--selected.variant-card--center{box-shadow:0 8px 32px rgba(62,122,78,.15),0 2px 8px rgba(26,26,46,.06)}
.variant-card--selected::after{content:'Selected';position:absolute;top:10px;right:14px;font-family:'Special Elite',monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--meadow);background:rgba(255,255,255,.8);padding:2px 8px;border-radius:10px}
.variant-label{font-family:'Special Elite',monospace;font-size:12px;color:var(--dim);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.variant-preview{min-height:80px;overflow:hidden}
.variant-preview svg{max-width:100%;height:auto}
.variant-play{display:inline-flex;align-items:center;gap:4px;font-family:'EB Garamond',serif;font-size:14px;color:var(--meadow);background:none;border:1px solid var(--meadow);border-radius:var(--radius-sm);padding:4px 12px;cursor:pointer;margin-top:8px;transition:all .2s var(--ease)}
.variant-play:hover{background:var(--meadow);color:#fff}
.variant-play.playing{background:var(--rose);border-color:var(--rose);color:#fff}
.variant-play svg{width:12px;height:12px}
.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:1.5px solid var(--card-border);background:var(--card-bg);color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:all .25s var(--ease);z-index:20}
.carousel-arrow:hover{border-color:var(--gold);color:var(--gold);box-shadow:0 3px 12px rgba(154,122,42,.2)}
.carousel-arrow:disabled{opacity:.3;cursor:default;box-shadow:none}
.carousel-arrow:disabled:hover{border-color:var(--card-border);color:var(--ink)}
.carousel-arrow--left{left:12px}
.carousel-arrow--right{right:12px}
.carousel-arrow svg{width:18px;height:18px}
.carousel-dots{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 0 0}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--parchment-deep);border:1px solid var(--card-border);cursor:pointer;transition:all .25s var(--ease);padding:0}
.carousel-dot:hover{background:var(--gold-light)}
.carousel-dot--active{background:var(--gold);border-color:var(--gold);transform:scale(1.3)}
.carousel-dot--selected{background:var(--meadow);border-color:var(--meadow)}
.carousel-counter{text-align:center;padding:4px 0 0;font-family:'Special Elite',monospace;font-size:12px;color:var(--dim)}

/* ── Score Area ─── */
.score-area{max-width:var(--max);margin:0 auto;padding:0 32px 32px;position:relative;z-index:3}
.score-shell{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.score-shell::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--meadow),var(--teal),var(--meadow-light))}
.score-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:20px 24px 14px;border-bottom:1px solid var(--border)}
.score-header h3{font-weight:600;font-size:20px;flex:1;min-width:0}
/* #scoreTitle ID styles removed — input is styled by .name-input class */
.score-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.score-btn{font-family:'EB Garamond',serif;font-size:15px;font-weight:500;padding:8px 18px;border-radius:var(--radius);cursor:pointer;border:1.5px solid transparent;display:inline-flex;align-items:center;gap:6px;transition:all .25s var(--ease);letter-spacing:.02em;line-height:1}
.score-btn svg{width:14px;height:14px;flex-shrink:0}
.score-btn--play{background:linear-gradient(135deg,var(--meadow),#2E6A3E);color:#F0F8F2;border-color:var(--meadow)}
.score-btn--play:hover{background:linear-gradient(135deg,#2E6A3E,#1E5A2E);box-shadow:0 3px 12px rgba(62,122,78,.25)}
.score-btn--play.active{background:linear-gradient(135deg,#2E6A3E,#1A4E28);box-shadow:inset 0 2px 6px rgba(0,0,0,.15)}
.score-btn--stop{background:linear-gradient(135deg,var(--rose),#8A2A48);color:#FCF0F2;border-color:var(--rose)}
.score-btn--stop:hover{background:linear-gradient(135deg,#8A2A48,#6A1A38);box-shadow:0 3px 12px rgba(168,58,88,.25)}
.score-btn--pdf{background:linear-gradient(135deg,var(--moonweed),#3A60AA);color:#F0F2F8;border-color:var(--moonweed)}
.score-btn--pdf:hover:not(:disabled){background:linear-gradient(135deg,#3A60AA,#2A508A);box-shadow:0 3px 12px rgba(74,120,204,.25)}
.score-btn--pdf:disabled{opacity:.45;cursor:default;box-shadow:none}
.score-timbre{font-family:'EB Garamond',serif;font-size:15px;padding:8px 12px;border-radius:var(--radius);border:1.5px solid var(--card-border);background:var(--parchment);color:var(--ink);cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%2358525E' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;transition:border-color .25s var(--ease)}
.score-timbre:hover,.score-timbre:focus{border-color:var(--gold);outline:none}
.score-display{padding:16px 20px 20px;min-height:80px;overflow-x:auto}
.score-display svg{display:block;margin:0 auto;max-width:100%}
.score-empty{text-align:center;padding:40px 20px;color:var(--dim);font-style:italic;font-size:16px}
.abc-hidden{position:absolute;top:0;left:0;width:1px;height:1px;opacity:0;pointer-events:none;overflow:hidden}


/* ── Step 4 inline actions ─── */
.complete-play-row{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.complete-play-btn{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:17px;padding:12px 28px;border-radius:var(--radius);border:none;background:linear-gradient(135deg,var(--meadow),#2E6A3E);color:#fff;cursor:pointer;letter-spacing:.02em;transition:all .3s var(--ease);box-shadow:0 4px 16px rgba(62,122,78,.25);display:inline-flex;align-items:center;gap:8px}
.complete-play-btn:hover{background:linear-gradient(135deg,#2E6A3E,var(--meadow));box-shadow:0 6px 24px rgba(62,122,78,.35);transform:translateY(-1px)}
.complete-play-btn svg{width:16px;height:16px}
.complete-pdf-btn{font-family:'EB Garamond',serif;font-size:15px;padding:10px 22px;border-radius:var(--radius);cursor:pointer;transition:all .25s var(--ease);letter-spacing:.02em;border:1.5px solid var(--moonweed);background:none;color:var(--moonweed);display:inline-flex;align-items:center;gap:6px}
.complete-pdf-btn:hover{background:var(--moonweed-dim)}
.complete-pdf-btn svg{width:14px;height:14px}

/* ── Wizard ─── */
.wizard-steps{max-width:var(--max);margin:0 auto;padding:0 32px 28px;position:relative;z-index:3}
.wizard-steps-inner{display:flex;align-items:center;justify-content:center}
.wizard-step-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0;transition:opacity .25s var(--ease)}
.wizard-step-item:hover{opacity:.8}
.wizard-step-num{width:36px;height:36px;border-radius:50%;border:2px solid var(--card-border);background:var(--card-bg);color:var(--dim);font-family:'Special Elite',monospace;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .35s var(--ease);flex-shrink:0}
.wizard-step-label{font-family:'EB Garamond',serif;font-size:16px;color:var(--dim);transition:color .35s var(--ease)}
.wizard-step-line{width:60px;height:2px;background:var(--card-border);margin:0 16px;transition:background .35s var(--ease)}
.wizard-step-item--active .wizard-step-num{background:var(--gold);border-color:var(--gold);color:#fff;box-shadow:0 2px 8px rgba(154,122,42,.3)}
.wizard-step-item--active .wizard-step-label{color:var(--ink);font-weight:500}
.wizard-step-item--done .wizard-step-num{background:var(--meadow);border-color:var(--meadow);color:#fff}
.wizard-step-item--done .wizard-step-label{color:var(--meadow)}
.wizard-step-line--done{background:var(--meadow)}
.wizard-panel{display:none}
.wizard-panel--active{display:block;animation:wizFadeIn .4s var(--ease)}
@keyframes wizFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.start-btn{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:18px;padding:14px 36px;border-radius:var(--radius);border:none;background:linear-gradient(135deg,var(--gold),#B8922E);color:#fff;cursor:pointer;letter-spacing:.02em;transition:all .3s var(--ease);box-shadow:0 4px 16px rgba(154,122,42,.25)}
.start-btn:hover{background:linear-gradient(135deg,#B8922E,var(--gold));box-shadow:0 6px 24px rgba(154,122,42,.35);transform:translateY(-1px)}

.name-input-wrap{margin-bottom:36px;position:relative}
.name-input{font-family:'Cormorant Garamond','Georgia',serif;font-weight:600;font-size:36px;color:var(--ink);background:var(--parchment);border:2.5px solid var(--gold-light);border-radius:var(--radius);padding:16px 20px;width:100%;max-width:460px;text-align:center;outline:none;transition:all .3s var(--ease);box-shadow:0 0 0 0 rgba(154,122,42,0)}
.name-input:hover{border-color:var(--gold);box-shadow:0 0 0 4px rgba(154,122,42,.1)}
.name-input:focus{border-color:var(--gold);box-shadow:0 0 0 6px rgba(154,122,42,.15);background:#fff}
.name-input::placeholder{color:var(--parchment-deep);font-weight:400;font-style:italic;font-size:28px}
.name-input-hint{font-family:'EB Garamond',serif;font-size:13px;color:var(--dim);font-style:italic;margin-top:10px}
@media(max-width:768px){
  .name-input{font-size:26px;padding:14px 16px}
}

/* Step 4 — Complete */
.complete-panel{max-width:var(--max);margin:0 auto;padding:0 32px 24px;position:relative;z-index:3}
.complete-inner{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:28px 32px;box-shadow:var(--shadow);text-align:center;position:relative;overflow:hidden}
.complete-inner::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--meadow),var(--teal),var(--meadow-light))}
.complete-icon{font-size:32px;color:var(--gold);margin-bottom:8px}
.complete-inner h2{font-weight:600;font-size:22px;margin-bottom:6px}
.complete-inner>p{font-size:16px;color:var(--muted);margin-bottom:20px}
.complete-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.edit-btn,.restart-btn{font-family:'EB Garamond',serif;font-size:15px;padding:10px 22px;border-radius:var(--radius);cursor:pointer;transition:all .25s var(--ease);letter-spacing:.02em}
.edit-btn{border:1.5px solid var(--moonweed);background:none;color:var(--moonweed)}
.edit-btn:hover{background:var(--moonweed-dim)}
.restart-btn{border:1.5px solid var(--card-border);background:none;color:var(--dim)}
.restart-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}

@media(max-width:768px){
  .wizard-step-label{display:none}
  .wizard-step-line{width:32px;margin:0 8px}
}


/* ── Carousel hint ─── */
.carousel-hint{text-align:center;font-family:'EB Garamond',serif;font-size:14px;font-style:italic;color:var(--dim);padding:8px 20px 4px;line-height:1.5}

/* ── Variant preview loading skeleton ─── */
@keyframes shimmer{0%{background-position:-200px 0}100%{background-position:200px 0}}
.variant-preview--loading{min-height:80px;background:linear-gradient(90deg,var(--parchment-warm) 25%,var(--parchment-deep) 50%,var(--parchment-warm) 75%);background-size:400px 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}


/* ── Responsive ─── */
@media(max-width:768px){
  .timeline-label{width:auto;text-align:left;padding-right:0;margin-bottom:4px}
  .timeline-row{flex-direction:column;align-items:flex-start}
  .slot{width:42px;height:42px;font-size:12px}
  .variant-card{width:300px;margin-left:-150px;padding:12px 14px}
  .carousel-arrow{width:36px;height:36px}
  .carousel-arrow--left{left:4px}
  .carousel-arrow--right{right:4px}
  .timeline,.parts-bin,.score-area{padding-left:20px;padding-right:20px}
  .parts-bin-header{padding:16px 18px 12px}
  .score-header{padding:16px 18px 12px;flex-direction:column;align-items:flex-start}
}
@media(max-width:420px){
  .page-frame{display:none}
  .timeline,.parts-bin,.score-area{padding-left:16px;padding-right:16px}
  .slot{width:38px;height:38px;font-size:11px}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}

.wizard-steps{padding-top:8px}
main{padding-bottom:28px}
@media(max-width:768px){.timeline,.parts-bin,.score-area{padding-left:20px;padding-right:20px}}
@media(max-width:420px){.timeline,.parts-bin,.score-area{padding-left:16px;padding-right:16px}}
