/* Symplate — The Conductor. Dark aubergine + cream + peach. */
:root{
  --bg:#1E1719; --panel:#271F22; --panel-2:#2E2528; --line:#3A2F32;
  --cream:#F3E9DF; --muted:#9A8C84; --faint:#6E625E;
  --peach:#F0A07A; --peach-deep:#E07E54; --green:#9BC29A;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;background:#140F11;}
body{font-family:'DM Sans',system-ui,sans-serif;color:var(--cream);}
.serif{font-family:'Instrument Serif',Georgia,serif;font-weight:400;letter-spacing:-0.01em;}
button{font-family:inherit;color:inherit;border:none;background:none;cursor:pointer;}

.app{min-height:100vh;display:flex;justify-content:center;align-items:flex-start;
  background:radial-gradient(120% 80% at 50% -10%, #2A2024 0%, #1E1719 55%, #140F11 100%);}
.shell{width:100%;max-width:480px;min-height:100vh;background:var(--bg);
  box-shadow:0 0 80px rgba(0,0,0,0.5);display:flex;flex-direction:column;position:relative;overflow:hidden;}

/* ---- status bar ---- */
.status{display:flex;justify-content:space-between;align-items:center;
  padding:14px 26px 0;font-size:13px;font-weight:600;color:var(--muted);}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 26px 6px;}
.brand{font-size:12px;font-weight:700;letter-spacing:0.22em;color:var(--faint);}
.now{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:0.02em;}

.scr{flex:1;display:flex;flex-direction:column;min-height:0;padding:0 26px;}

/* ================= SETUP ================= */
.setup-h{font-size:13px;color:var(--peach);font-weight:700;letter-spacing:0.06em;text-transform:uppercase;margin:18px 0 6px;}
.setup-q{font-size:40px;line-height:1.0;margin:0 0 16px;}
.timepick{display:flex;align-items:center;gap:18px;justify-content:center;
  background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:14px 18px;margin-bottom:6px;}
.timepick .t{font-size:50px;line-height:1;min-width:150px;text-align:center;}
.stepper{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line);
  font-size:24px;color:var(--cream);display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:border-color .15s,background .15s;}
.stepper:active{background:var(--panel-2);}
.steplbl{text-align:center;font-size:12px;color:var(--faint);margin:8px 0 2px;letter-spacing:.03em;}

.section-row{display:flex;align-items:baseline;justify-content:space-between;margin:24px 0 12px;}
.section-row .c{font-size:12px;color:var(--faint);font-weight:600;}

.dish{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:12px 14px;margin-bottom:10px;}
.dish .nm{flex:1;font-size:17px;font-weight:500;min-width:0;}
.dish .mins{display:flex;align-items:center;gap:10px;color:var(--muted);}
.dish .mins .v{font-size:15px;min-width:54px;text-align:right;font-variant-numeric:tabular-nums;}
.mstep{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);font-size:17px;
  color:var(--cream);display:flex;align-items:center;justify-content:center;}
.dish .rm{width:30px;height:30px;border-radius:50%;color:var(--faint);font-size:20px;display:flex;align-items:center;justify-content:center;}
.dish .rm:hover{color:var(--peach);}

.empty{border:1.5px dashed var(--line);border-radius:16px;padding:22px;text-align:center;
  color:var(--faint);font-size:14px;margin-bottom:10px;}

/* search to add dishes */
.search{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:0 14px;margin-top:4px;transition:border-color .15s;}
.search:focus-within{border-color:var(--peach);}
.search .ic{color:var(--faint);font-size:18px;flex-shrink:0;}
.search input{flex:1;background:none;border:none;outline:none;color:var(--cream);
  font-family:inherit;font-size:16px;padding:13px 0;min-width:0;}
.search input::placeholder{color:var(--faint);}
.search .clr{width:26px;height:26px;border-radius:50%;color:var(--faint);font-size:18px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;}
.search .clr:hover{color:var(--peach);}

.results{margin-top:8px;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;}
.res{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 15px;
  border-bottom:1px solid var(--line);transition:background .12s;}
.res:last-child{border-bottom:none;}
button.res:hover{background:var(--panel-2);}
.res .rnm{flex:1;font-size:16px;font-weight:500;min-width:0;}
.res .rm2{color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums;}
.res .add{color:var(--peach);font-size:20px;width:24px;text-align:center;flex-shrink:0;}
.res.added{opacity:.55;}
.res.added .add{color:var(--green);}
.res.custom .rnm{color:var(--peach);}
.res .minput{width:62px;background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:8px 10px;color:var(--cream);font-family:inherit;font-size:14px;text-align:center;outline:none;}
.res .minput:focus{border-color:var(--peach);}

.dishlist{margin-top:14px;}

/* recipe-link import */
.importer{margin-top:14px;}
.importer .lbl{font-size:12px;color:var(--faint);font-weight:600;letter-spacing:.03em;}
.import{display:flex;align-items:center;gap:8px;margin-top:7px;}
.import input{flex:1;min-width:0;background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:11px 13px;color:var(--cream);font-family:inherit;font-size:14px;outline:none;}
.import input:focus{border-color:var(--peach);}
.import input::placeholder{color:var(--faint);}
.import .imp{flex:0 0 auto;background:var(--peach);color:#241015;border-radius:12px;
  padding:11px 16px;font-size:14px;font-weight:700;}
.import .imp:disabled{background:var(--panel-2);color:var(--faint);}
.importmsg{font-size:13px;color:var(--muted);margin-top:8px;}
.importmsg.err{color:var(--peach);}
.importmsg.load{animation:pulse 1.1s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.45;}50%{opacity:1;}}

/* ================= CONDUCTOR ================= */
.cond{flex:1;display:flex;flex-direction:column;min-height:0;padding:0 26px;}
.label{font-size:13px;color:var(--peach);font-weight:700;letter-spacing:0.06em;text-transform:uppercase;}
.move{font-size:54px;line-height:0.98;margin:12px 0 10px;}
.meta{font-size:16px;color:var(--muted);font-weight:500;}
.ring-wrap{display:flex;justify-content:center;margin:14px 0 8px;}

.then{margin-top:8px;}
.then-h{font-size:12px;color:var(--faint);font-weight:700;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:2px;}
.qrow{display:flex;align-items:baseline;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);}
.qrow:last-child{border-bottom:none;}
.qrow .qt{font-family:'Instrument Serif',serif;font-size:21px;width:54px;color:var(--peach);flex-shrink:0;}
.qrow .qn{flex:1;font-size:16px;font-weight:500;}
.qrow .qnote{font-size:13px;color:var(--faint);}
.qrow.plate .qn{color:var(--green);}
.qrow.cooking .qt{color:var(--green);}
.qrow.cooking .qn::after{content:'on now';font-size:11px;color:var(--green);margin-left:8px;
  border:1px solid var(--green);border-radius:999px;padding:2px 7px;vertical-align:middle;font-weight:600;}

/* ready state */
.ready{flex:1;min-height:260px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:10px;padding:32px 0;}
.ready .big{font-size:40px;line-height:1.05;color:var(--green);white-space:nowrap;}
.ready .sub{color:var(--muted);font-size:16px;}

/* ---- footer / controls ---- */
.foot{padding:14px 26px 22px;border-top:1px solid var(--line);background:var(--bg);}
.btn{display:block;width:100%;text-align:center;border-radius:14px;padding:15px 0;font-weight:700;font-size:15px;}
.btn.primary{background:var(--peach);color:#241015;}
.btn.primary:disabled{opacity:.35;}
.btn.ghost{border:1.5px solid var(--line);color:var(--cream);}

.preview{display:flex;align-items:center;gap:14px;margin-bottom:12px;}
.play{width:44px;height:44px;border-radius:50%;background:var(--panel-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px;color:var(--peach);}
.play.on{background:var(--peach);color:#241015;border-color:var(--peach);}
.scrub{flex:1;}
.scrub-lbl{font-size:11px;color:var(--faint);letter-spacing:.04em;margin-bottom:5px;display:flex;justify-content:space-between;}
input[type=range].slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:4px;
  background:var(--line);outline:none;}
input[type=range].slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--peach);cursor:pointer;border:3px solid var(--bg);box-shadow:0 0 0 1px var(--peach);}
input[type=range].slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--peach);border:3px solid var(--bg);cursor:pointer;}

.editlink{display:block;text-align:center;color:var(--faint);font-size:13px;font-weight:600;margin-top:14px;}
.editlink:hover{color:var(--peach);}

/* ================= DESKTOP ================= */
@media (min-width:900px){
  .app{align-items:center;padding:32px 0;}
  .shell{max-width:1000px;min-height:704px;height:auto;border-radius:28px;border:1px solid var(--line);}
  .shell.desk-2col .scr{display:grid;grid-template-columns:1fr 1fr;gap:0 48px;padding:0 44px 8px;}
  .desk-pad{padding:8px 44px 0;}
  .move{font-size:62px;}
  .ready .big{font-size:58px;}
  .setup-q{font-size:46px;}
  /* setup grid: time on left, dishes on right */
  .setup-grid{display:grid;grid-template-columns:minmax(0,0.85fr) minmax(0,1fr);gap:0 48px;}
  .cond-grid{display:grid;grid-template-columns:minmax(0,0.95fr) minmax(0,1fr);gap:0 48px;align-items:start;}
  .setup-grid>div,.cond-grid>div{min-width:0;}
  .move{overflow-wrap:break-word;}
  .ring-wrap{justify-content:flex-start;}
}
