:root{
  --bg:#f8f4ee; --ink:#0d0d0d; --teal:#0d0d0d; --teal-bright:#0d0d0d;
  --gold:#ffdd00; --yellow-d:#ffd000; --card:#ffffff; --muted:#6b6b6b; --line:#e7ded0;
  --teal-tint:#f1ece3; --danger:#e2483d;
  --shadow:0 1px 2px rgba(0,0,0,.04),0 8px 24px rgba(0,0,0,.06);
  --radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--ink);
  line-height:1.55;-webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}
a{color:var(--teal-bright);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:'DM Sans',sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.12}
h1{font-size:clamp(26px,5vw,38px);font-weight:700;margin-bottom:12px}
h2{font-size:clamp(20px,4vw,26px);font-weight:600;margin-bottom:10px}
h3{font-size:18px;font-weight:600;margin-bottom:6px}
.eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#9a9a9a;font-weight:700;margin-bottom:8px}
.muted{color:var(--muted)}
.lead{color:var(--muted);font-size:16px;margin-bottom:22px;max-width:60ch}

/* Header */
.site-head{position:sticky;top:0;z-index:30;background:rgba(247,243,236,.9);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.head-inner{max-width:1040px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.brand{font-family:'Caveat',cursive;font-weight:700;font-size:28px;color:var(--ink);line-height:1}
.brand span{color:var(--ink)}
.brand:hover{text-decoration:none}
.mainnav{margin-left:auto;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.mainnav a{color:var(--ink);font-weight:500;font-size:14px;padding:7px 11px;border-radius:9px}
.mainnav a:hover{background:var(--teal-tint);text-decoration:none}
.mainnav a.on{background:var(--teal);color:#fff}
.mainnav a.adminlink{color:var(--gold);font-weight:600}
.mainnav a.logout{color:var(--muted)}

/* Page */
.page{max-width:1040px;margin:0 auto;padding:32px 20px 60px;width:100%;flex:1 0 auto}
.flash{background:var(--teal-tint);border-left:3px solid var(--gold);padding:12px 16px;
  border-radius:10px;margin-bottom:22px;font-size:15px}

/* Cards / grid */
.grid{display:grid;gap:16px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:760px){.grid.cols-2,.grid.cols-3{grid-template-columns:1fr}}
.card{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow)}
.card h3{margin-bottom:8px}
.card p{font-size:15px;color:var(--muted)}
.card-link{display:block;color:inherit;position:relative}
.card-link:hover{text-decoration:none;border-color:var(--teal-bright)}
.tag-done{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;gap:4px;
  background:var(--teal);color:#fff;font-size:11px;font-weight:600;letter-spacing:.03em;
  padding:3px 10px 3px 8px;border-radius:999px}
.tag-done::before{content:"✓";font-weight:700}
.tile-emoji{font-size:26px;display:block;margin-bottom:10px}
/* Flat-Icon Chip neben der Überschrift */
.card-head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.card-head h3{margin:0}
.tile-icon{flex:0 0 auto;width:42px;height:42px;border-radius:11px;
  background:var(--teal-tint);color:var(--teal);display:inline-flex;
  align-items:center;justify-content:center}
.tile-icon svg{width:23px;height:23px;display:block}
.tile-icon.danger{background:#F6E4E0;color:var(--danger)}
.card-link .card-head{margin-bottom:8px}

/* Buttons */
.btn{display:inline-block;font:inherit;font-weight:700;cursor:pointer;border-radius:999px;
  padding:12px 22px;border:1.5px solid transparent;transition:background .15s,border-color .15s}
.btn:hover{text-decoration:none}
.btn-primary{background:#64933f;color:#fff}
.btn-primary:hover{background:#577f37}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--teal-bright);color:var(--teal-bright)}
.btn-danger{background:#b3261e;color:#fff}
.btn-danger:hover{background:#8f1d17}
.btn-sm{padding:8px 14px;font-size:14px}
.btn-danger{background:transparent;color:var(--danger);border-color:var(--line)}

/* Forms */
.form{max-width:460px}
.form.wide{max-width:680px}
.field{margin-bottom:16px}
label.lbl{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
input[type=text],input[type=email],input[type=password],input[type=date],textarea,select{
  width:100%;font:inherit;padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;
  background:var(--card);color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--teal)}
textarea{min-height:120px;resize:vertical}
.req{color:var(--danger)}

/* Auth box */
.authbox{max-width:420px;margin:40px auto;background:var(--card);border:1.5px solid var(--line);
  border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.err{background:#fbeae8;color:var(--danger);padding:11px 14px;border-radius:10px;font-size:14px;margin-bottom:14px}

/* Checkliste */
.phase{margin-bottom:28px}
.phase h2{display:flex;align-items:baseline;gap:10px}
.phase h2 small{font-size:13px;color:var(--muted);font-weight:400}
.cl-item{background:var(--card);border:1.5px solid var(--line);border-radius:12px;
  padding:14px 16px;margin-bottom:10px;display:flex;gap:13px;align-items:flex-start}
.cl-item.done{opacity:.6}
.cl-item .chk{width:22px;height:22px;flex-shrink:0;margin-top:2px;accent-color:var(--teal);cursor:pointer}
.cl-item .body{flex:1}
.cl-item .t{font-weight:600}
.cl-item.done .t{text-decoration:line-through}
.cl-item .d{font-size:14px;color:var(--muted);margin-top:3px}
.cl-note{margin-top:8px;font-size:14px;padding:8px 10px;min-height:auto}
.progress-wrap{background:var(--card);border:1.5px solid var(--line);border-radius:12px;padding:16px;margin-bottom:26px}
.bar{height:10px;background:var(--teal-tint);border-radius:6px;overflow:hidden}
.bar > span{display:block;height:100%;background:var(--teal);transition:width .4s}

/* Tabellen (Admin) */
table.tbl{width:100%;border-collapse:collapse;background:var(--card);border-radius:12px;overflow:hidden;border:1.5px solid var(--line)}
table.tbl th,table.tbl td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
table.tbl th{background:var(--teal-tint);font-weight:600}
table.tbl tr:last-child td{border-bottom:0}

/* Info-Artikel */
.article{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);max-width:760px}
.article h2{margin-bottom:6px}
.article .stand{font-size:13px;color:var(--muted);margin-bottom:16px}
.article p{margin-bottom:12px}
.linklist{list-style:none;margin-top:14px}
.linklist li{padding:9px 0;border-bottom:1px solid var(--line)}
.aff{font-size:11px;background:var(--gold);color:#3a2a08;padding:1px 6px;border-radius:6px;margin-left:6px;font-weight:600}

/* Disclaimer box */
.disclaimer{font-size:13px;color:var(--muted);background:var(--card);border:1px solid var(--line);
  border-radius:12px;padding:14px;margin-top:18px}

/* Output box (generierter Brief) */
.output{background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:22px;
  white-space:pre-wrap;font-family:'Inter',sans-serif;font-size:15px;line-height:1.6}

/* Footer */
.site-foot{border-top:1px solid var(--line);background:#fff;margin-top:auto;flex-shrink:0}
.foot-inner{max-width:1040px;margin:0 auto;padding:24px 20px}
.foot-inner .disc{font-size:12px;color:var(--muted);max-width:80ch;margin-bottom:8px}
.foot-inner .meta{font-size:13px;color:var(--muted)}

@media print{.site-head,.site-foot,.noprint{display:none!important}.page{padding:0}}

/* ===== Planner ===== */
.planner-shell{max-width:680px;margin:0 auto}
.topbar{position:sticky;top:62px;z-index:10;background:linear-gradient(var(--bg) 70%,rgba(247,243,236,0));padding:14px 0 18px}
.route{position:relative;height:34px;margin:0 6px}
.route-line{position:absolute;top:50%;left:0;right:0;height:2px;transform:translateY(-50%);
  background:repeating-linear-gradient(90deg,var(--line) 0 7px,transparent 7px 14px)}
.route-fill{position:absolute;top:50%;left:0;height:2px;transform:translateY(-50%);background:var(--teal);width:0;transition:width .5s cubic-bezier(.4,0,.2,1)}
.route-cap{position:absolute;top:50%;transform:translate(-50%,-50%);width:9px;height:9px;border-radius:50%;background:var(--teal)}
.route-cap.start{left:0}
.route-cap.end{right:0;left:auto;transform:translate(50%,-50%);background:var(--card);border:2px solid var(--line)}
.route-cap.end.reached{background:var(--gold);border-color:var(--gold)}
.plane{position:absolute;top:50%;left:0;transform:translate(-50%,-50%);transition:left .5s cubic-bezier(.4,0,.2,1);color:var(--teal);line-height:0;filter:drop-shadow(0 2px 3px rgba(20,48,46,.18))}
.plane svg{display:block}
.route-labels{display:flex;justify-content:space-between;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:8px;font-weight:600}
.saved{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--teal-bright);font-weight:500;opacity:0;transition:opacity .3s;margin-top:4px}
.saved.show{opacity:1}
.saved svg{width:13px;height:13px}
.step{display:none;animation:rise .45s cubic-bezier(.2,.7,.2,1)}
.step.active{display:block}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.q{font-weight:600;font-size:16px;margin-bottom:12px;display:block}
.q .opt-note{font-weight:400;color:var(--muted);font-size:14px;display:block;margin-top:2px}
.opts{display:grid;gap:10px}
.opts.cols-2{grid-template-columns:repeat(2,1fr)}
.opts.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:480px){.opts.cols-3{grid-template-columns:repeat(2,1fr)}}
.opt{appearance:none;cursor:pointer;text-align:left;background:var(--card);border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;font:inherit;color:var(--ink);display:flex;align-items:center;gap:12px;transition:border-color .15s,background .15s,transform .08s;width:100%}
.opt:hover{border-color:var(--teal-bright)}
.opt:active{transform:scale(.99)}
.opt .emoji{font-size:20px;line-height:1}
.opt .label{font-weight:500}
.opt .sub{display:block;font-size:13px;color:var(--muted);font-weight:400}
.opt.sel{border-color:var(--teal);background:var(--teal-tint);box-shadow:inset 0 0 0 1px var(--teal)}
.opt.center{justify-content:center;text-align:center;flex-direction:column;gap:6px;padding:18px 12px}
.stepper{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card)}
.stepper button{width:46px;height:46px;border:0;background:transparent;font-size:22px;cursor:pointer;color:var(--teal);font-family:inherit}
.stepper button:hover{background:var(--teal-tint)}
.stepper span{min-width:48px;text-align:center;font-weight:600;font-size:17px}
.ages{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.age-pill{display:flex;align-items:center;gap:8px;background:var(--teal-tint);border:1px solid var(--line);border-radius:10px;padding:6px 8px 6px 12px;font-size:14px}
.age-pill select{border:0;background:transparent;font:inherit;color:var(--ink);padding:2px;width:auto}
.help{font-size:13px;color:var(--muted);margin-top:10px;padding:11px 13px;background:var(--teal-tint);border-radius:10px;border-left:3px solid var(--gold)}
.help.hidden,.field.hidden{display:none}
.help strong{color:var(--ink)}
.nav{display:flex;gap:12px;margin-top:30px}
.nav .btn-primary{flex:1}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ============ Begleiter-Auswahl ============ */
.pick-wrap{max-width:760px;margin:0 auto;text-align:center}
.pick-wrap .lead{margin:0 auto 28px}
.pick-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;border:0;padding:0;margin:0}
.pick-card{display:flex;flex-direction:column;align-items:center;gap:6px;
  background:var(--card);border:2px solid var(--line);border-radius:var(--radius);
  padding:26px 20px 22px;cursor:pointer;font:inherit;color:var(--ink);
  transition:border-color .18s,transform .18s,box-shadow .18s}
.pick-card:hover{border-color:var(--teal);transform:translateY(-3px);box-shadow:var(--shadow)}
.pick-card:focus-visible{outline:3px solid var(--teal-bright);outline-offset:2px}
.pick-avatar{width:128px;height:128px;border-radius:50%;overflow:hidden;
  background:var(--teal-tint);display:flex;align-items:center;justify-content:center;
  border:3px solid var(--gold);margin-bottom:8px}
.pick-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.pick-fallback{font-size:62px;line-height:1}
.pick-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:22px}
.pick-sub{color:var(--muted);font-size:14px;max-width:24ch}
.pick-choose{margin-top:12px;background:var(--teal);color:#fff;font-weight:600;
  font-size:14px;padding:9px 22px;border-radius:10px}
.pick-card:hover .pick-choose{background:var(--teal-bright)}
@media(max-width:560px){.pick-grid{grid-template-columns:1fr}.pick-avatar{width:104px;height:104px}}

/* ============ Floating-Begleiter ============ */
.assi{position:fixed;right:18px;bottom:18px;z-index:50;display:flex;flex-direction:column;
  align-items:flex-end;gap:10px;max-width:min(340px,calc(100vw - 32px))}
.assi-avatar{position:relative;width:66px;height:66px;border-radius:50%;border:3px solid var(--gold);
  background:var(--teal-tint);padding:0;overflow:visible;cursor:pointer;flex:0 0 auto;
  box-shadow:var(--shadow);transition:transform .18s}
.assi-avatar:hover{transform:scale(1.06)}
.assi-avatar:focus-visible{outline:3px solid var(--teal-bright);outline-offset:2px}
.assi-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.assi-fallback{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:32px}
.assi-dot{position:absolute;top:2px;right:2px;width:14px;height:14px;border-radius:50%;
  background:var(--gold);border:2px solid var(--bg);opacity:0;transform:scale(.4);
  transition:opacity .2s,transform .2s}
.assi-dot.on{opacity:1;transform:scale(1);animation:assiPulse 1.6s infinite}
@keyframes assiPulse{0%,100%{box-shadow:0 0 0 0 rgba(224,165,60,.5)}50%{box-shadow:0 0 0 7px rgba(224,165,60,0)}}
.assi-bubble{position:relative;background:var(--card);border:1px solid var(--line);
  border-radius:16px;border-bottom-right-radius:5px;padding:13px 16px 14px;
  box-shadow:var(--shadow);max-width:100%;opacity:0;transform:translateY(8px) scale(.96);
  transform-origin:bottom right;pointer-events:none;transition:opacity .2s,transform .2s}
.assi-bubble.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.assi-bubble::after{content:"";position:absolute;right:24px;bottom:-7px;width:14px;height:14px;
  background:var(--card);border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  transform:rotate(45deg)}
.assi-name{display:block;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;
  font-size:13px;color:var(--teal);margin-bottom:3px}
.assi-text{display:block;font-size:14.5px;line-height:1.45;color:var(--ink)}
.assi-close{position:absolute;top:6px;right:9px;background:none;border:0;color:var(--muted);
  font-size:18px;line-height:1;cursor:pointer;padding:2px}
.assi-close:hover{color:var(--ink)}
@media(max-width:560px){
  .assi{right:12px;bottom:12px;max-width:calc(100vw - 24px)}
  .assi-avatar{width:56px;height:56px}
  .assi-text{font-size:14px}
}
@media print{.assi{display:none!important}}

/* ============ Intro / Vorstellungsvideo ============ */
.intro-wrap{max-width:760px;margin:0 auto;text-align:center}
.intro-video{position:relative;width:100%;aspect-ratio:16/9;margin:22px 0 26px;
  background:var(--ink);border-radius:var(--radius);overflow:hidden;
  border:3px solid var(--gold);box-shadow:var(--shadow)}
.intro-video video{width:100%;height:100%;object-fit:cover;display:block;background:var(--ink)}
.intro-play{position:absolute;inset:0;margin:auto;width:78px;height:78px;border-radius:50%;
  border:0;background:rgba(255,255,255,.92);color:var(--teal);font-size:30px;line-height:1;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  box-shadow:0 6px 24px rgba(0,0,0,.35);transition:transform .15s,background .15s}
.intro-play:hover{transform:scale(1.08);background:#fff}
.intro-play:focus-visible{outline:3px solid #fff;outline-offset:3px}
.intro-video.no-video{aspect-ratio:auto;background:var(--teal-tint);border-color:var(--line)}
.intro-fallback{display:flex;flex-direction:column;align-items:center;gap:14px;padding:32px 22px;text-align:center}
.intro-fallback[hidden]{display:none}
.intro-ava{width:118px;height:118px;border-radius:50%;overflow:hidden;border:3px solid var(--gold);
  background:#fff;display:flex;align-items:center;justify-content:center}
.intro-ava img{width:100%;height:100%;object-fit:cover}
.intro-ava-fb{font-size:58px}
.intro-speech{max-width:46ch;color:var(--ink);font-size:16px;line-height:1.55}
.intro-next{display:flex;flex-direction:column;align-items:center;gap:14px}
.intro-name-input{width:100%;max-width:340px;padding:13px 16px;font-size:16px;
  border:2px solid var(--line);border-radius:12px;background:var(--card);color:var(--ink);
  text-align:center;font-family:inherit;transition:border-color .15s}
.intro-name-input:focus{outline:none;border-color:var(--teal)}
.intro-name-input::placeholder{color:var(--muted)}
.btn-lg{font-size:17px;padding:14px 34px;border-radius:12px}
@media(max-width:560px){.intro-play{width:64px;height:64px;font-size:26px}.intro-speech{font-size:15px}}

/* ---- Begleiter: Tippen + Bewegung ---- */
.assi-typing{display:inline-flex;gap:5px;align-items:center;padding:4px 0 2px}
.assi-typing[hidden]{display:none}
.assi.linked .assi-bubble{cursor:pointer}
.assi.linked .assi-bubble:hover{border-color:var(--teal)}
.assi-typing i{width:7px;height:7px;border-radius:50%;background:var(--muted);opacity:.45;
  animation:assiType 1s infinite}
.assi-typing i:nth-child(2){animation-delay:.15s}
.assi-typing i:nth-child(3){animation-delay:.3s}
@keyframes assiType{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}
.assi.nudge .assi-avatar{animation:assiNudge .6s ease}
@keyframes assiNudge{0%,100%{transform:none}25%{transform:translateY(-5px) rotate(-4deg)}60%{transform:translateY(0) rotate(3deg)}}

/* ============ Hero mit Hintergrund-Slideshow (Dashboard) ============ */
.hero{position:relative;border-radius:var(--radius);overflow:hidden;margin:0 0 30px;
  box-shadow:var(--shadow);background:var(--ink);min-height:300px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.hero-slide.on{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;display:block}
.hero-shade{position:absolute;inset:0;z-index:1;
  background:linear-gradient(120deg, rgba(10,30,28,.86) 0%, rgba(10,30,28,.58) 50%, rgba(10,30,28,.34) 100%)}
.hero-content{position:relative;z-index:2;padding:28px 26px 30px}
.hero-content .eyebrow{color:var(--gold)}
.hero-content h1{color:#fff;margin-bottom:18px}
.hero-content .grid{margin:0}
@media(max-width:560px){.hero-content{padding:22px 16px 24px}}

/* ============ Statistik / Haushaltsbuch ============ */
.stat-card{display:flex;flex-direction:column}
.stat-big{font-size:26px;font-weight:700;color:var(--ink);font-family:'Bricolage Grotesque',sans-serif;margin:6px 0 8px}
.donut-wrap{position:relative;width:150px;height:150px;margin:6px auto 8px}
.donut-wrap.small{width:120px;height:120px}
.donut-wrap svg{display:block;width:100%;height:100%}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;line-height:1.15}
.donut-center strong{font-size:20px;color:var(--ink);font-family:'Bricolage Grotesque',sans-serif}
.donut-center .muted{font-size:12px}
.ring-wrap{width:120px;height:120px;margin:6px auto 8px}
.ring-wrap svg{display:block;width:100%;height:100%}
.ring-txt{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:22px;fill:var(--ink)}
.legend{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:7px}
.legend li{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink)}
.legend-name{flex:1}
.legend-val{color:var(--muted);font-size:13px;white-space:nowrap}

/* Haushaltsbuch (modern) */
.hh-card{padding:22px 22px 20px}
.hh-h{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;margin-bottom:16px}
.hh-list{display:flex;flex-direction:column;gap:8px}
.hh-dot{width:11px;height:11px;border-radius:4px;flex:0 0 auto;display:inline-block}
.profswitch{display:inline-flex;align-items:center;margin:0}
.profswitch select{font:inherit;padding:5px 9px;border:1px solid var(--line);border-radius:8px;background:var(--card);color:var(--ink);max-width:170px;cursor:pointer}
.hh-row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);box-shadow:0 1px 3px rgba(20,48,46,.05);
  border-radius:12px;padding:10px 12px;transition:border-color .15s,background .15s}
.hh-row:hover{border-color:var(--teal-bright)}
.hh-label{flex:1;min-width:0;font-size:15px;color:var(--ink);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.hh-badge{font-size:10px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;color:var(--teal-bright);
  background:var(--teal-tint);padding:2px 7px;border-radius:999px}
.hh-labelinput{flex:1;min-width:0;font:inherit;font-size:15px;padding:8px 10px;border:1px solid var(--line);
  border-radius:9px;background:var(--card);color:var(--ink)}
.hh-labelinput:focus{outline:none;border-color:var(--teal)}
.hh-input{display:inline-flex;align-items:center;gap:6px;flex:0 0 auto}
.hh-input input{width:96px;text-align:right;font:inherit;padding:8px 10px;border:1px solid var(--line);
  border-radius:9px;background:var(--card);color:var(--ink);transition:border-color .15s,box-shadow .15s}
.hh-input input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,90,85,.12)}
.hh-cur{color:var(--muted);font-size:14px}
.hh-del{flex:0 0 auto;width:30px;height:30px;border:0;border-radius:8px;background:transparent;color:var(--muted);
  font-size:20px;line-height:1;cursor:pointer;transition:background .15s,color .15s}
.hh-del:hover{background:#F6E4E0;color:var(--danger)}
.hh-add{margin-top:4px;align-self:flex-start;background:transparent;border:1.5px dashed var(--line);
  color:var(--teal-bright);font:inherit;font-weight:600;font-size:14px;padding:9px 14px;border-radius:11px;
  cursor:pointer;transition:border-color .15s,background .15s}
.hh-add:hover{border-color:var(--teal);background:var(--teal-tint)}
.hh-total{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:14px;
  border-top:1.5px solid var(--line);font-size:16px;color:var(--ink)}
.hh-total strong{font-size:22px;font-family:'Bricolage Grotesque',sans-serif}
.hh-note{font-size:12.5px;margin-top:10px}
.hh-cover{text-align:center;margin-top:6px}
.hh-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.sk-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.sk-item{display:flex;justify-content:space-between;align-items:center;background:var(--teal-tint);
  border-radius:10px;padding:11px 13px;font-size:14px;gap:10px}
.sk-item strong{font-family:'Bricolage Grotesque',sans-serif}
.sk-item.sk-edit{background:var(--bg);border:1px solid var(--line)}
.sk-item.sk-edit label{color:var(--ink)}
@media(max-width:760px){.sk-grid{grid-template-columns:1fr}}
@media(max-width:480px){.hh-input input{width:84px}}
