/* Little Plates — design system
   Register: product UI used mid-task in a kitchen, at arm's length, hands busy.
   Committed color strategy: one tomato accent; true off-white base (chroma ~0.005,
   deliberately NOT the cream/beige band); soft radius system (cards 20, controls pill). */

@font-face{font-family:'Baloo 2';font-style:normal;font-weight:400 800;font-display:swap;src:url('../fonts/Baloo2.woff2') format('woff2');}
@font-face{font-family:'Nunito';font-style:normal;font-weight:200 1000;font-display:swap;src:url('../fonts/Nunito.woff2') format('woff2');}

:root{
  /* surfaces: warm peach toward the brand hue — colorful, still readable */
  --bg:#FBEFE7;
  --surface:#FFFFFF;
  --surface-2:#F7E8DE;
  --line:#F0DACC;
  --line-strong:#DEC2AF;
  /* ink */
  --ink:#3A2B24;
  --ink-2:#6E5A50;
  --ink-3:#A08874;
  /* brand: tomato */
  --brand:#E2603F;
  --brand-deep:#C24425;
  --brand-text:#A33417;
  --brand-tint:#FBE3DA;
  /* full palette roles */
  --green:#2E7D57;
  --green-mid:#3E9668;
  --green-deep:#1F5C3D;
  --green-tint:#DDF1E5;
  --amber:#F0A63C;
  --amber-deep:#C77E14;
  --amber-text:#7A5410;
  --amber-tint:#FDEBCB;
  --blue:#5D9BC7;
  --blue-text:#2E5F7E;
  --blue-tint:#E1EFF7;
  --pink:#E88FA6;
  --pink-tint:#FBE4EA;
  /* scene canvas is a fixed daylight counter in BOTH themes (it is a picture) */
  --scene-bg:#FFF9F5;
  --scene-line:#EFE2DA;
  /* elevation (tinted to bg hue, never pure black) */
  --shadow-1:0 1px 2px rgba(84,52,40,.06),0 2px 8px rgba(84,52,40,.06);
  --shadow-2:0 2px 6px rgba(84,52,40,.08),0 10px 28px rgba(84,52,40,.10);
  --shadow-3:0 6px 16px rgba(84,52,40,.14),0 24px 48px rgba(84,52,40,.16);
  /* motion */
  --ease-out:cubic-bezier(0.23,1,0.32,1);
  --ease-in-out:cubic-bezier(0.77,0,0.175,1);
  --ease-drawer:cubic-bezier(0.32,0.72,0,1);
  --dur-press:140ms;
  --dur-state:220ms;
  --dur-view:280ms;
  /* shape system: cards 20, panels 16, controls pill */
  --r-card:20px;
  --r-panel:16px;
  --r-pill:999px;
  /* layout */
  --nav-h:64px;
  --sat:env(safe-area-inset-top,0px);
  --sab:env(safe-area-inset-bottom,0px);
  /* z scale */
  --z-sticky:10;
  --z-sheet-backdrop:20;
  --z-sheet:21;
  --z-toast:30;
}

[data-theme="dark"]{
  --bg:#241A15;
  --surface:#2F211B;
  --surface-2:#3B2A22;
  --line:#4D372B;
  --line-strong:#63483A;
  --ink:#F7EDE7;
  --ink-2:#CFB8AA;
  --ink-3:#9C8271;
  --brand:#F0805D;
  --brand-deep:#C24425;
  --brand-text:#FFB098;
  --brand-tint:#4B2A1E;
  --green:#5CBB8D;
  --green-mid:#5CBB8D;
  --green-deep:#8ED9B4;
  --green-tint:#22392E;
  --amber:#F0A63C;
  --amber-deep:#F0A63C;
  --amber-text:#F5D9A5;
  --amber-tint:#43351B;
  --blue:#7FB5D6;
  --blue-text:#B8D9EC;
  --blue-tint:#1F3442;
  --pink:#E88FA6;
  --pink-tint:#46242D;
  --shadow-1:0 1px 2px rgba(0,0,0,.25),0 2px 8px rgba(0,0,0,.25);
  --shadow-2:0 2px 6px rgba(0,0,0,.3),0 10px 28px rgba(0,0,0,.35);
  --shadow-3:0 6px 16px rgba(0,0,0,.4),0 24px 48px rgba(0,0,0,.45);
}

*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font:600 1rem/1.55 'Nunito',system-ui,sans-serif;
  min-height:100dvh;
  -webkit-tap-highlight-color:transparent;
  overscroll-behavior-y:none;
  touch-action:manipulation;
}
img{max-width:100%;display:block;}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer;}
h1,h2,h3{font-family:'Baloo 2','Nunito',system-ui,sans-serif;line-height:1.15;margin:0;text-wrap:balance;}
p{margin:0;}
:focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:6px;}
::selection{background:var(--brand-tint);}

/* ============ app frame ============ */
#app{
  max-width:560px;
  margin:0 auto;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
}
.screen{
  flex:1;
  padding:calc(var(--sat) + 16px) 20px calc(var(--nav-h) + var(--sab) + 24px);
  animation:screen-in var(--dur-view) var(--ease-out) both;
}
@keyframes screen-in{
  from{opacity:0;transform:translateY(10px);}
  to{opacity:1;transform:none;}
}

/* ============ bottom tab bar ============ */
.tabbar{
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:var(--z-sticky);
  display:flex;
  justify-content:center;
  background:color-mix(in srgb,var(--surface) 88%,transparent);
  -webkit-backdrop-filter:blur(14px);
  backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
  padding-bottom:var(--sab);
}
.tabbar-inner{display:flex;width:100%;max-width:560px;}
.tab{
  flex:1;
  text-decoration:none;
  min-height:var(--nav-h);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  color:var(--ink-2);
  font-size:.75rem;
  font-weight:800;
  transition:color var(--dur-state) var(--ease-out),transform var(--dur-press) var(--ease-out);
}
.tab:active{transform:scale(.94);}
.tab .ico{width:26px;height:26px;}
.tab[data-tab="home"][aria-current="page"]{color:var(--brand-deep);}
.tab[data-tab="breakfasts"][aria-current="page"]{color:var(--amber-deep);}
.tab[data-tab="mains"][aria-current="page"]{color:var(--green);}
[data-theme="dark"] .tab[data-tab="home"][aria-current="page"]{color:var(--brand);}
[data-theme="dark"] .tab[data-tab="mains"][aria-current="page"]{color:var(--green-mid);}

.ico{display:inline-block;width:22px;height:22px;flex:none;fill:currentColor;}

/* ============ home ============ */
.home-head{
  margin:4px -4px 0;
  padding:22px 20px 18px;
  border-radius:26px;
  background:linear-gradient(135deg,#FFE0C6 0%,#FFD1B8 45%,#FDDFA0 100%);
  border:1px solid #F5C29E;
  position:relative;
  overflow:hidden;
}
[data-theme="dark"] .home-head{
  background:linear-gradient(135deg,#4A2C1D 0%,#54301F 45%,#4E3A17 100%);
  border-color:#63482A;
}
.home-head::after{
  content:"";
  position:absolute;right:-26px;top:-26px;
  width:110px;height:110px;border-radius:50%;
  background:rgba(255,255,255,.35);
}
[data-theme="dark"] .home-head::after{background:rgba(255,255,255,.06);}
.brand-lockup{display:flex;align-items:center;gap:12px;position:relative;}
.brand-mark{width:56px;height:56px;flex:none;}
.home-head h1{font-size:1.9rem;font-weight:700;color:var(--ink);}
.home-head .sub{color:#8A4A2B;font-size:1rem;margin-top:2px;font-weight:700;}
[data-theme="dark"] .home-head .sub{color:#F2B590;}
.home-note{
  margin-top:18px;
  color:var(--ink-3);
  font-size:.88rem;
  display:flex;gap:8px;align-items:center;justify-content:center;
}
.home-note .ico{width:17px;height:17px;flex:none;}

/* today's idea card */
.today{
  margin-top:16px;
  display:flex;align-items:center;gap:14px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  padding:12px;
  box-shadow:var(--shadow-1);
}
.today .thumb{width:74px;height:74px;border-radius:16px;object-fit:cover;flex:none;}
.today .kicker{font-size:.78rem;font-weight:800;color:var(--amber-deep);}
.today .t{font-family:'Baloo 2';font-weight:700;font-size:1.08rem;line-height:1.2;color:var(--ink);}
.today .meta{display:flex;gap:6px;margin-top:5px;}
.today-body{flex:1;min-width:0;}
.today-go{
  width:48px;height:48px;flex:none;border-radius:var(--r-pill);
  background:var(--brand-deep);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-1);
  transition:transform var(--dur-press) var(--ease-out);
}
.today-go:active{transform:scale(.92);}
.today-go .ico{width:22px;height:22px;}

.resume{
  margin-top:16px;
  display:flex;align-items:center;gap:14px;
  width:100%;
  text-align:left;
  background:var(--brand-tint);
  border:1px solid color-mix(in srgb,var(--brand) 30%,transparent);
  border-radius:var(--r-card);
  padding:14px 16px;
  transition:transform var(--dur-press) var(--ease-out);
}
.resume:active{transform:scale(.98);}
.resume img{width:64px;height:64px;border-radius:12px;object-fit:cover;}
.resume .t{font-family:'Baloo 2';font-weight:700;font-size:1.05rem;color:var(--brand-text);}
.resume .s{font-size:.85rem;color:var(--ink-2);}

.home-sections{margin-top:18px;display:grid;gap:14px;}
.photocard{
  position:relative;
  display:flex;align-items:center;
  height:126px;width:100%;
  border-radius:var(--r-card);
  overflow:hidden;
  text-align:left;
  box-shadow:var(--shadow-2);
  isolation:isolate;
  transition:transform var(--dur-press) var(--ease-out),box-shadow var(--dur-state) var(--ease-out);
}
.photocard:active{transform:scale(.98);}
.photocard img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
}
.photocard .scrim{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(30,14,8,.72) 0%,rgba(30,14,8,.42) 52%,rgba(30,14,8,.05) 100%);
}
.photocard .pc-body{display:flex;flex-direction:column;gap:2px;padding:0 20px;flex:1;min-width:0;}
.photocard .t{font-family:'Baloo 2';font-weight:700;font-size:1.5rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.35);}
.photocard .s{color:#FFE4D3;font-size:.88rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.4);}
.photocard .go{color:#fff;width:24px;height:24px;margin-right:16px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));}

/* ============ recipe lists ============ */
.list-head{padding:8px 0 16px;display:flex;align-items:center;gap:13px;}
.list-head .disc{
  width:52px;height:52px;flex:none;border-radius:17px;
  display:flex;align-items:center;justify-content:center;color:#fff;
}
.list-head .disc .ico{width:29px;height:29px;}
.list-head.lh-b .disc{background:var(--amber);}
.list-head.lh-m .disc{background:var(--brand);}
.list-head h1{font-size:1.6rem;}
.list-head.lh-b h1{color:var(--amber-text);}
.list-head.lh-m h1{color:var(--brand-text);}
.list-head .sub{color:var(--ink-2);margin-top:2px;font-size:.95rem;}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:14px;}
.rcard{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  overflow:hidden;
  text-align:left;
  box-shadow:var(--shadow-1);
  display:flex;flex-direction:column;
  transition:transform var(--dur-press) var(--ease-out),box-shadow var(--dur-state) var(--ease-out);
  animation:card-in .45s var(--ease-out) both;
  animation-delay:calc(var(--i,0) * 40ms);
}
@keyframes card-in{
  from{opacity:0;transform:translateY(12px) scale(.98);}
  to{opacity:1;transform:none;}
}
.rcard:active{transform:scale(.97);}
.rcard .ph{aspect-ratio:4/3;width:100%;object-fit:cover;background:var(--surface-2);}
.rcard .body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:6px;flex:1;}
.rcard .name{font-family:'Baloo 2';font-weight:700;font-size:1.02rem;line-height:1.2;color:var(--ink);}
.rcard .meta{margin-top:auto;display:flex;gap:6px;flex-wrap:wrap;}
.chip{
  display:inline-flex;align-items:center;gap:4px;
  font-size:.75rem;font-weight:800;
  color:var(--ink-2);
  background:var(--surface-2);
  border-radius:var(--r-pill);
  padding:3px 9px;
  white-space:nowrap;
}
.chip .ico{width:13px;height:13px;}
.chip-time{background:var(--amber-tint);color:var(--amber-text);}
.chip-steps{background:var(--blue-tint);color:var(--blue-text);}
.chip-serves{background:var(--green-tint);color:var(--green-deep);}

/* ============ recipe detail ============ */
.detail-hero{position:relative;margin:0 -20px;}
.detail-hero img{width:100%;aspect-ratio:16/11;object-fit:cover;}
.detail-hero .back{
  position:absolute;top:calc(var(--sat) + 12px);left:16px;
  width:44px;height:44px;border-radius:var(--r-pill);
  background:color-mix(in srgb,var(--surface) 92%,transparent);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-2);
  transition:transform var(--dur-press) var(--ease-out);
}
.detail-hero .back:active{transform:scale(.92);}
.detail-body{padding-top:16px;}
.detail-body h1{font-size:1.55rem;}
.detail-body .sub{color:var(--ink-2);margin-top:4px;}
.detail-meta{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.detail-meta .chip{font-size:.85rem;padding:6px 12px;}
.ing-panel{
  margin-top:20px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  padding:16px 18px;
  box-shadow:var(--shadow-1);
}
.ing-panel h2{font-size:1.1rem;margin-bottom:8px;}
.ing-list{list-style:none;margin:0;padding:0;}
.ing-list li{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);}
.ing-list li:last-child{border-bottom:0;}
.ing-list .qty{margin-left:auto;font-weight:800;color:var(--brand-text);white-space:nowrap;}
.ing-check{
  width:26px;height:26px;flex:none;border-radius:8px;
  border:2px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  color:transparent;
  transition:background var(--dur-state) var(--ease-out),border-color var(--dur-state) var(--ease-out),color var(--dur-state) var(--ease-out);
}
li[data-done="1"] .ing-check{background:var(--green);border-color:var(--green);color:#fff;}
li[data-done="1"] .nm,li[data-done="1"] .qty{opacity:.45;}
.ing-list .nm{transition:opacity var(--dur-state) var(--ease-out);}
.ing-row{width:100%;display:flex;align-items:center;gap:10px;text-align:left;min-height:44px;}

.cta-bar{position:sticky;bottom:calc(var(--nav-h) + var(--sab) + 12px);margin-top:24px;}
.btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  min-height:56px;
  border-radius:var(--r-pill);
  font-family:'Baloo 2';font-weight:700;font-size:1.15rem;
  padding:0 26px;
  transition:transform var(--dur-press) var(--ease-out),background var(--dur-state) var(--ease-out);
}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--brand-deep);color:#fff;box-shadow:var(--shadow-2);width:100%;}
.btn-secondary{background:var(--surface);border:1.5px solid var(--line-strong);color:var(--ink);}
.btn .ico{width:22px;height:22px;}

/* ============ step player ============ */
.player{
  position:fixed;inset:0;z-index:var(--z-sticky);
  background:var(--bg);
  display:flex;flex-direction:column;
  max-width:560px;margin:0 auto;
}
.player-top{
  padding:calc(var(--sat) + 10px) 16px 8px;
  display:flex;align-items:center;gap:10px;
}
.player-top .name{
  font-family:'Baloo 2';font-weight:700;font-size:1.05rem;
  flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.icon-btn{
  width:44px;height:44px;flex:none;border-radius:var(--r-pill);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-2);
  background:var(--surface);
  border:1px solid var(--line);
  transition:transform var(--dur-press) var(--ease-out),background var(--dur-state) var(--ease-out),color var(--dur-state) var(--ease-out);
}
.icon-btn:active{transform:scale(.92);}
.icon-btn[aria-pressed="true"]{background:var(--brand-tint);color:var(--brand-text);border-color:color-mix(in srgb,var(--brand) 35%,transparent);}
.progress{height:6px;border-radius:99px;background:var(--surface-2);margin:4px 16px 0;overflow:hidden;}
.progress i{
  display:block;height:100%;border-radius:99px;
  background:linear-gradient(90deg,var(--amber) 0%,var(--brand) 70%);
  transform-origin:left;
  transition:transform 400ms var(--ease-in-out);
}

.player-scroll{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:12px 20px 8px;}
.stepno{
  font-size:.85rem;font-weight:800;
  display:flex;align-items:center;gap:8px;
}
.stepno .no{
  background:var(--brand-tint);color:var(--brand-text);
  border-radius:var(--r-pill);padding:3px 12px;
}
.stepno .safety-tag{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--amber-tint);color:var(--amber-text);
  border-radius:var(--r-pill);padding:3px 10px;font-size:.75rem;
}
.stepno .safety-tag .ico{width:14px;height:14px;}

.scene-wrap{
  margin-top:10px;
  background:var(--scene-bg);
  border:1px solid var(--scene-line);
  border-radius:var(--r-card);
  overflow:hidden;
  box-shadow:var(--shadow-1);
}
.scene-wrap svg{display:block;width:100%;height:auto;}

.step-text{
  margin-top:14px;
  font-size:1.3rem;font-weight:700;line-height:1.5;color:var(--ink);
  text-wrap:pretty;
}
.step-text .amt{
  display:inline-block;
  background:var(--brand-tint);color:var(--brand-text);
  border-radius:10px;
  padding:0 .45em;
  font-weight:900;
  white-space:nowrap;
}
.why{
  margin-top:12px;
  display:flex;gap:10px;align-items:flex-start;
  background:var(--amber-tint);
  border:1px solid color-mix(in srgb,var(--amber) 40%,transparent);
  border-radius:var(--r-panel);
  padding:12px 14px;
  color:var(--ink-2);font-size:.95rem;line-height:1.5;
}
.why .ico{width:20px;height:20px;flex:none;color:var(--amber-deep);margin-top:1px;}
.why b{color:var(--amber-text);}

.safety-card{
  margin-top:12px;
  background:var(--amber-tint);
  border:1.5px solid color-mix(in srgb,var(--amber) 55%,transparent);
  border-radius:var(--r-panel);
  padding:12px 14px;
  display:flex;gap:10px;align-items:flex-start;
  color:var(--amber-text);font-size:.95rem;line-height:1.5;font-weight:700;
}
.safety-card .ico{width:22px;height:22px;flex:none;margin-top:1px;}

/* timer */
.timer{
  margin-top:14px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  padding:14px 16px;
  display:flex;align-items:center;gap:14px;
  box-shadow:var(--shadow-1);
}
.timer .ring{width:64px;height:64px;flex:none;}
.timer .ring circle.track{stroke:var(--surface-2);}
.timer .ring circle.fill{
  stroke:var(--brand);
  transition:stroke-dashoffset 1s linear,stroke var(--dur-state) var(--ease-out);
}
.timer[data-state="done"] .ring circle.fill{stroke:var(--green);}
.timer .time{font-family:'Baloo 2';font-weight:700;font-size:1.7rem;font-variant-numeric:tabular-nums;letter-spacing:.01em;}
.timer .lbl{font-size:.82rem;color:var(--ink-2);font-weight:700;}
.timer .actions{margin-left:auto;display:flex;gap:8px;}
.timer .go{
  min-width:64px;height:48px;border-radius:var(--r-pill);
  background:var(--brand-deep);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Baloo 2';font-weight:700;
  transition:transform var(--dur-press) var(--ease-out),background var(--dur-state) var(--ease-out);
}
.timer .go:active{transform:scale(.94);}
.timer[data-state="done"] .go{background:var(--green);}
.timer .go .ico{width:22px;height:22px;}
@keyframes timer-done-pulse{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.04);}
}
.timer[data-state="done"]{animation:timer-done-pulse .9s var(--ease-in-out) 3;}

/* player bottom controls */
.player-bottom{padding:8px 16px calc(var(--sab) + 14px);}
.scrubber{display:flex;justify-content:center;gap:0;margin-bottom:10px;flex-wrap:wrap;}
.scrub-dot{
  padding:10px 3px;
  display:flex;align-items:center;
}
.scrub-dot i{
  display:block;width:8px;height:8px;border-radius:99px;
  background:var(--line-strong);
  transition:width var(--dur-state) var(--ease-out),background var(--dur-state) var(--ease-out);
}
.scrub-dot[data-done="1"] i{background:var(--brand);opacity:.45;}
.scrub-dot[aria-current="step"] i{width:22px;background:var(--brand-deep);opacity:1;}
[data-theme="dark"] .scrub-dot[aria-current="step"] i{background:var(--brand);}
.step-nav{display:flex;gap:10px;}
.step-nav .btn{flex:1;}
.step-nav .btn-back{flex:0 0 auto;width:76px;}

/* ============ ingredients bottom sheet ============ */
dialog.sheet{
  border:0;padding:0;margin:0 auto;
  width:100%;max-width:560px;
  max-height:78dvh;
  background:var(--surface);
  color:var(--ink);
  border-radius:22px 22px 0 0;
  box-shadow:var(--shadow-3);
  position:fixed;bottom:0;top:auto;
  z-index:var(--z-sheet);
  transform:translateY(100%);
  transition:transform 320ms var(--ease-drawer),overlay 320ms allow-discrete,display 320ms allow-discrete;
}
dialog.sheet[open]{transform:translateY(0);}
@starting-style{dialog.sheet[open]{transform:translateY(100%);}}
dialog.sheet::backdrop{
  background:rgba(30,15,10,.45);
  opacity:1;
  transition:opacity 320ms var(--ease-out),overlay 320ms allow-discrete,display 320ms allow-discrete;
}
@starting-style{dialog.sheet[open]::backdrop{opacity:0;}}
.sheet-grip{width:44px;height:5px;border-radius:99px;background:var(--line-strong);margin:10px auto 4px;}
.sheet-inner{padding:6px 20px calc(var(--sab) + 20px);overflow-y:auto;max-height:calc(78dvh - 30px);}
.sheet-inner h2{font-size:1.2rem;padding:8px 0;}

/* ============ done screen ============ */
.done-hero{margin:0 -20px;position:relative;}
.done-hero img{width:100%;aspect-ratio:16/11;object-fit:cover;}
.done-body{text-align:center;padding-top:18px;}
.done-body h1{font-size:1.7rem;}
.done-body .sub{color:var(--ink-2);margin-top:4px;}
.plate-check{
  margin-top:18px;text-align:left;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-card);
  padding:16px 18px;
  box-shadow:var(--shadow-1);
}
.plate-check h2{font-size:1.1rem;margin-bottom:10px;}
.plate-check ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;}
.plate-check li{display:flex;gap:10px;align-items:flex-start;color:var(--ink-2);line-height:1.45;font-size:.97rem;}
.plate-check li .ico{width:20px;height:20px;flex:none;color:var(--green);margin-top:2px;}
.plate-check li b{color:var(--ink);}
.done-actions{display:grid;gap:10px;margin-top:20px;}
.confetti-burst{position:absolute;inset:0;pointer-events:none;overflow:hidden;}

/* ============ toast ============ */
.toast{
  position:fixed;left:50%;bottom:calc(var(--nav-h) + var(--sab) + 20px);
  transform:translateX(-50%) translateY(0);
  z-index:var(--z-toast);
  background:var(--ink);color:var(--bg);
  font-weight:800;font-size:.9rem;
  border-radius:var(--r-pill);
  padding:10px 18px;
  box-shadow:var(--shadow-2);
  opacity:1;
  transition:opacity 300ms var(--ease-out),transform 300ms var(--ease-out);
}
.toast[data-hide]{opacity:0;transform:translateX(-50%) translateY(8px);}

/* ============ reduced motion ============ */
@media (prefers-reduced-motion:reduce){
  .screen,.rcard{animation:none;}
  .timer[data-state="done"]{animation:none;}
  dialog.sheet,dialog.sheet::backdrop{transition-duration:1ms;}
  .progress i{transition-duration:1ms;}
  /* scenes: hold the "money frame" — engine sets paused + negative delay */
  .scene-wrap [style*="--sd"]{animation-play-state:paused !important;}
}

/* hover-capable pointers only */
@media (hover:hover) and (pointer:fine){
  .rcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);}
  .jump:hover{box-shadow:var(--shadow-2);}
  .btn-primary:hover{background:color-mix(in srgb,var(--brand-deep) 88%,#000 12%);}
}
