/* ============================================================
   vamilio APP — Cockpit-Design (Redesign nach Demo)
   Scope: .vamilio-app  ·  Fonts: Outfit/Manrope (Theme),
   gemappt auf 'Fraunces'/'Bricolage Grotesque'.
   ============================================================ */
@font-face{font-family:'Fraunces';src:url('../fonts/Outfit-var.woff2') format('woff2-variations');font-weight:100 900;font-style:normal;font-display:swap;}
@font-face{font-family:'Bricolage Grotesque';src:url('../fonts/Manrope-var.woff2') format('woff2-variations');font-weight:200 800;font-style:normal;font-display:swap;}

.vamilio-app, body.vamilio-app-page{
--plum:#513064; --plum-deep:#2E1A39; --plum-mid:#6E4488; --orchid:#8757A3;
    --lilac:#C9B6DA; --lilac-soft:#E7DCEF;
    --cream:#F6F1EA; --cream-deep:#EFE7DC; --paper:#FFFDFA;
    --ink:#241B2B; --muted:#7C7185;
    --gold:#E0A86B; --sage:#9DB89A; --blush:#E8A0A8;
    --line:rgba(46,26,57,.10);
    --r-lg:34px; --r-md:24px; --r-sm:16px;
}
.vamilio-app *{box-sizing:border-box;}
.vamilio-app a{color:inherit;text-decoration:none;cursor:pointer;}
.vamilio-app button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;}
.vamilio-app img{display:block;}
.vamilio-app svg{display:inline-block;}

  /* Selbst-gehostete Marken-Schriften (kein Google). Outfit = Display, Manrope = Text.
     Die bisherigen Namen 'Fraunces'/'Bricolage Grotesque' zeigen jetzt auf Outfit/Manrope,
     damit alle Stilregeln ohne Umbau greifen. */
        
  
    
    /* warme Aura + Körnung */
  .vamilio-app::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
    background:
      radial-gradient(60% 50% at 82% -5%, rgba(135,87,163,.20), transparent 60%),
      radial-gradient(50% 45% at -5% 12%, rgba(224,168,107,.16), transparent 55%),
      radial-gradient(55% 50% at 50% 110%, rgba(201,182,218,.22), transparent 60%);}
  .vamilio-app::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");}
  .vamilio-app h1, .vamilio-app h2, .vamilio-app h3, .vamilio-app h4{font-family:'Fraunces',serif;letter-spacing:-.022em;line-height:1.02;}
  .vamilio-app a{color:inherit;text-decoration:none;}
  .vamilio-app button{font-family:inherit;cursor:pointer;border:0;background:none;}
  .vamilio-app .serif{font-family:'Fraunces',serif;}
  .vamilio-app .ital{font-style:italic;}

  /* screens */
  .vamilio-app .screen{display:none;}
  .vamilio-app .screen.is-active{display:block;}
  .vamilio-app .screen.auth.is-active{display:flex;min-height:100vh;}

  /* ============ AUTH ============ */
  .vamilio-app .auth{align-items:stretch;}
  .vamilio-app .auth-visual{flex:1.05;background:linear-gradient(155deg,var(--plum-deep),var(--plum) 60%,var(--orchid));
    color:#fff;padding:64px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;}
  .vamilio-app .auth-visual::after{content:"";position:absolute;width:560px;height:560px;border-radius:50%;
    background:radial-gradient(circle,rgba(255,255,255,.13),transparent 70%);right:-180px;top:-140px;}
  .vamilio-app .auth-brand img{height:38px;}
  .vamilio-app .auth-visual h1{font-size:clamp(38px,4.4vw,62px);font-weight:900;position:relative;z-index:2;}
  .vamilio-app .auth-visual h1 em{font-style:italic;color:var(--lilac);}
  .vamilio-app .auth-visual p{opacity:.84;max-width:400px;margin-top:20px;font-size:17px;position:relative;z-index:2;}
  .vamilio-app .auth-bullets{list-style:none;position:relative;z-index:2;display:flex;flex-direction:column;gap:14px;}
  .vamilio-app .auth-bullets li{display:flex;align-items:center;gap:13px;font-weight:600;font-size:15.5px;}
  .vamilio-app .auth-bullets .bic{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.15);display:grid;place-items:center;}
  .vamilio-app .auth-bullets .bic svg{width:16px;height:16px;}
  .vamilio-app .auth-form-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:44px;background:var(--paper);}
  .vamilio-app .auth-card{width:100%;max-width:400px;}
  .vamilio-app .auth-card h2{font-size:36px;font-weight:600;margin-bottom:6px;}
  .vamilio-app .auth-card .sub{color:var(--muted);margin-bottom:30px;}
  .vamilio-app .field{margin-bottom:17px;}
  .vamilio-app .field label{display:block;font-size:13px;font-weight:600;margin-bottom:7px;}
  .vamilio-app .field input{width:100%;border:1.6px solid var(--line);border-radius:14px;padding:14px 16px;font-size:16px;font-family:inherit;background:var(--cream);color:var(--ink);transition:.16s;}
  .vamilio-app .field input:focus{outline:none;border-color:var(--orchid);background:#fff;}
  .vamilio-app .pw-wrap{position:relative;}
  .vamilio-app .pw-wrap input{padding-right:50px;width:100%;}
  .vamilio-app .pw-toggle{position:absolute;top:50%;right:8px;transform:translateY(-50%);width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:0;background:transparent;cursor:pointer;padding:0;color:var(--muted);}
  .vamilio-app .pw-toggle:hover{color:var(--plum);}
  .vamilio-app .pw-toggle svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
  .vamilio-app .pw-toggle .pw-slash{opacity:0;}
  .vamilio-app .pw-toggle.is-on .pw-slash{opacity:1;}
  .vamilio-app .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:'Bricolage Grotesque';font-weight:700;font-size:15px;padding:15px 26px;border-radius:40px;transition:.18s;}
  .vamilio-app .btn-primary{background:var(--plum);color:#fff;box-shadow:0 12px 26px rgba(81,48,100,.30);}
  .vamilio-app .btn-primary:hover{background:var(--plum-deep);transform:translateY(-1px);}
  .vamilio-app .auth-switch{text-align:center;margin-top:22px;color:var(--muted);font-size:14px;}
  .vamilio-app .auth-switch a{color:var(--orchid);font-weight:700;}
  .vamilio-app .auth-legal{font-size:12px;color:var(--muted);margin-top:20px;text-align:center;}

  /* ============ APP / HEADER NAV ============ */
  .vamilio-app .wrap{max-width:1240px;margin:0 auto;padding:0 28px;}

  .vamilio-app .topnav{position:sticky;top:18px;z-index:60;margin:18px auto 0;max-width:1240px;padding:0 28px;}
  .vamilio-app .topnav-inner{position:relative;z-index:9000;background:rgba(255,253,250,.78);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.6);box-shadow:0 14px 40px rgba(46,26,57,.10);
    border-radius:50px;padding:11px 12px 11px 22px;display:flex;align-items:center;gap:18px;}
  .vamilio-app .nav-logo img{height:30px;display:block;}
  .vamilio-app .nav-links{display:flex;gap:3px;margin-left:8px;flex:1;}
  .vamilio-app .nav-link{display:flex;align-items:center;gap:8px;padding:10px 15px;border-radius:30px;font-weight:600;font-size:14.5px;color:var(--muted);transition:.15s;white-space:nowrap;}
  .vamilio-app .nav-link svg{width:17px;height:17px;}
  .vamilio-app .nav-link:hover{color:var(--ink);background:rgba(81,48,100,.07);}
  .vamilio-app .nav-link.is-active{color:#fff;background:var(--plum);}
  .vamilio-app .nav-right{display:flex;align-items:center;gap:10px;}
  .vamilio-app .nav-plan{font-family:'Bricolage Grotesque';font-weight:700;font-size:11px;letter-spacing:.08em;color:var(--plum);background:var(--lilac-soft);padding:7px 13px;border-radius:30px;text-transform:uppercase;}
  .vamilio-app .nav-bell{width:42px;height:42px;border-radius:50%;background:#fff;border:1px solid var(--line);display:grid;place-items:center;}
  .vamilio-app .nav-bell svg{width:18px;height:18px;}
  .vamilio-app .nav-ava{width:42px;height:42px;border-radius:50%;background:linear-gradient(140deg,var(--orchid),var(--plum));color:#fff;display:grid;place-items:center;font-weight:700;font-family:'Fraunces';font-size:17px;}
  .vamilio-app .nav-burger{display:none;width:42px;height:42px;border-radius:50%;background:var(--plum);color:#fff;place-items:center;}
  .vamilio-app .nav-burger svg{width:20px;height:20px;}

  .vamilio-app .view{display:none;padding:30px 0 80px;animation:rise .5s cubic-bezier(.2,.7,.2,1);}
  .vamilio-app .view.is-active{display:block;}
  @keyframes rise{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

  .vamilio-app .eyebrow{font-family:'Bricolage Grotesque';font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--orchid);}

  /* ---- HERO: asymmetrische Titelstory + Kommandomodul ---- */
  .vamilio-app .hero{display:grid;grid-template-columns:1.45fr .85fr;gap:24px;margin-top:14px;}
  .vamilio-app .hero-story{position:relative;}
  .vamilio-app .hero-greet{font-size:15px;color:var(--muted);font-weight:600;margin:8px 0 10px;}
  .vamilio-app .hero-title{font-size:clamp(48px,7vw,92px);font-weight:900;letter-spacing:-.025em;}
  .vamilio-app .hero-title em{font-style:italic;color:var(--orchid);}
  .vamilio-app .hero-sub{font-size:18px;color:var(--muted);max-width:440px;margin-top:18px;}
  .vamilio-app .hero-actions{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap;}
  .vamilio-app .chip{display:inline-flex;align-items:center;gap:9px;padding:12px 20px;border-radius:40px;font-weight:600;font-size:14.5px;background:#fff;border:1px solid var(--line);transition:.16s;}
  .vamilio-app .chip svg{width:17px;height:17px;color:var(--orchid);}
  .vamilio-app .chip:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(46,26,57,.10);}
  .vamilio-app .chip-solid{background:var(--plum);color:#fff;border-color:var(--plum);}
  .vamilio-app .chip-solid svg{color:#fff;}

  /* Kommandomodul (C) */
  .vamilio-app .command{background:linear-gradient(160deg,var(--plum-deep),var(--plum));border-radius:var(--r-lg);padding:28px;color:#fff;position:relative;overflow:hidden;box-shadow:0 24px 50px rgba(46,26,57,.30);}
  .vamilio-app .command::after{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(201,182,218,.25),transparent 70%);right:-80px;bottom:-90px;}
  .vamilio-app .command h3{font-size:15px;font-weight:600;opacity:.7;font-family:'Bricolage Grotesque';letter-spacing:.04em;position:relative;z-index:2;}
  .vamilio-app .command .big{font-family:'Fraunces';font-weight:900;font-size:56px;margin:6px 0 2px;position:relative;z-index:2;}
  .vamilio-app .command .big small{font-size:22px;font-weight:500;opacity:.7;}
  .vamilio-app .command .cap{font-size:13.5px;opacity:.72;position:relative;z-index:2;}
  .vamilio-app .cmd-stats{display:flex;gap:10px;margin-top:22px;position:relative;z-index:2;}
  .vamilio-app .cmd-stat{flex:1;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-sm);padding:13px;}
  .vamilio-app .cmd-stat .n{font-family:'Fraunces';font-weight:700;font-size:24px;}
  .vamilio-app .cmd-stat .l{font-size:11.5px;opacity:.7;margin-top:2px;line-height:1.3;}

  /* ---- Werkzeug-Inseln (B, organisch) ---- */
  .vamilio-app .section-head{display:flex;align-items:baseline;justify-content:space-between;margin:48px 0 20px;}
  .vamilio-app .section-head h2{font-size:30px;font-weight:600;}
  .vamilio-app .section-head h2 em{font-style:italic;color:var(--orchid);}
  .vamilio-app .more{font-family:'Bricolage Grotesque';color:var(--plum);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px;}
  .vamilio-app .more svg{width:15px;height:15px;}

  .vamilio-app .islands{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;}
  .vamilio-app .island{border-radius:var(--r-lg);padding:26px;position:relative;overflow:hidden;cursor:pointer;transition:.22s cubic-bezier(.2,.7,.2,1);min-height:188px;display:flex;flex-direction:column;justify-content:space-between;}
  .vamilio-app .island:hover{transform:translateY(-5px) rotate(-.4deg);}
  .vamilio-app .island .ti{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;background:rgba(255,255,255,.22);}
  .vamilio-app .island .ti svg{width:26px;height:26px;color:#fff;}
  .vamilio-app .island h3{font-size:23px;font-weight:600;color:#fff;}
  .vamilio-app .island p{font-size:14px;opacity:.86;color:#fff;margin-top:3px;}
  .vamilio-app .island .go{position:absolute;top:24px;right:24px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;transition:.2s;}
  .vamilio-app .island .go svg{width:17px;height:17px;color:#fff;}
  .vamilio-app .island:hover .go{background:rgba(255,255,255,.32);transform:rotate(-45deg);}
  .vamilio-app .isl-meal{grid-column:span 7;background:linear-gradient(140deg,#6E4488,#8757A3);}
  .vamilio-app .isl-budget{grid-column:span 5;background:linear-gradient(140deg,#2E1A39,#513064);}
  .vamilio-app .isl-plan{grid-column:span 5;background:linear-gradient(140deg,#A8536C,#C77F8E);}
  .vamilio-app .isl-mental{grid-column:span 7;background:linear-gradient(140deg,#3C6E5C,#6FA088);}
  .vamilio-app .island.big-art .ti{width:60px;height:60px;}

  /* ---- "Diese Woche neu" als editoriale Liste ---- */
  .vamilio-app .feed-item{display:flex;align-items:center;gap:20px;padding:20px 24px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:12px;transition:.16s;}
  .vamilio-app .feed-item:hover{border-color:var(--orchid);transform:translateX(4px);}
  .vamilio-app .feed-ic{width:50px;height:50px;border-radius:14px;background:var(--lilac-soft);display:grid;place-items:center;flex:0 0 50px;}
  .vamilio-app .feed-ic svg{width:23px;height:23px;color:var(--plum);}
  .vamilio-app .feed-info{flex:1;}
  .vamilio-app .feed-info h4{font-family:'Bricolage Grotesque';font-size:16px;font-weight:700;}
  .vamilio-app .feed-info span{font-size:13.5px;color:var(--muted);}
  .vamilio-app .feed-btn{font-family:'Bricolage Grotesque';font-weight:700;font-size:13.5px;padding:11px 20px;border-radius:30px;background:var(--ink);color:#fff;transition:.16s;}
  .vamilio-app .feed-btn:hover{background:var(--plum);}

  /* ---- generische Inhaltskarten für Unterseiten ---- */
  .vamilio-app .grid{display:grid;gap:18px;}
  .vamilio-app .g2{grid-template-columns:1fr 1fr;}.vamilio-app .g3{grid-template-columns:repeat(3,1fr);}
  .vamilio-app .card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:26px;}
  .vamilio-app .card h3{font-size:20px;font-weight:600;margin-bottom:8px;}
  .vamilio-app .card h3 .ihx{width:20px;height:20px;vertical-align:-3px;margin-right:7px;color:var(--orchid);}
  .vamilio-app .card p{color:var(--muted);font-size:14.5px;}
  .vamilio-app .view-head{margin-bottom:8px;}
  .vamilio-app .view-title{font-size:46px;font-weight:900;letter-spacing:-.02em;margin:6px 0 4px;}
  .vamilio-app .view-title em{font-style:italic;color:var(--orchid);}
  .vamilio-app .view-intro{color:var(--muted);max-width:560px;margin-bottom:28px;font-size:16px;}
  .vamilio-app .bar{height:9px;border-radius:9px;background:var(--lilac-soft);overflow:hidden;margin-top:9px;}
  .vamilio-app .bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--orchid),var(--plum));border-radius:9px;}
  .vamilio-app .brow{display:flex;justify-content:space-between;font-size:14px;font-weight:600;margin-top:18px;}
  .vamilio-app .brow small{color:var(--muted);}
  .vamilio-app .ml-board{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
  .vamilio-app .ml-task{display:flex;align-items:center;gap:11px;padding:12px 14px;border-radius:12px;background:var(--cream);margin-bottom:9px;font-size:14.5px;font-weight:600;}
  .vamilio-app .ml-task .d{width:9px;height:9px;border-radius:50%;background:var(--orchid);flex:0 0 9px;}
  .vamilio-app .who{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff;font-family:'Fraunces';}
  .vamilio-app .locked{position:relative;}
  .vamilio-app .lock-ov{position:absolute;inset:0;background:linear-gradient(160deg,rgba(46,26,57,.86),rgba(81,48,100,.82));backdrop-filter:blur(3px);border-radius:var(--r-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#fff;text-align:center;padding:24px;}
  .vamilio-app .lock-ov svg{width:26px;height:26px;}
  .vamilio-app .lock-ov h4{font-family:'Fraunces';font-size:18px;}
  .vamilio-app .lock-ov p{font-size:13.5px;opacity:.85;max-width:240px;}
  .vamilio-app .lock-ov .btn{background:#fff;color:var(--plum);width:auto;padding:11px 22px;margin-top:4px;}

  .vamilio-app .proto{position:fixed;bottom:16px;right:16px;background:var(--ink);color:#fff;font-family:'Bricolage Grotesque';font-size:11px;font-weight:700;padding:8px 14px;border-radius:30px;opacity:.8;z-index:99;letter-spacing:.04em;}

  /* mobile menu */
  .vamilio-app .mobile-nav{display:none;position:fixed;inset:0;z-index:80;background:rgba(46,26,57,.5);backdrop-filter:blur(4px);}
  .vamilio-app .mobile-nav.is-open{display:block;}
  .vamilio-app .mobile-sheet{position:absolute;top:0;right:0;width:80%;max-width:320px;height:100%;background:var(--plum-deep);padding:30px 22px;display:flex;flex-direction:column;gap:5px;}
  .vamilio-app .mobile-sheet .nav-link{color:rgba(255,255,255,.8);font-size:16px;padding:14px 16px;}
  .vamilio-app .mobile-sheet .nav-link.is-active{background:var(--orchid);color:#fff;}
  .vamilio-app .mobile-sheet .mclose{align-self:flex-end;color:#fff;width:40px;height:40px;}

  @media(max-width:920px){
    .vamilio-app .hero{grid-template-columns:1fr;}
    .vamilio-app .nav-links{display:none;}
    .vamilio-app .nav-burger{display:grid;}
    .vamilio-app .islands{grid-template-columns:1fr;}
    .vamilio-app .isl-meal, .vamilio-app .isl-budget, .vamilio-app .isl-plan, .vamilio-app .isl-mental{grid-column:span 1;}
    .vamilio-app .g2, .vamilio-app .g3, .vamilio-app .ml-board{grid-template-columns:1fr;}
    .vamilio-app .auth-visual{display:none;}
    .vamilio-app .hero-title{font-size:clamp(40px,12vw,64px);}
  }


  /* ============================================================
     Kompatibilitäts-Layer: Klassen der bestehenden Inhalts-Views
     im neuen Cockpit-Design.
     ============================================================ */
  .vamilio-app .sec-title,.vamilio-app .view-title{font-family:'Fraunces',serif;font-size:40px;font-weight:900;letter-spacing:-.02em;margin-bottom:6px;}
  .vamilio-app .sec-sub,.vamilio-app .view-intro{color:var(--muted);font-size:16px;margin-bottom:24px;}
  .vamilio-app .sec-h{display:flex;align-items:baseline;justify-content:space-between;margin:32px 0 16px;}
  .vamilio-app .sec-h h3{font-family:'Fraunces',serif;font-size:22px;font-weight:600;}

  /* KI-Tools */
  .vamilio-app .ai-note{background:var(--lilac-soft);border:1px solid var(--line);border-radius:var(--r-sm);padding:13px 17px;font-size:13.5px;margin-bottom:16px;}
  .vamilio-app .ai-input-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap;}
  .vamilio-app .ai-input{flex:1;min-width:220px;border:1.6px solid var(--line);background:var(--paper);border-radius:16px;padding:14px 16px;font-size:16px;font-family:inherit;color:var(--ink);resize:vertical;}
  .vamilio-app .ai-input:focus{outline:none;border-color:var(--orchid);}
  .vamilio-app .ai-output{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:22px;font-size:14.5px;line-height:1.6;white-space:pre-wrap;}

  /* Chat */
  .vamilio-app .ai-chat{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;}
  .vamilio-app .ai-chat-stream{display:flex;flex-direction:column;gap:10px;min-height:120px;max-height:460px;overflow-y:auto;margin-bottom:12px;}
  .vamilio-app .ai-msg{max-width:85%;padding:12px 16px;border-radius:18px;font-size:14.5px;line-height:1.5;white-space:pre-wrap;}
  .vamilio-app .ai-msg-bot{align-self:flex-start;background:var(--lilac-soft);border-bottom-left-radius:5px;}
  .vamilio-app .ai-msg-user{align-self:flex-end;background:var(--plum);color:#fff;border-bottom-right-radius:5px;}
  .vamilio-app .ai-chat-input{display:flex;gap:10px;align-items:center;}
  .vamilio-app .ai-chat-input .ai-input{min-width:0;}
  .vamilio-app .ai-hint{font-size:12px;color:var(--muted);margin-top:10px;}

  /* Chips/Filter */
  .vamilio-app .chips{display:flex;gap:9px;overflow-x:auto;padding-bottom:4px;margin-bottom:16px;scrollbar-width:none;}
  .vamilio-app .chips::-webkit-scrollbar{display:none;}
  .vamilio-app .chips .chip{flex:0 0 auto;padding:9px 17px;font-size:13.5px;}
  .vamilio-app .chips .chip.is-active{background:var(--plum);color:#fff;border-color:var(--plum);}

  /* Community-Karten */
  .vamilio-app .pcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:20px 22px;margin-bottom:14px;}
  .vamilio-app .pcard-top{display:flex;align-items:center;gap:12px;}
  .vamilio-app .post-ava{width:40px;height:40px;border-radius:50%;background:var(--lilac);display:grid;place-items:center;font-weight:700;color:var(--plum);font-family:'Fraunces';flex:0 0 40px;}
  .vamilio-app .pcard-name{font-weight:700;font-size:14.5px;font-family:'Bricolage Grotesque';}
  .vamilio-app .pcard-sub{color:var(--muted);font-size:12.5px;}
  .vamilio-app .pcard-sub b{color:var(--plum);}
  .vamilio-app .pcard-more{margin-left:auto;color:var(--muted);font-weight:800;letter-spacing:1px;}
  .vamilio-app .pcard h4{font-family:'Fraunces';font-size:18px;font-weight:600;margin:13px 0 6px;}
  .vamilio-app .pcard p{font-size:14.5px;}
  .vamilio-app .pcard ol{font-size:14.5px;margin:6px 0 0 20px;}
  .vamilio-app .pcard-meta{display:flex;gap:20px;color:var(--muted);font-size:13px;margin-top:14px;font-weight:600;align-items:center;}
  .vamilio-app .pcard-meta span{display:inline-flex;align-items:center;gap:6px;}
  .vamilio-app .pcard-meta svg{width:16px;height:16px;}
  .vamilio-app .app-pagehead{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:6px;}

  /* Lern-Kategorien & Listen */
  .vamilio-app .lcats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:8px;}
  .vamilio-app .lcat{display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;}
  .vamilio-app .lcat-ic{width:58px;height:58px;border-radius:50%;background:var(--lilac-soft);display:grid;place-items:center;}
  .vamilio-app .lcat-ic svg{width:26px;height:26px;color:var(--plum);}
  .vamilio-app .lcat span{font-size:12px;font-weight:600;line-height:1.25;}
  .vamilio-app .lcat-pick{cursor:pointer;}
  .vamilio-app .litem{display:flex;align-items:center;gap:14px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:13px;margin-bottom:12px;}
  .vamilio-app .litem-thumb{width:60px;height:60px;border-radius:14px;flex:0 0 60px;background:var(--lilac-soft);display:grid;place-items:center;color:var(--plum);}
  .vamilio-app .litem-thumb svg{width:26px;height:26px;}
  .vamilio-app .litem-body{flex:1;min-width:0;}
  .vamilio-app .litem-body h4{font-family:'Bricolage Grotesque';font-size:15px;font-weight:700;}
  .vamilio-app .litem-body p{font-size:13px;color:var(--muted);margin:2px 0 5px;}
  .vamilio-app .litem-time{font-size:12px;color:var(--muted);font-weight:600;display:inline-flex;align-items:center;gap:5px;}
  .vamilio-app .litem-time svg{width:13px;height:13px;}
  .vamilio-app .litem-bm{color:var(--muted);flex:0 0 auto;align-self:flex-start;}

  /* Meal-Prep */
  .vamilio-app .meal-plans{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-bottom:10px;}
  .vamilio-app .meal-empty{color:var(--muted);font-size:14px;padding:8px 0;}
  .vamilio-app .meal-plan-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:18px;display:flex;flex-direction:column;gap:12px;}
  .vamilio-app .meal-plan-title{font-family:'Bricolage Grotesque';font-weight:700;font-size:15px;}
  .vamilio-app .meal-plan-date{color:var(--muted);font-size:12.5px;}
  .vamilio-app .meal-plan-btns{display:flex;gap:8px;}
  .vamilio-app .meal-plan-btns .btn{padding:9px 17px;font-size:13px;}
  .vamilio-app .meal-detail{margin-top:24px;}
  .vamilio-app .meal-detail-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px;}
  .vamilio-app .meal-detail-head h3{font-family:'Fraunces';font-size:24px;font-weight:600;}
  .vamilio-app .meal-actions{display:flex;gap:8px;}
  .vamilio-app .meal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:10px;}
  .vamilio-app .meal-day{text-align:left;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:13px;cursor:pointer;transition:.16s;display:flex;flex-direction:column;gap:8px;min-height:120px;}
  .vamilio-app .meal-day:hover{border-color:var(--orchid);transform:translateY(-3px);}
  .vamilio-app .meal-day-h{font-family:'Bricolage Grotesque';font-weight:700;font-size:13px;color:var(--plum);display:flex;align-items:baseline;justify-content:space-between;gap:8px;}
  .vamilio-app .meal-day-kcal{font-weight:600;font-size:11px;color:var(--muted);white-space:nowrap;}
  .vamilio-app .meal-day-meal{font-size:12px;line-height:1.3;}
  .vamilio-app .meal-day-meal span{display:block;color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;}
  .vamilio-app .meal-meal-kcal{display:block;font-style:normal;color:var(--muted);font-size:10.5px;margin-top:1px;}
  .vamilio-app .meal-shopping{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;}
  .vamilio-app .meal-shop-group{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:14px 16px;}
  .vamilio-app .meal-shop-cat{font-family:'Bricolage Grotesque';font-weight:700;font-size:14px;color:var(--plum);margin-bottom:8px;}
  .vamilio-app .meal-shop-item{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:14px;cursor:pointer;}
  .vamilio-app .meal-shop-item.is-on{color:var(--muted);text-decoration:line-through;}
  .vamilio-app .meal-chk{width:18px;height:18px;border-radius:5px;border:2px solid var(--lilac);flex:0 0 18px;position:relative;}
  .vamilio-app .meal-chk.on{background:var(--plum);border-color:var(--plum);}
  .vamilio-app .meal-chk.on::after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);}
  .vamilio-app .meal-modal{position:fixed;inset:0;background:rgba(46,26,57,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;}
  .vamilio-app .meal-modal-card{background:var(--paper);border-radius:var(--r-md);padding:26px;max-width:460px;width:100%;position:relative;max-height:85vh;overflow-y:auto;}
  .vamilio-app .meal-modal-x{position:absolute;top:14px;right:16px;font-size:26px;line-height:1;color:var(--muted);}
  .vamilio-app .meal-modal-card h3{font-family:'Fraunces';font-size:22px;font-weight:600;margin-bottom:14px;color:var(--plum);}
  .vamilio-app .meal-modal-meal{margin-bottom:16px;}
  .vamilio-app .meal-modal-meal h4{font-family:'Bricolage Grotesque';font-size:15px;font-weight:700;margin-bottom:6px;}
  .vamilio-app .meal-modal-kcal{display:inline-block;margin-left:8px;font-size:12px;font-weight:600;color:var(--plum);background:var(--lilac-soft);border-radius:99px;padding:2px 10px;vertical-align:middle;}
  .vamilio-app .meal-modal-meal ul{margin:0 0 0 18px;font-size:14px;}
  @media (max-width:1024px){ .vamilio-app .meal-grid{grid-template-columns:1fr 1fr;} }
  @media (max-width:520px){ .vamilio-app .meal-grid{grid-template-columns:1fr;} .vamilio-app .lcats{grid-template-columns:1fr 1fr;} }

  /* hidden immer respektieren */
  .vamilio-app *[hidden]{display:none !important;}

  /* Spinner */
  .vamilio-app .btn.is-loading,.vamilio-app .ai-go.is-loading{opacity:.7;pointer-events:none;}
  .vamilio-app .btn.is-loading svg,.vamilio-app .ai-go.is-loading svg{animation:vamilio-spin 1s linear infinite;}
  @keyframes vamilio-spin{to{transform:rotate(360deg);}}

  /* Budget-Balken (alte Klassen -> neues Design) */
  .vamilio-app .acts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:22px;}
  .vamilio-app .act{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:24px;text-align:center;display:flex;flex-direction:column;align-items:center;}
  .vamilio-app .act-ic{width:56px;height:56px;border-radius:50%;background:var(--lilac-soft);display:grid;place-items:center;margin-bottom:14px;}
  .vamilio-app .act-ic svg{width:26px;height:26px;color:var(--plum);}
  .vamilio-app .act h3{font-family:'Fraunces';font-size:24px;font-weight:700;margin-bottom:4px;}
  .vamilio-app .act p{color:var(--muted);font-size:13.5px;}
  .vamilio-app .panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:24px;}
  .vamilio-app .panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
  .vamilio-app .panel-head h3{font-family:'Fraunces';font-size:19px;font-weight:600;}
  .vamilio-app .row2,.vamilio-app .commrow{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
  .vamilio-app .cat{display:flex;align-items:center;gap:13px;padding:11px 0;}
  .vamilio-app .cat-ic{width:38px;height:38px;border-radius:11px;background:var(--lilac-soft);display:grid;place-items:center;flex:0 0 38px;}
  .vamilio-app .cat-ic svg{width:19px;height:19px;color:var(--plum);}
  .vamilio-app .todo{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14.5px;font-weight:600;}
  .vamilio-app .todo .chk{width:21px;height:21px;border-radius:6px;border:2px solid var(--lilac);flex:0 0 21px;cursor:pointer;display:grid;place-items:center;}
  .vamilio-app .todo .chk svg{width:13px;height:13px;color:#fff;opacity:0;}
  .vamilio-app .todo.done .chk{background:var(--plum);border-color:var(--plum);}
  .vamilio-app .todo.done .chk svg{opacity:1;}
  .vamilio-app .todo.done span{color:var(--muted);text-decoration:line-through;}
  .vamilio-app .todo-add{display:flex;align-items:center;gap:9px;color:var(--muted);font-weight:600;font-size:14px;padding-top:14px;}
  .vamilio-app .planner-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;}
  .vamilio-app .planner-day{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:10px;min-height:110px;}
  .vamilio-app .planner-day-h{font-family:'Bricolage Grotesque';font-weight:700;font-size:13px;color:var(--plum);margin-bottom:8px;}
  .vamilio-app .planner-item{background:var(--lilac-soft);border-radius:8px;padding:5px 8px;font-size:12px;margin-bottom:6px;}
  @media (max-width:1024px){ .vamilio-app .acts,.vamilio-app .row2,.vamilio-app .commrow{grid-template-columns:1fr;} .vamilio-app .planner-grid{grid-template-columns:1fr 1fr;} }

  .vamilio-app .link,.vamilio-app .more{font-family:'Bricolage Grotesque';color:var(--plum);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px;}
  .vamilio-app .tip{display:flex;align-items:center;gap:20px;}
  .vamilio-app .tip-ic svg{width:50px;height:50px;color:var(--plum);}
  .vamilio-app .tip-text{font-family:'Fraunces';font-style:italic;font-weight:500;font-size:21px;line-height:1.35;}
  .vamilio-app .tip-underline{height:5px;width:130px;background:var(--orchid);border-radius:5px;margin-top:8px;opacity:.5;}

  /* Text-Logo in der Topnav (statt Bilddatei) */
  .vamilio-app .logo-text{display:flex;align-items:center;gap:8px;font-family:'Fraunces',serif;font-weight:900;font-size:22px;color:var(--plum);letter-spacing:-.02em;}

  /* App-Seite: warmer Cream-Hintergrund über die ganze Seite */
  body.vamilio-app-page{margin:0;background:var(--cream,#F6F1EA);}
  .vamilio-app{min-height:100vh;padding-bottom:60px;}

  /* ============================================================
     Layout-Härtung: Breite begrenzen wie in der Demo (robust gegen
     äußere Theme-Regeln) + Hintergrund-Aura sicherstellen.
     ============================================================ */
  .vamilio-app{position:relative;max-width:100%;overflow-x:hidden;background:var(--cream);}
  .vamilio-app::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
    background:
      radial-gradient(60% 50% at 82% -5%, rgba(135,87,163,.18), transparent 60%),
      radial-gradient(50% 45% at -5% 12%, rgba(224,168,107,.14), transparent 55%),
      radial-gradient(55% 50% at 50% 110%, rgba(201,182,218,.20), transparent 60%);}
  /* Inhalt über die Aura legen */
  .vamilio-app .topnav,.vamilio-app .wrap{position:relative;z-index:2;}

  /* Breite verbindlich begrenzen und zentrieren */
  .vamilio-app .topnav{max-width:1180px !important;margin-left:auto !important;margin-right:auto !important;}
  .vamilio-app .wrap{max-width:1180px !important;margin-left:auto !important;margin-right:auto !important;padding-left:28px;padding-right:28px;}

  @media (max-width:520px){
    .vamilio-app .wrap{padding-left:16px;padding-right:16px;}
    .vamilio-app .topnav{padding-left:14px;padding-right:14px;}
  }

  /* "Mehr"-Dropdown in der Top-Nav */
  .vamilio-app .nav-more-wrap{position:relative;}
  .vamilio-app .nav-more-btn{cursor:pointer;}
  .vamilio-app .nav-more-menu{position:absolute;top:calc(100% + 10px);right:0;background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:8px;min-width:210px;box-shadow:0 20px 44px rgba(46,26,57,.16);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.16s;z-index:70;}
  .vamilio-app .nav-more-wrap:hover .nav-more-menu{opacity:1;visibility:visible;transform:translateY(0);}
  .vamilio-app .nav-more-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:12px;font-weight:600;font-size:14px;color:var(--ink);}
  .vamilio-app .nav-more-item svg{width:18px;height:18px;color:var(--orchid);}
  .vamilio-app .nav-more-item:hover{background:rgba(81,48,100,.07);}
  .vamilio-app .nav-more-item.is-active{background:var(--plum);color:#fff;}
  .vamilio-app .nav-more-item.is-active svg{color:#fff;}

  /* ============================================================
     Fixes: Button-/Icon-Größen + Karten-Hintergrund
     ============================================================ */
  /* SVGs in Buttons/Chips/Feed nie überdimensioniert */
  .vamilio-app .btn svg,
  .vamilio-app .chip svg,
  .vamilio-app .feed-btn svg,
  .vamilio-app .ai-go svg,
  .vamilio-app .meal-plan-btns .btn svg{width:18px;height:18px;flex:0 0 auto;}

  /* Buttons kompakt halten (nicht full-width, außer Auth) */
  .vamilio-app .btn{width:auto;}
  .vamilio-app .auth-card .btn-primary{width:100%;}

  /* "Wochenplan generieren" & Co: normale Button-Höhe, Spinner klein */
  .vamilio-app #meal-generate,
  .vamilio-app .ai-go,
  .vamilio-app .meal-actions .btn{padding:14px 24px;font-size:15px;min-height:0;height:auto;}
  .vamilio-app #meal-generate svg,
  .vamilio-app .ai-go svg{width:18px;height:18px;}
  .vamilio-app .btn.is-loading svg,
  .vamilio-app .ai-go.is-loading svg{width:18px;height:18px;animation:vamilio-spin 1s linear infinite;}

  /* Meal-Prep Eingabezeile: Button neben Textfeld, nicht riesig */
  .vamilio-app .meal-app .ai-input-row{align-items:stretch;}
  .vamilio-app #meal-generate{flex:0 0 auto;align-self:flex-start;}

  /* Command-Karte: kein eckiger Schatten-Kasten dahinter.
     Schatten weicher + transparenter, Karte sauber abgerundet. */
  .vamilio-app .command{box-shadow:0 30px 60px -20px rgba(46,26,57,.45);isolation:isolate;}
  .vamilio-app .hero-story,.vamilio-app .hero{background:transparent;box-shadow:none;}

  /* ============================================================
     Megamenü (App-Nav) – nach Mitgliedschaft gegliedert
     ============================================================ */
  .vamilio-app .nav-more-wrap{position:static;}
  .vamilio-app .mega{position:absolute;top:74px;left:50%;transform:translateX(-50%) translateY(-8px);width:860px;max-width:94vw;background:#FFFDFA;border:1px solid var(--line);border-radius:24px;box-shadow:0 40px 90px rgba(46,26,57,.28);opacity:0;visibility:hidden;transition:.18s;z-index:9999;overflow:hidden;}
  .vamilio-app .nav-more-wrap:hover .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
  .vamilio-app .mega-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:#FFFDFA;}
  .vamilio-app .mega-col{padding:24px 22px;border-right:1px solid var(--line);background:#FFFDFA;}
  .vamilio-app .mega-col:first-child{background:linear-gradient(180deg,#FBF7F1,#FFFDFA);}
  .vamilio-app .mega-col:last-child{border-right:0;}
  .vamilio-app .mega-col-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2px;}
  .vamilio-app .mega-plan{font-family:'Fraunces',serif;font-weight:700;font-size:18px;color:var(--plum);}
  .vamilio-app .mega-price{font-family:'Bricolage Grotesque';font-weight:700;font-size:12px;color:var(--orchid);background:var(--lilac-soft);padding:4px 10px;border-radius:20px;white-space:nowrap;}
  .vamilio-app .mega-note{font-size:12px;color:var(--muted);margin:2px 0 16px;}
  .vamilio-app .mega-item{display:flex;align-items:center;gap:12px;padding:10px 11px;border-radius:13px;transition:.14s;margin-bottom:3px;}
  .vamilio-app .mega-item:hover{background:rgba(81,48,100,.08);}
  .vamilio-app .mega-item.is-active{background:var(--plum);}
  .vamilio-app .mega-item.is-active .mega-label{color:#fff;}
  .vamilio-app .mega-item.is-active .mega-desc{color:rgba(255,255,255,.78);}
  .vamilio-app .mega-item.is-active .mega-ic{background:rgba(255,255,255,.20);}
  .vamilio-app .mega-item.is-active .mega-ic svg{color:#fff;}
  .vamilio-app .mega-ic{width:40px;height:40px;border-radius:12px;background:var(--lilac-soft);display:grid;place-items:center;flex:0 0 40px;}
  .vamilio-app .mega-ic svg{width:20px;height:20px;color:var(--plum);}
  .vamilio-app .mega-tx{display:flex;flex-direction:column;line-height:1.2;min-width:0;}
  .vamilio-app .mega-label{font-family:'Bricolage Grotesque';font-weight:700;font-size:14.5px;}
  .vamilio-app .mega-desc{font-size:11.5px;color:var(--muted);margin-top:2px;}
  @media (max-width:1024px){ .vamilio-app .nav-more-wrap{display:none;} }

  /* Megamenü-Stapelreihenfolge erzwingen: Nav-Bereich über dem Inhalt */
  .vamilio-app .topnav{z-index:9000;}
  .vamilio-app .wrap{z-index:1;}
  .vamilio-app .command{z-index:1;}
  .vamilio-app .hero{z-index:1;}
  /* Das Menü selbst über allem */
  .vamilio-app .mega{z-index:9999 !important;}
  /* Panel etwas schmaler + nach rechts ausrichten, damit es nicht den Hero-Titel überdeckt */
  .vamilio-app .mega{left:auto;right:0;transform:translateY(-8px);}
  .vamilio-app .nav-more-wrap:hover .mega{transform:translateY(0);}

  /* ============================================================
     Auth-Seite (Konto): Login/Register
     ============================================================ */
  body.vamilio-auth-page{margin:0;}
  body.vamilio-auth-page .vamilio-app{padding-bottom:0;min-height:100vh;}
  body.vamilio-auth-page .vamilio-app::before{display:none;}
  .vamilio-app .auth{display:flex;min-height:100vh;}
  .vamilio-app .auth-brand{margin-bottom:auto;}
  .vamilio-app .auth-visual{display:flex;flex-direction:column;gap:30px;padding:54px 48px;color:#fff;position:relative;overflow:hidden;}
  .vamilio-app .auth-visual::after{content:"";position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(201,182,218,.22),transparent 70%);right:-200px;top:-160px;}
  .vamilio-app .auth-card h2{font-size:34px;font-weight:600;margin-bottom:6px;}
  .vamilio-app .field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px;}
  .vamilio-app .auth-err{background:#FCEDED;border:1px solid #E8B4B4;color:#9C2B2B;border-radius:14px;padding:12px 16px;font-size:13.5px;margin-bottom:18px;}
  .vamilio-app .auth-remember{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--muted);margin:-4px 0 18px;}
  .vamilio-app .auth-remember input{width:16px;height:16px;}
  .vamilio-app .auth-card .btn-primary{width:100%;margin-top:4px;}

  /* Paketauswahl (Radio-Pillen) */
  .vamilio-app .plan-pick{display:flex;gap:8px;margin-bottom:18px;}
  .vamilio-app .plan-opt{flex:1;text-align:center;border:1.6px solid var(--line);border-radius:14px;padding:10px;font-size:13.5px;font-weight:700;cursor:pointer;transition:.14s;position:relative;}
  .vamilio-app .plan-opt input{position:absolute;opacity:0;}
  .vamilio-app .plan-opt.is-on{border-color:var(--plum);background:var(--lilac-soft);color:var(--plum);}

  @media (max-width:860px){
    .vamilio-app .auth{flex-direction:column;}
    .vamilio-app .auth-visual{padding:36px 28px;min-height:auto;}
    .vamilio-app .auth-form-wrap{padding:32px 24px;}
  }

  /* Register: Zwei-Schritt-Ablauf */
  .vamilio-app .reg-steps{display:flex;gap:8px;margin-bottom:20px;}
  .vamilio-app .reg-step{flex:1;text-align:center;font-size:12px;font-weight:700;color:var(--muted);padding:8px;border-radius:20px;background:var(--cream);transition:.14s;}
  .vamilio-app .reg-step.is-on{background:var(--plum);color:#fff;}
  .vamilio-app .field-row{display:flex;gap:12px;}
  .vamilio-app .field-row > span{display:block;flex:1;}
  .vamilio-app .field select{width:100%;border:1.6px solid var(--line);border-radius:14px;padding:14px 16px;font-size:16px;font-family:inherit;background:var(--cream);color:var(--ink);}
  .vamilio-app .field select:focus{outline:none;border-color:var(--orchid);background:#fff;}
  .vamilio-app .plan-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;}
  .vamilio-app .plan-card{border:1.6px solid var(--line);border-radius:16px;overflow:hidden;cursor:pointer;transition:.14s;}
  .vamilio-app .plan-card-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;cursor:pointer;}
  .vamilio-app .plan-card input{position:absolute;opacity:0;}
  .vamilio-app .plan-card.is-on{border-color:var(--plum);background:var(--lilac-soft);}
  .vamilio-app .plan-card-name{font-family:'Bricolage Grotesque';font-weight:700;font-size:16px;flex:1;}
  .vamilio-app .plan-card.is-on .plan-card-name{color:var(--plum);}
  .vamilio-app .plan-card-price{font-size:14px;font-weight:700;color:var(--muted);}
  .vamilio-app .plan-card.is-on .plan-card-price{color:var(--plum);}
  .vamilio-app .plan-card-body{padding:0 18px 16px;}
  .vamilio-app .plan-card-note{font-size:13px;color:var(--muted);margin-bottom:10px;}
  .vamilio-app .plan-card-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;}
  .vamilio-app .plan-card-list li{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;}
  .vamilio-app .plan-card-list svg{width:17px;height:17px;color:var(--plum);flex:0 0 17px;}

  /* Pflichtfeld-Kennzeichnung */
  .vamilio-app .req{color:#C0392B;font-weight:700;}
  .vamilio-app .req-note{font-size:12px;color:var(--muted);margin:-4px 0 16px;line-height:1.4;}
  .vamilio-app .field input.is-invalid,.vamilio-app .field select.is-invalid{border-color:#C0392B;background:#FCEDED;}

  /* Upgrade-Banner auf der Übersicht */
  .vamilio-app .upgrade-banner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
    background:linear-gradient(135deg,var(--plum-deep),var(--plum));color:#fff;border-radius:var(--r-lg);padding:26px 30px;margin-top:36px;box-shadow:0 24px 50px rgba(46,26,57,.22);}
  .vamilio-app .upgrade-banner h3{font-family:'Fraunces',serif;font-size:22px;font-weight:600;margin-bottom:4px;}
  .vamilio-app .upgrade-banner p{font-size:14.5px;opacity:.88;max-width:520px;}
  .vamilio-app .upgrade-banner .btn-primary{background:#fff;color:var(--plum);flex:0 0 auto;}
  .vamilio-app .upgrade-banner .btn-primary svg{color:var(--plum);}

  /* Hinweis, wenn man von einem gesperrten Bereich kam */
  .vamilio-app .locked-note{background:#FFF4E6;border:1px solid var(--gold);color:#7A4A12;border-radius:var(--r-md);padding:14px 18px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;gap:10px;}
  .vamilio-app .locked-note svg{width:20px;height:20px;flex:0 0 20px;color:var(--gold);}

  /* ============================================================
     Onboarding-Fragebogen (Willkommen)
     ============================================================ */
  body.vamilio-onboard-page{margin:0;}
  body.vamilio-onboard-page .vamilio-app{padding-bottom:0;min-height:100vh;}
  body.vamilio-onboard-page .vamilio-app::before{display:none;}
  .vamilio-app .onb-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:linear-gradient(160deg,#FBF7F1,var(--paper));}
  .vamilio-app .onb-card{width:100%;max-width:540px;background:#FFFDFA;border:1px solid var(--line);border-radius:26px;box-shadow:0 36px 80px rgba(46,26,57,.16);padding:30px 34px 34px;}
  .vamilio-app .onb-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
  .vamilio-app .onb-skip{background:none;border:none;color:var(--muted);font-size:13.5px;font-weight:600;cursor:pointer;text-decoration:underline;}
  .vamilio-app .onb-skip:hover{color:var(--plum);}
  .vamilio-app .onb-progress{height:6px;background:var(--lilac-soft);border-radius:20px;overflow:hidden;margin-bottom:24px;}
  .vamilio-app .onb-bar{display:block;height:100%;width:25%;background:linear-gradient(90deg,var(--plum),var(--orchid));border-radius:20px;transition:width .25s ease;}
  .vamilio-app .onb-step{display:none;}
  .vamilio-app .onb-step.is-active{display:block;animation:onb-fade .25s ease;}
  @keyframes onb-fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
  .vamilio-app .onb-eyebrow{font-family:'Bricolage Grotesque';font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--orchid);margin-bottom:8px;}
  .vamilio-app .onb-card h2{font-size:27px;font-weight:600;margin-bottom:6px;line-height:1.15;}
  .vamilio-app .onb-sub{color:var(--muted);font-size:14.5px;margin-bottom:22px;}
  .vamilio-app .onb-label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin:6px 0 10px;}
  .vamilio-app .onb-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:26px;}
  .vamilio-app .onb-nav .btn{flex:0 0 auto;}
  .vamilio-app .onb-nav .onb-back{background:var(--lilac-soft);color:var(--ink);}
  .vamilio-app .onb-nav .btn-primary{margin-left:auto;}
  /* Mitglieder-Zeilen */
  .vamilio-app .onb-member{display:flex;gap:8px;align-items:center;margin-bottom:10px;}
  .vamilio-app .onb-member input,.vamilio-app .onb-member select{border:1.6px solid var(--line);border-radius:12px;padding:11px 12px;font-size:16px;font-family:inherit;background:var(--cream);color:var(--ink);min-width:0;}
  .vamilio-app .onb-member input[name="member_name[]"]{flex:1;}
  .vamilio-app .onb-rm{flex:0 0 auto;width:38px;height:38px;border:none;border-radius:11px;background:var(--lilac-soft);color:var(--plum);cursor:pointer;display:grid;place-items:center;}
  .vamilio-app .onb-rm:hover{background:#F2D9D9;color:#C0392B;}
  .vamilio-app .onb-add{background:none;border:1.6px dashed var(--line);border-radius:12px;padding:10px;width:100%;color:var(--plum);font-weight:700;font-size:14px;cursor:pointer;margin-top:4px;}
  .vamilio-app .onb-add:hover{border-color:var(--orchid);background:var(--lilac-soft);}
  /* Ziele */
  .vamilio-app .onb-goals{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
  .vamilio-app .onb-goal{display:flex;align-items:center;gap:10px;border:1.6px solid var(--line);border-radius:14px;padding:13px 15px;cursor:pointer;font-weight:600;font-size:14px;transition:.14s;}
  .vamilio-app .onb-goal input{width:18px;height:18px;accent-color:var(--plum);}
  .vamilio-app .onb-goal:has(input:checked){border-color:var(--plum);background:var(--lilac-soft);color:var(--plum);}
  @media (max-width:560px){ .vamilio-app .onb-goals{grid-template-columns:1fr;} .vamilio-app .onb-card{padding:24px 20px 28px;} }

  /* Echtes Logo in der App-Nav */
  .vamilio-app .nav-logo-link{display:flex;align-items:center;}
  .vamilio-app .nav-logo-img{height:34px;width:auto;display:block;}
  @media (max-width:600px){ .vamilio-app .nav-logo-img{height:28px;} }

/* ── Meal-Prep: Profil-Chips über dem Generator ───────────────── */
.vamilio-app .meal-profile{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:0 0 14px;}
.vamilio-app .meal-profile-label{font-size:12.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);}
.vamilio-app .meal-chip{display:inline-flex;align-items:center;gap:6px;background:var(--lilac-soft);color:var(--plum);border:1px solid var(--line);border-radius:30px;padding:6px 12px;font-size:13px;font-weight:600;}
.vamilio-app .meal-chip .i{width:13px;height:13px;}
.vamilio-app .meal-chip--cta{background:var(--plum);color:#fff;border-color:var(--plum);text-decoration:none;}
.vamilio-app .meal-chip--cta:hover{background:var(--orchid);}
.vamilio-app .meal-profile-edit{font-size:13px;font-weight:700;color:var(--plum);text-decoration:underline;text-underline-offset:3px;}

/* ── Familie: Mitglieder-Karten ───────────────────────────────── */
.vamilio-app .fam-head{display:flex;flex-direction:column;gap:6px;max-width:380px;margin:0 0 18px;}
.vamilio-app .fam-name-label{font-size:12.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);}
.vamilio-app .fam-name{border:1.5px solid var(--line);border-radius:14px;padding:11px 14px;font:inherit;background:#FFFDFA;}
.vamilio-app .fam-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:18px;}
.vamilio-app .fam-card{background:#FFFDFA;border:1px solid var(--line);border-radius:20px;padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:0 8px 24px rgba(46,26,57,.06);}
.vamilio-app .fam-card-top{display:flex;align-items:center;gap:10px;}
.vamilio-app .fam-ava{width:38px;height:38px;border-radius:50%;background:var(--plum);color:#fff;display:grid;place-items:center;font-weight:800;flex:0 0 38px;}
.vamilio-app .fam-ava.is-kid{background:var(--orchid);}
.vamilio-app .fam-card-top input{flex:1;min-width:0;border:0;border-bottom:1.5px solid var(--line);padding:6px 2px;font:inherit;font-weight:700;background:transparent;}
.vamilio-app .fam-del{border:0;background:var(--lilac-soft);color:var(--ink);width:30px;height:30px;border-radius:50%;font-size:18px;cursor:pointer;line-height:1;}
.vamilio-app .fam-del:hover{background:var(--coral, #E0707F);color:#fff;}
.vamilio-app .fam-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.vamilio-app .fam-card label{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:700;color:var(--muted);}
.vamilio-app .fam-card input,.vamilio-app .fam-card select{border:1.5px solid var(--line);border-radius:12px;padding:9px 11px;font:inherit;font-size:16px;background:#fff;color:var(--ink);}
.vamilio-app .fam-opt{font-weight:500;text-transform:none;letter-spacing:0;}
.vamilio-app .fam-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.vamilio-app .fam-status{font-size:13.5px;font-weight:700;color:var(--plum);}
.vamilio-app .fam-privacy{display:flex;gap:10px;align-items:flex-start;margin-top:18px;padding:14px 16px;background:var(--lilac-soft);border-radius:16px;font-size:13px;line-height:1.55;color:var(--ink);}
.vamilio-app .fam-privacy .i{width:18px;height:18px;flex:0 0 18px;margin-top:2px;color:var(--plum);}

/* ── Konto: Plan-Karten & Rechnungen ──────────────────────────── */
.vamilio-app .bill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:12px;}
.vamilio-app .bill-card{background:#FFFDFA;border:1.5px solid var(--line);border-radius:20px;padding:18px;display:flex;flex-direction:column;gap:8px;}
.vamilio-app .bill-card.is-current{border-color:var(--plum);box-shadow:0 10px 30px rgba(81,48,100,.12);}
.vamilio-app .bill-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;}
.vamilio-app .bill-plan{font-family:'Fraunces',serif;font-weight:700;font-size:19px;color:var(--plum);}
.vamilio-app .bill-price{font-family:'Bricolage Grotesque';font-weight:700;font-size:12.5px;color:var(--orchid);background:var(--lilac-soft);padding:4px 10px;border-radius:20px;white-space:nowrap;}
.vamilio-app .bill-blurb{font-size:13.5px;color:var(--muted);line-height:1.5;flex:1;}
.vamilio-app .bill-badge{align-self:flex-start;background:var(--plum);color:#fff;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:7px 13px;border-radius:20px;}
.vamilio-app .bill-change{justify-content:center;}
.vamilio-app .bill-status{min-height:20px;font-size:14px;font-weight:700;margin:4px 0 0;}
.vamilio-app .bill-note{font-size:12.5px;color:var(--muted);margin-top:6px;max-width:640px;line-height:1.55;}
.vamilio-app .bill-warn{font-size:14px;color:var(--ink);background:var(--lilac-soft);border-radius:12px;padding:10px 12px;}
.vamilio-app .bill-linkbtn{border:0;background:none;color:var(--plum);font:inherit;font-weight:700;text-decoration:underline;text-underline-offset:3px;cursor:pointer;padding:0;margin-left:6px;}
.vamilio-app .bill-inv{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line);font-size:14px;}
.vamilio-app .bill-inv:last-child{border-bottom:0;}
.vamilio-app .bill-inv-date{flex:1;}
.vamilio-app .bill-inv-state{color:var(--coral,#C0392B);font-weight:700;font-size:12px;}
.vamilio-app .bill-inv-total{color:var(--muted);}
.vamilio-app .bill-inv-link{color:var(--plum);font-weight:700;text-decoration:underline;text-underline-offset:3px;}

/* ── ICON-SICHERHEITSNETZ ─────────────────────────────────────────
   Sprite-SVGs (<svg><use …>) ohne Größenangabe rendern im Browser-
   Standard mit 300×150 px. Dieses Netz gibt JEDEM ungesizten Icon
   in der App eine vernünftige Standardgröße. :where() hat null
   Spezifität – jede vorhandene oder künftige Klassen-Regel und
   jedes width-Attribut gewinnt weiterhin. */
.vamilio-app :where(svg:not([width])){width:20px;height:20px;flex:none;}

/* Bibliothek: Suchleiste & Merken-Button (waren ungestylt) */
.vamilio-app .search{display:flex;align-items:center;gap:10px;background:#FFFDFA;border:1.5px solid var(--line);border-radius:30px;padding:11px 16px;max-width:520px;}
.vamilio-app .search svg{width:18px;height:18px;color:var(--muted);}
.vamilio-app .search input{flex:1;min-width:0;border:0;background:transparent;font:inherit;font-size:16px;color:var(--ink);outline:none;}
.vamilio-app .litem-bm svg{width:20px;height:20px;}
.vamilio-app .litem-bm:hover{color:var(--plum);}

/* Konto: Abmelden-Link */
.vamilio-app .app-logout{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:600;font-size:14.5px;}
.vamilio-app .app-logout:hover{color:var(--plum);}

/* ── Meal-Prep: Vorgaben-Chips ("Gadgets") ────────────────────── */
.vamilio-app .meal-opts{display:flex;flex-direction:column;gap:10px;margin:0 0 16px;padding:14px 16px;background:#FFFDFA;border:1px solid var(--line);border-radius:18px;}
.vamilio-app .meal-avoid{display:flex;flex-direction:column;gap:8px;margin:0 0 16px;padding:14px 16px;background:#FFFDFA;border:1px solid var(--line);border-radius:18px;}
.vamilio-app .meal-avoid .meal-opts-label{flex:none;}
.vamilio-app .meal-avoid-in{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:11px 14px;font:inherit;font-size:max(16px,1em);background:#fff;color:var(--ink);}
.vamilio-app .meal-avoid-in:focus{outline:none;border-color:var(--plum);}
.vamilio-app .meal-opts-group{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;}
.vamilio-app .meal-opts-label{flex:0 0 96px;font-size:11.5px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);}
.vamilio-app .meal-opts-row{display:flex;flex-wrap:wrap;gap:7px;flex:1;min-width:200px;}
.vamilio-app .meal-opt{border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:30px;padding:7px 13px;font:inherit;font-size:13.5px;font-weight:600;cursor:pointer;transition:.14s;}
.vamilio-app .meal-opt:hover{border-color:var(--plum);color:var(--plum);}
.vamilio-app .meal-opt.is-on{background:var(--plum);border-color:var(--plum);color:#fff;}
@media(max-width:640px){.vamilio-app .meal-opts-label{flex-basis:100%;}}

/* ── Meal-Prep: Generieren-Button solo (Textfeld entfernt) ────── */
.vamilio-app .meal-generate-row{margin:4px 0 6px;}
.vamilio-app .meal-generate-row .btn-lg{padding:15px 26px;font-size:16px;}

/* ── Meal-Prep: aufklappbare Chip-Gruppen ("+ N weitere") ─────── */
.vamilio-app .meal-opt.is-more{display:none;}
.vamilio-app .meal-opts-group.is-expanded .meal-opt.is-more{display:inline-block;}
.vamilio-app .meal-opts-toggle{border:1.5px dashed var(--line);background:transparent;color:var(--muted);border-radius:30px;padding:7px 13px;font:inherit;font-size:13.5px;font-weight:700;cursor:pointer;transition:.14s;}
.vamilio-app .meal-opts-toggle:hover{border-color:var(--plum);color:var(--plum);}

/* ── Meal-Prep: Familien-Gate & Familie: Kopf-Felder ──────────── */
.vamilio-app .meal-gate{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:#FFFDFA;border:1.5px dashed var(--plum);border-radius:20px;padding:18px 20px;margin-bottom:16px;}
.vamilio-app .meal-gate-ic{width:48px;height:48px;border-radius:14px;background:var(--lilac-soft);display:grid;place-items:center;color:var(--plum);flex:0 0 48px;}
.vamilio-app .meal-gate-tx{flex:1;min-width:220px;}
.vamilio-app .meal-gate-tx h4{font-family:'Bricolage Grotesque';font-size:16px;margin:0 0 4px;}
.vamilio-app .meal-gate-tx p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.55;}
.vamilio-app .fam-head{flex-direction:row;flex-wrap:wrap;gap:14px;max-width:none;}
.vamilio-app .fam-head-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:220px;}
.vamilio-app .fam-head-field--wide{flex-basis:100%;max-width:520px;}

/* ── Familie: Felder dürfen nicht aus der Karte/dem Grid ausbrechen.
   Inputs haben eine intrinsische Mindestbreite; in Grid-/Flex-Spalten
   braucht es width:100% + min-width:0, sonst sprengen sie die Zelle. */
.vamilio-app .fam-card label{min-width:0;}
.vamilio-app .fam-card input,
.vamilio-app .fam-card select{width:100%;min-width:0;box-sizing:border-box;}
.vamilio-app .fam-name{width:100%;min-width:0;box-sizing:border-box;}

/* ── Selects im App-Design: eigener Pfeil + Trennstrich ─────────
   appearance:none entfernt den nativen Browser-Pfeil; stattdessen
   ein SVG-Chevron (eingerückt) und davor eine Hairline – in allen
   Browsern identisch. */
.vamilio-app .fam-card select,
.vamilio-app .field select{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  background-color:#fff;
  background-image:
    linear-gradient(var(--line,#E6DEEC), var(--line,#E6DEEC)),
    url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23513064' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat,no-repeat;
  background-size:1.5px 55%, 14px 14px;
  background-position:right 42px center, right 14px center;
  padding-right:56px;
}
.vamilio-app .fam-card select::-ms-expand,
.vamilio-app .field select::-ms-expand{display:none;}

/* ── Rezept-Pool & Zubereitungs-Schritte ──────────────────────── */
.vamilio-app .rcp-search{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:11px 14px;margin-bottom:14px;color:var(--muted);}
.vamilio-app .rcp-search .i{width:18px;height:18px;flex:0 0 18px;}
.vamilio-app .rcp-search input{border:0;outline:0;background:transparent;font:inherit;font-size:max(16px,1em);width:100%;color:var(--ink);}
.vamilio-app .rcp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;}
.vamilio-app .rcp-card{text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:14px 16px;cursor:pointer;font:inherit;display:flex;flex-direction:column;gap:5px;transition:.14s;}
.vamilio-app .rcp-card:hover{border-color:var(--plum);transform:translateY(-1px);}
.vamilio-app .rcp-card-name{font-weight:700;color:var(--ink);line-height:1.35;}
.vamilio-app .rcp-card-meta{font-size:12.5px;color:var(--muted);}
.vamilio-app .rcp-foot{margin-top:14px;display:flex;justify-content:center;}
.vamilio-app .rcp-empty{font-size:13.5px;color:var(--muted);text-align:center;max-width:520px;line-height:1.6;}
.vamilio-app .rcp-detail{background:#FFFDFA;border:1.5px solid var(--plum);border-radius:18px;padding:16px 18px;margin-bottom:14px;}
.vamilio-app .rcp-detail-head{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.vamilio-app .rcp-detail-head h4{font-family:'Bricolage Grotesque';font-size:17px;margin:0;}
.vamilio-app .rcp-detail-x{border:0;background:var(--lilac-soft);color:var(--plum);width:30px;height:30px;border-radius:50%;font-size:18px;cursor:pointer;line-height:1;}
.vamilio-app .rcp-detail-sub{font-size:11.5px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin:12px 0 4px;}
.vamilio-app .rcp-detail ul{margin:0;padding-left:18px;}
.vamilio-app .rcp-detail li{font-size:14px;margin:2px 0;}
.vamilio-app .meal-steps{font-size:14px;line-height:1.7;color:var(--ink);background:var(--lilac-soft);border-radius:12px;padding:12px 14px;margin-top:10px;}
.vamilio-app .meal-steps-btn{margin-top:8px;border:1.5px solid var(--plum);background:#fff;color:var(--plum);border-radius:30px;padding:8px 14px;font:inherit;font-size:13.5px;font-weight:700;cursor:pointer;transition:.14s;}
.vamilio-app .meal-steps-btn:hover{background:var(--plum);color:#fff;}
.vamilio-app .meal-steps-btn:disabled{opacity:.6;cursor:default;}

/* Rezept-Detail: Ersteller-Zeile */
.vamilio-app .rcp-detail-autor{font-size:12.5px;color:var(--muted);margin-top:2px;}

/* ── Rezeptbilder (gpt-image-2) ───────────────────────────────── */
.vamilio-app .rcp-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:11px;display:block;margin-bottom:4px;background:var(--lilac-soft);}
.vamilio-app .rcp-card-img--ph{background:linear-gradient(135deg,var(--lilac-soft),#FFF6EC);}
.vamilio-app .rcp-detail-img{width:100%;max-width:440px;aspect-ratio:4/3;object-fit:cover;border-radius:14px;margin-top:12px;display:block;}

/* ── Bibliothek: verlinkte Themen & "Bald"-Kennzeichnung ──────── */
.vamilio-app a.litem{text-decoration:none;color:inherit;}
.vamilio-app .litem--link{cursor:pointer;transition:.14s;}
.vamilio-app .litem--link:hover{border-color:var(--plum);transform:translateY(-1px);}
.vamilio-app .litem-go{width:34px;height:34px;border-radius:50%;background:var(--lilac-soft);color:var(--plum);display:grid;place-items:center;flex:0 0 34px;}
.vamilio-app .litem-go svg{width:16px;height:16px;}
.vamilio-app .litem--soon{opacity:.62;}
.vamilio-app .litem-soon{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--lilac-soft);border-radius:20px;padding:5px 10px;flex:0 0 auto;}
.vamilio-app form.search{display:flex;}

/* ── Rezept-Detail: Bild links, Zutaten rechts, Zubereitung unten ── */
.vamilio-app .rcp-detail-main{display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap;margin-top:12px;}
.vamilio-app .rcp-detail-main .rcp-detail-img{margin-top:0;flex:0 1 420px;min-width:240px;}
.vamilio-app .rcp-detail-ing{flex:1;min-width:230px;}
.vamilio-app .rcp-detail-ing .rcp-detail-sub{margin-top:2px;}
.vamilio-app .rcp-detail li{font-size:16px;line-height:1.55;margin:5px 0;}

/* ── Angebots-Badges in der Einkaufsliste ─────────────────────── */
.vamilio-app .offer-badge{display:inline-block;margin-left:10px;background:#FFF1E8;color:#B4490F;border:1px solid #F4C9AC;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:700;line-height:1.5;white-space:nowrap;}
.vamilio-app a.offer-badge--link{text-decoration:none;}
.vamilio-app a.offer-badge--link:hover{background:#B4490F;color:#fff;border-color:#B4490F;}

/* ── Meal-Prep: "Diese Woche im Angebot"-Leiste ───────────────── */
.vamilio-app .meal-offers{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:#FFF6EC;border:1.5px solid #F4C9AC;border-radius:16px;padding:12px 14px;margin:0 0 14px;}
.vamilio-app .meal-offers-label{font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#B4490F;flex:0 0 auto;}
.vamilio-app .meal-offer-chip{background:#fff;border:1px solid #F4C9AC;color:#7C3D10;border-radius:20px;padding:5px 11px;font-size:13px;font-weight:600;text-decoration:none;white-space:nowrap;}
.vamilio-app a.meal-offer-chip:hover{background:#B4490F;border-color:#B4490F;color:#fff;}
.vamilio-app .meal-offers-hint{flex-basis:100%;font-size:12.5px;color:var(--muted);}

/* ── Angebots-Badges: kompakt & layoutsicher (ohne Link) ──────── */
.vamilio-app .offer-badge{font-size:11.5px;padding:2px 9px;margin-left:8px;max-width:60%;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;}
@media(max-width:760px){.vamilio-app .offer-badge{display:block;margin:4px 0 0 26px;max-width:fit-content;}}

/* ── Angebots-Badge: immer eigene Zeile unter dem Artikel ─────────
   In den schmalen Listen-Spalten wurde das Badge inline abgeschnitten
   ("ALDI · …"). Auf eigener Zeile ist Händler · Preis · bis-Datum
   immer vollständig lesbar. */
.vamilio-app .meal-shop-item{flex-wrap:wrap;}
.vamilio-app .offer-badge{display:block;flex-basis:100%;width:fit-content;margin:5px 0 0 26px;max-width:calc(100% - 26px);white-space:normal;overflow:visible;text-overflow:clip;line-height:1.45;}

/* ── Angebots-Leiste: nach Geschäft gruppiert ─────────────────── */
.vamilio-app .meal-offers{flex-direction:column;align-items:flex-start;gap:9px;}
.vamilio-app .meal-offers-group{display:flex;flex-wrap:wrap;align-items:center;gap:7px;width:100%;}
.vamilio-app .meal-offers-store{flex:0 0 84px;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#B4490F;}
@media(max-width:640px){.vamilio-app .meal-offers-store{flex-basis:100%;}}

/* ── Angebots-Akkordeon: ein Geschäft pro Klapper ─────────────── */
.vamilio-app .meal-offers--acc{gap:7px;}
.vamilio-app .moa{width:100%;background:#fff;border:1px solid #F4C9AC;border-radius:13px;overflow:hidden;}
.vamilio-app .moa-head{display:flex;align-items:center;gap:12px;padding:11px 14px;cursor:pointer;list-style:none;user-select:none;}
.vamilio-app .moa-head::-webkit-details-marker{display:none;}
.vamilio-app .moa-store{font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#B4490F;}
.vamilio-app .moa-count{font-size:12.5px;color:var(--muted);flex:1;}
.vamilio-app .moa-chevron{width:9px;height:9px;border-right:2.2px solid #B4490F;border-bottom:2.2px solid #B4490F;transform:rotate(45deg);transition:.16s;margin-right:3px;}
.vamilio-app .moa[open] .moa-chevron{transform:rotate(225deg);}
.vamilio-app .moa[open] .moa-head{border-bottom:1px solid #FBE3D2;}
.vamilio-app .moa-list{margin:0;padding:4px 14px 10px;list-style:none;}
.vamilio-app .moa-list li{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 12px;padding:7px 0;border-bottom:1px dashed #FBE3D2;font-size:13.5px;}
.vamilio-app .moa-list li:last-child{border-bottom:0;}
.vamilio-app .moa-prod{flex:1;min-width:170px;font-weight:600;color:var(--ink);}
.vamilio-app .moa-price{font-weight:700;color:#B4490F;white-space:nowrap;}
.vamilio-app .moa-bis{font-size:12px;color:var(--muted);white-space:nowrap;}

/* ── Angebots-Disclaimer ──────────────────────────────────────── */
.vamilio-app .meal-offers-disclaimer,
.vamilio-app .offers-note{font-size:11.5px;color:var(--muted);line-height:1.5;}
.vamilio-app .meal-offers-disclaimer{flex-basis:100%;}
.vamilio-app .offers-note{margin-top:10px;}

/* ── Tag-Detail-Modal: über dem klebenden Header (topnav hat z-index 9000) ── */
.vamilio-app .meal-modal{z-index:99000;}

/* ── Popup-Verhalten: Milchglas-Hintergrund + Scrollstop ──────── */
html.vam-noscroll, html.vam-noscroll body{overflow:hidden;}
.vamilio-app .meal-modal{background:rgba(248,244,241,.62);backdrop-filter:blur(12px) saturate(.9);-webkit-backdrop-filter:blur(12px) saturate(.9);}
.vamilio-app .meal-modal-card{box-shadow:0 22px 60px rgba(46,26,57,.22),0 3px 14px rgba(46,26,57,.12);border:1px solid rgba(81,48,100,.08);}

/* ── "Meine Essenspläne": Karten-UI überarbeitet ──────────────── */
.vamilio-app .meal-plan-card{gap:8px;padding:16px 16px 14px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;}
.vamilio-app .meal-plan-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(46,26,57,.12);border-color:rgba(81,48,100,.24);}
.vamilio-app .meal-plan-top{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.vamilio-app .meal-plan-typ{font-size:11.5px;font-weight:800;letter-spacing:.03em;background:var(--lilac-soft);color:var(--plum);border-radius:20px;padding:3px 10px;white-space:nowrap;}
.vamilio-app .meal-plan-card.is-anlass .meal-plan-typ{background:#FFF1E8;color:#B4490F;}
.vamilio-app .meal-plan-date{font-size:12px;color:var(--muted);}
.vamilio-app .meal-plan-title{font-family:'Fraunces';font-weight:700;font-size:17px;line-height:1.3;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.vamilio-app .meal-plan-stats{font-size:12.5px;font-weight:700;color:var(--plum);}
.vamilio-app .meal-plan-preview{font-size:13px;color:var(--muted);line-height:1.45;border-top:1px dashed var(--line);padding-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.vamilio-app .meal-plan-btns{margin-top:auto;display:flex;gap:8px;}
.vamilio-app .meal-plan-btns .btn{padding:8px 16px;font-size:13.5px;}
.vamilio-app .meal-del{background:transparent;color:var(--muted);}
.vamilio-app .meal-del:hover{background:#FBE9E9;color:#b32d2e;}

/* ── Anlass: Personen-Abfrage ─────────────────────────────────── */
.vamilio-app .meal-gaeste{display:flex;align-items:center;gap:14px;margin:-4px 0 12px;padding:10px 14px;background:#FFF6EC;border:1.5px dashed #F4C9AC;border-radius:14px;}
.vamilio-app .meal-gaeste-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.vamilio-app .meal-gaeste input{width:84px;min-width:0;box-sizing:border-box;padding:9px 12px;border:1.5px solid var(--line);border-radius:12px;font:inherit;font-weight:700;color:var(--plum);background:#fff;text-align:center;}
.vamilio-app .meal-gaeste input:focus{outline:none;border-color:#B4490F;}
.vamilio-app .meal-gaeste-suffix{font-size:13px;color:var(--muted);}

/* ── Angebots-Frage-Dialog ────────────────────────────────────── */
.vamilio-app .meal-ask-card{max-width:420px;text-align:left;}
.vamilio-app .meal-ask-text{font-size:14.5px;color:var(--muted);line-height:1.55;margin:0 0 18px;}
.vamilio-app .meal-ask-btns{display:flex;flex-direction:column;gap:9px;}
.vamilio-app .meal-ask-btns .btn{width:100%;justify-content:center;}

/* ── Personen-Abfrage: mobil sauber stapeln ───────────────────── */
.vamilio-app .meal-gaeste{flex-wrap:wrap;}
.vamilio-app .meal-gaeste-row{flex:1;min-width:0;}
.vamilio-app .meal-gaeste-suffix{flex:1;min-width:140px;white-space:normal;}
@media(max-width:640px){
  .vamilio-app .meal-gaeste{flex-direction:column;align-items:flex-start;gap:9px;}
  .vamilio-app .meal-gaeste-row{width:100%;}
}

/* ── Community-Name: Live-Status ──────────────────────────────── */
.vamilio-app .fam-cname-status{font-size:12.5px;font-weight:600;color:var(--muted);display:none;}
.vamilio-app .fam-cname-status.is-show{display:block;margin-top:5px;}
.vamilio-app .fam-cname-status.is-ok{color:#1F7A3D;}
.vamilio-app .fam-cname-status.is-bad{color:#b32d2e;}
.vamilio-app .fam-cname-hint{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.4;}

/* ── Mitglieds-Farben: Bubble & Auswahl ───────────────────────── */
.vamilio-app .fam-ava{color:#fff;}
.vamilio-app .fam-color{margin:2px 0 4px;}
.vamilio-app .fam-color-label{display:block;font-size:11.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.vamilio-app .fam-swatches{display:flex;gap:9px;flex-wrap:wrap;}
.vamilio-app .fam-swatch{width:24px;height:24px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1.5px var(--line);cursor:pointer;padding:0;transition:transform .12s,box-shadow .12s;}
.vamilio-app .fam-swatch:hover{transform:scale(1.14);}
.vamilio-app .fam-swatch.is-on{box-shadow:0 0 0 2.5px var(--plum);transform:scale(1.08);}
.vamilio-app .fam-swatch.is-taken{cursor:not-allowed;opacity:.32;position:relative;}
.vamilio-app .fam-swatch.is-taken:hover{transform:none;}
.vamilio-app .fam-swatch.is-taken::after{content:"";position:absolute;top:50%;left:50%;width:130%;height:2px;background:rgba(46,26,57,.55);transform:translate(-50%,-50%) rotate(45deg);border-radius:2px;}

/* ── Rezeptbilder: weich einblenden statt aufploppen ──────────── */
.vamilio-app img.rcp-card-img{opacity:0;transition:opacity .28s ease;}
.vamilio-app img.rcp-card-img.is-loaded{opacity:1;}

/* ── Rezept-Detail mobil: als volle Zeile innerhalb der Liste ─── */
.vamilio-app #rcp-list > #rcp-detail.is-inline{grid-column:1 / -1;min-width:0;width:100%;margin:-12px 0 14px;border-top-left-radius:0;border-top-right-radius:0;border-top:0;background:#fff;border-color:var(--line);padding-top:2px;}
.vamilio-app .rcp-card.is-open{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:0;}
.vamilio-app .rcp-card.is-open:hover{transform:none;border-color:var(--line);}
.vamilio-app .rcp-detail-head--slim{justify-content:flex-end;margin:0 0 -6px;}

/* ── Rezept-Karten: fühlbares Tipp-Feedback + Lade-Hinweis ────── */
.vamilio-app .rcp-card:active{transform:scale(.992);border-color:var(--plum);}
.vamilio-app .rcp-detail-loading{padding:10px 4px 14px;color:var(--muted);font-weight:600;}

/* ── Familienplaner ───────────────────────────────────────────── */
.vamilio-app .pl-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:4px 0 12px;}
.vamilio-app .pl-nav{display:flex;align-items:center;gap:8px;min-width:0;}
.vamilio-app .pl-nav-btn{width:34px;height:34px;border-radius:10px;border:1.5px solid var(--line);background:#fff;font-size:19px;color:var(--plum);cursor:pointer;line-height:1;}
.vamilio-app .pl-weeklabel{font-weight:800;color:var(--ink);white-space:nowrap;}
.vamilio-app .pl-todaybtn{border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:7px 11px;font-weight:700;color:var(--plum);cursor:pointer;font-size:13px;}
.vamilio-app .pl-savebtn{border:0;background:var(--plum);color:#fff;border-radius:12px;padding:10px 16px;font-weight:800;cursor:pointer;font:inherit;font-size:14.5px;}
.vamilio-app .pl-addbtn{border:0;background:var(--plum);color:#fff;border-radius:10px;padding:7px 11px;font-weight:700;cursor:pointer;font:inherit;font-size:13px;}
.vamilio-app .pl-members{display:inline-flex;align-items:stretch;gap:0;background:var(--cream-deep);border:1.5px solid var(--line);border-radius:14px;padding:4px;margin-bottom:10px;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;vertical-align:top;}
.vamilio-app .pl-members::-webkit-scrollbar{display:none;}
.vamilio-app .pl-mc{--mc:var(--plum);display:inline-flex;align-items:center;gap:7px;border:0;background:transparent;border-radius:10px;padding:7px 14px;cursor:pointer;font:inherit;font-size:14px;font-weight:700;color:var(--muted);white-space:nowrap;transition:background .15s,color .15s;}
.vamilio-app .pl-mc:hover{color:var(--ink);}
.vamilio-app .pl-mc.is-active{background:#fff;color:var(--ink);box-shadow:0 2px 6px rgba(46,26,57,.10);}
.vamilio-app .pl-mc-dot{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--mc);color:#fff;font-size:11px;font-weight:800;flex:0 0 auto;}
.vamilio-app .pl-mc-name{line-height:1;}
.vamilio-app .pl-mc-count{font-weight:800;font-size:11.5px;color:var(--muted);font-variant-numeric:tabular-nums;}
.vamilio-app .pl-mc--all .pl-mc-dot--all{position:relative;background:transparent;}
.vamilio-app .pl-mc--all .pl-mc-dot--all::before{content:"";position:absolute;inset:5px;
  background:
    radial-gradient(circle at 25% 25%, currentColor 40%, transparent 44%),
    radial-gradient(circle at 75% 25%, currentColor 40%, transparent 44%),
    radial-gradient(circle at 25% 75%, currentColor 40%, transparent 44%),
    radial-gradient(circle at 75% 75%, currentColor 40%, transparent 44%);
  color:var(--muted);}
.vamilio-app .pl-mc--all.is-active .pl-mc-dot--all::before{color:var(--plum);}
.vamilio-app .pl-bub{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;color:#fff;font-size:12px;font-weight:800;border:0;flex:0 0 auto;}
.vamilio-app .pl-bub--chk{cursor:pointer;box-shadow:0 0 0 2px #fff;}
.vamilio-app .pl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;}
.vamilio-app .pl-day{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:12px 13px;min-width:0;}
.vamilio-app .pl-day.is-heute{border-color:var(--plum);box-shadow:0 0 0 1px var(--plum) inset;}
.vamilio-app .pl-day-h{display:flex;align-items:baseline;gap:8px;margin-bottom:9px;}
.vamilio-app .pl-day-k{font-weight:800;color:var(--plum);font-size:15px;}
.vamilio-app .pl-day-d{color:var(--muted);font-size:12.5px;font-weight:700;flex:1;}
.vamilio-app .pl-day-add{border:1.5px dashed var(--line);background:transparent;color:var(--muted);width:26px;height:26px;border-radius:9px;cursor:pointer;font-size:16px;line-height:1;}
.vamilio-app .pl-day-add:hover{color:var(--plum);border-color:var(--plum);}
.vamilio-app .pl-empty{color:var(--muted);opacity:.6;padding:4px 2px;}
.vamilio-app .pl-it{display:flex;align-items:center;gap:8px;background:var(--lilac-soft);border-left:4px solid var(--plum);border-radius:10px;padding:8px 10px;margin-bottom:7px;cursor:pointer;min-width:0;}
.vamilio-app .pl-it.is-termin{background:#FFF6EC;}
.vamilio-app .pl-it-titel{flex:1;min-width:0;font-size:14px;overflow-wrap:anywhere;}
.vamilio-app .pl-it-zeit{color:var(--plum);}
.vamilio-app .pl-it.is-all-done .pl-it-titel{text-decoration:line-through;opacity:.6;}
.vamilio-app .pl-it-bubs{display:flex;gap:5px;flex:0 0 auto;}
.vamilio-app .pl-hint{background:#FFF6EC;border:1.5px solid #F4C9AC;color:#B4490F;border-radius:12px;padding:10px 13px;font-weight:600;margin-bottom:10px;}
.vamilio-app .pl-modal, body > .pl-modal{position:fixed;inset:0;z-index:99000;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(248,244,241,.62);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow-y:auto;}
.vamilio-app .pl-modal[hidden], body > .pl-modal[hidden]{display:none;}
.vamilio-app .pl-modal-card, body > .pl-modal .pl-modal-card{background:#fff;border:1.5px solid var(--line);border-radius:18px;padding:16px 18px 18px;max-width:540px;width:100%;box-shadow:0 18px 50px rgba(40,20,60,.16);font-family:'Manrope',-apple-system,'Segoe UI',Roboto,sans-serif;color:var(--ink);margin:auto;max-height:calc(100vh - 32px);overflow-y:auto;}
.pl-modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.pl-modal-head h4{margin:0;font-size:17px;}
.pl-modal .pl-x{border:0;background:var(--lilac-soft);color:var(--plum);width:30px;height:30px;border-radius:50%;font-size:18px;cursor:pointer;line-height:1;}
.pl-modal .pl-f{display:block;font-weight:700;font-size:13px;color:var(--muted);margin:10px 0 0;}
.pl-modal .pl-f input,.pl-modal .pl-f select{display:block;width:100%;margin-top:5px;border:1.5px solid var(--line);border-radius:11px;padding:10px 12px;font:inherit;font-size:max(16px,1em);background:#fff;color:var(--ink);}
.pl-modal .pl-row2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media (max-width:560px){.pl-modal .pl-row2{grid-template-columns:1fr;}}
.pl-modal .pl-m-pick{display:flex;gap:8px;flex-wrap:wrap;margin-top:7px;}
.pl-modal .pl-pick{border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:7px 13px;font:inherit;font-size:13.5px;font-weight:700;cursor:pointer;color:var(--ink);}
.pl-modal .pl-pick.is-on{color:#fff;}
.pl-modal .pl-pick-leer{color:var(--muted);font-weight:600;font-size:13px;}
.pl-modal .pl-m-foot{display:flex;gap:10px;align-items:center;margin-top:16px;}
.pl-modal .pl-delbtn{border:1.5px solid #e3c4c4;background:#fff;color:#b32d2e;border-radius:12px;padding:9px 14px;font-weight:700;cursor:pointer;font:inherit;font-size:13.5px;margin-left:auto;}
.pl-modal .pl-m-err{color:#b32d2e;font-weight:700;font-size:13px;margin-top:9px;min-height:16px;}
.pl-modal button{font-family:inherit;cursor:pointer;}
.pl-modal .pl-savebtn,.pl-modal button[type=submit]{border:0;background:var(--plum);color:#fff;border-radius:12px;padding:10px 16px;font-weight:800;cursor:pointer;font:inherit;font-size:14.5px;}
.pl-modal .pl-savebtn:hover,.pl-modal button[type=submit]:hover{background:var(--plum-deep);}

/* ── Planer-Feinschliff: Checkbox-Optik & Bearbeiten-Stift ────── */
.vamilio-app .pl-bub--chk{box-shadow:none;font-size:11.5px;}
.vamilio-app .pl-it-edit{border:0;background:transparent;color:var(--muted);opacity:.65;font-size:14px;cursor:pointer;padding:2px 1px 2px 5px;flex:0 0 auto;line-height:1;}
.vamilio-app .pl-it-edit:hover{color:var(--plum);opacity:1;}
@media (max-width:560px){
	.vamilio-app .pl-weeklabel{font-size:14.5px;}
	.vamilio-app .pl-addbtn{padding:7px 11px;font-size:13px;}
}

/* ── Haushaltsbudget (vollwertig) ─────────────────────────────── */
.vamilio-app .act--btn{cursor:pointer;text-align:center;border:1.5px solid transparent;font:inherit;width:100%;transition:border-color .15s,box-shadow .15s;}
.vamilio-app .act--btn:hover{border-color:var(--plum);box-shadow:0 6px 18px rgba(81,48,100,.10);}
.vamilio-app .act-edit{display:inline-block;margin-left:6px;color:var(--plum);font-weight:800;font-size:12px;opacity:.9;}
.vamilio-app .pl-bar-actions{display:flex;gap:8px;align-items:center;}
.vamilio-app #bud-beleg-btn{display:inline-flex;align-items:center;gap:6px;}
.vamilio-app .bud-beleg-i{width:15px;height:15px;flex:0 0 15px;}
.vamilio-app .bud-cat{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);}
.vamilio-app .bud-cat:last-child{border-bottom:0;}
.vamilio-app .bud-cat-name{flex:0 0 130px;font-weight:700;font-size:14.5px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vamilio-app .bud-cat-track{flex:1;height:9px;background:var(--lilac-soft);border-radius:99px;overflow:hidden;min-width:60px;}
.vamilio-app .bud-cat-fill{display:block;height:100%;background:var(--teal);border-radius:99px;transition:width .3s;}
.vamilio-app .bud-cat-fill.is-over{background:#d98324;}
.vamilio-app .bud-cat-num{flex:0 0 auto;color:var(--muted);font-size:13px;font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums;}
.vamilio-app .bud-cat-num.is-over{color:#b4490f;}
.vamilio-app .bud-inout{color:var(--muted);font-size:13px;font-weight:700;}
.vamilio-app .bud-entry{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);}
.vamilio-app .bud-entry:last-child{border-bottom:0;}
.vamilio-app .bud-entry-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.vamilio-app .bud-entry-label{font-weight:700;font-size:14.5px;}
.vamilio-app .bud-entry-meta{font-size:12.5px;color:var(--muted);font-weight:600;}
.vamilio-app .bud-entry-amt{font-weight:800;font-size:14.5px;white-space:nowrap;font-variant-numeric:tabular-nums;}
.vamilio-app .bud-entry--income .bud-entry-amt{color:var(--teal);}
.vamilio-app .bud-entry--expense .bud-entry-amt{color:var(--ink);}
.vamilio-app .bud-entry--saving .bud-entry-amt{color:var(--plum);}
.vamilio-app .bud-entry-del{border:0;background:var(--lilac-soft);color:var(--plum);width:26px;height:26px;border-radius:50%;font-size:16px;line-height:1;cursor:pointer;flex:0 0 auto;}
.vamilio-app .bud-entry-del:hover{background:#f3d7d7;color:#b32d2e;}
.vamilio-app .bud-entry-edit{border:0;background:var(--lilac-soft);color:var(--plum);width:26px;height:26px;border-radius:50%;font-size:13px;line-height:1;cursor:pointer;flex:0 0 auto;}
.vamilio-app .bud-entry-edit:hover{background:var(--plum);color:#fff;}
.vamilio-app .bud-empty{padding:14px 2px;color:var(--muted);}
.vamilio-app .bud-foot{margin-top:14px;color:var(--muted);font-size:13.5px;}
.vamilio-app .bud-foot a{color:var(--plum);font-weight:700;}
.vamilio-app .bud-hint{color:var(--muted);font-size:13.5px;margin:0 0 12px;}
/* Kategorie-Editor im Modal */
.pl-modal .bud-cat-edit{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.pl-modal .bud-cat-name-in{flex:1;border:1.5px solid var(--line);border-radius:11px;padding:9px 12px;font:inherit;font-size:max(16px,1em);background:#fff;color:var(--ink);min-width:0;}
.pl-modal .bud-cat-plan-in{width:90px;border:1.5px solid var(--line);border-radius:11px;padding:9px 12px;font:inherit;font-size:max(16px,1em);background:#fff;color:var(--ink);text-align:right;}
.pl-modal .bud-cat-eur{color:var(--muted);font-weight:700;flex:0 0 auto;}
.pl-modal .bud-cat-del{border:0;background:var(--lilac-soft);color:var(--plum);width:30px;height:30px;border-radius:50%;font-size:18px;line-height:1;cursor:pointer;flex:0 0 auto;}
.pl-modal .bud-cat-del:hover{background:#f3d7d7;color:#b32d2e;}
.pl-modal .bud-cat-autotag{flex:0 0 auto;font-size:11px;font-weight:800;color:var(--plum);background:var(--lilac-soft);border-radius:999px;padding:4px 9px;text-transform:uppercase;letter-spacing:.04em;}
.pl-modal .bud-cat-edit[data-auto="1"] input{background:var(--cream-deep);color:var(--muted);cursor:not-allowed;}
.pl-modal .bud-cat-addrow{display:inline-flex;align-items:center;gap:6px;border:1.5px dashed var(--line);background:transparent;color:var(--plum);border-radius:11px;padding:9px 14px;font:inherit;font-weight:700;font-size:13.5px;cursor:pointer;margin-top:4px;}
.pl-modal .bud-cat-addrow:hover{border-color:var(--plum);}
.pl-modal .bud-cat-addrow svg{width:15px;height:15px;}
@media (max-width:560px){.vamilio-app .bud-cat-name{flex-basis:88px;}}

/* ── Mental-Load-Verteiler ─────────────────────────────────────── */
.vamilio-app .ml-intro{color:var(--muted);font-size:14px;margin:0 0 16px;}
.vamilio-app .ml-group{margin-bottom:18px;}
.vamilio-app .ml-group-h{font-weight:800;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;display:flex;align-items:center;justify-content:space-between;gap:8px;}
.vamilio-app .ml-group-label{flex:1;min-width:0;}
.vamilio-app .ml-group-tools,.vamilio-app .ml-task-tools{display:flex;gap:4px;flex:0 0 auto;}
.vamilio-app .ml-icon{border:0;background:transparent;color:var(--muted);width:28px;height:28px;border-radius:8px;font-size:15px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;}
.vamilio-app .ml-icon:hover{background:var(--lilac-soft);color:var(--plum);}
.vamilio-app .ml-add-task{margin-top:4px;border:1.5px dashed var(--line);background:transparent;color:var(--muted);border-radius:12px;padding:9px 14px;font:inherit;font-size:13px;font-weight:700;cursor:pointer;width:100%;}
.vamilio-app .ml-add-task:hover{border-color:var(--plum);color:var(--plum);}
.vamilio-app .ml-custom-head{font-weight:800;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--plum);margin:24px 0 10px;padding-top:18px;border-top:1.5px solid var(--line);}
.vamilio-app .ml-add-group{display:block;width:100%;border:1.5px dashed var(--line);background:transparent;color:var(--plum);border-radius:14px;padding:13px 16px;font:inherit;font-size:14px;font-weight:800;cursor:pointer;margin:6px 0 18px;}
.vamilio-app .ml-add-group:hover{border-color:var(--plum);background:var(--lilac-soft);}
.vamilio-app .ml-task{display:flex;align-items:center;gap:12px;padding:11px 14px;border:1.5px solid var(--line);border-radius:14px;background:var(--paper);margin-bottom:8px;flex-wrap:wrap;}
.vamilio-app .ml-task.is-on{border-color:color-mix(in srgb, var(--plum) 35%, var(--line));background:#fff;}
.vamilio-app .ml-check{flex:0 0 auto;width:26px;height:26px;border-radius:8px;border:1.5px solid var(--line);background:#fff;color:#fff;font-size:15px;font-weight:800;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;}
.vamilio-app .ml-task.is-on .ml-check{background:var(--plum);border-color:var(--plum);}
.vamilio-app .ml-task-label{flex:1;min-width:140px;font-size:14.5px;font-weight:600;cursor:pointer;}
.vamilio-app .ml-who{display:flex;gap:6px;flex:0 0 auto;}
.vamilio-app .ml-pill{--mc:var(--plum);border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:6px 12px;font:inherit;font-size:12.5px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s;}
.vamilio-app .ml-pill:hover{border-color:var(--mc);}
.vamilio-app .ml-pill-a.is-sel,.vamilio-app .ml-pill-b.is-sel{background:var(--mc);border-color:var(--mc);color:#fff;}
.vamilio-app .ml-pill-both.is-sel{background:var(--ink);border-color:var(--ink);color:#fff;}
.vamilio-app .ml-balance{background:#fff;border:1.5px solid var(--line);border-radius:18px;padding:16px 18px;margin-bottom:18px;}
.vamilio-app .ml-balance-head{display:flex;align-items:center;justify-content:space-between;font-weight:800;font-size:14px;margin-bottom:10px;}
.vamilio-app .ml-bal-mid{color:var(--muted);font-variant-numeric:tabular-nums;}
.vamilio-app .ml-bal-name{max-width:42%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vamilio-app .ml-balance-bar{display:flex;height:12px;border-radius:99px;overflow:hidden;background:var(--lilac-soft);}
.vamilio-app .ml-balance-bar > span{display:block;height:100%;transition:width .3s;}
.vamilio-app .ml-balance-hint{margin:10px 0 0;font-size:13.5px;color:var(--muted);font-weight:600;}
.vamilio-app .ml-foot{display:flex;align-items:center;gap:12px;margin-top:4px;}
.vamilio-app .ml-saved{color:var(--teal);font-weight:800;font-size:13px;}
.vamilio-app .ml-saved.is-error{color:#b4490f;}
@media (max-width:560px){
	.vamilio-app .ml-task{gap:8px;}
	.vamilio-app .ml-who{width:100%;justify-content:flex-start;}
}

/* ── Lern-Tutor (ruhig, edel – vamilio) ────────────────────────── */
.vamilio-app .tutor-field{margin:0 0 26px;}
.vamilio-app .tutor-field-label{font-family:'Bricolage Grotesque';font-weight:700;font-size:13px;letter-spacing:.02em;color:var(--muted);margin:0 0 12px;}
.vamilio-app .tutor-opt{font-weight:500;color:var(--lilac);}

/* Fach-Karten: einheitlich, ruhig, mit feiner Linie */
.vamilio-app .tutor-subjects{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.vamilio-app .tutor-subj{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 14px;border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--paper);cursor:pointer;transition:border-color .18s,box-shadow .18s,transform .18s;}
.vamilio-app .tutor-subj:hover{border-color:var(--lilac);transform:translateY(-2px);}
.vamilio-app .tutor-subj.is-sel{border-color:var(--plum);box-shadow:0 10px 28px rgba(81,48,100,.12);}
.vamilio-app .tutor-subj-ic{width:48px;height:48px;border-radius:50%;background:var(--lilac-soft);display:flex;align-items:center;justify-content:center;color:var(--plum);transition:background .18s;}
.vamilio-app .tutor-subj.is-sel .tutor-subj-ic{background:var(--plum);color:#fff;}
.vamilio-app .tutor-subj-ic svg{width:22px;height:22px;}
.vamilio-app .tutor-subj-name{font-family:'Bricolage Grotesque';font-weight:700;font-size:14.5px;color:var(--ink);}

/* Klassenstufe */
.vamilio-app .tutor-grades{display:flex;flex-wrap:wrap;gap:8px;}
.vamilio-app .tutor-grades-empty{color:var(--muted);font-size:14px;margin:0;}
.vamilio-app .tutor-grade{min-width:48px;height:48px;padding:0 4px;border:1.5px solid var(--line);border-radius:14px;background:var(--paper);cursor:pointer;font-family:'Bricolage Grotesque';font-weight:700;font-size:16px;color:var(--ink);transition:.15s;}
.vamilio-app .tutor-grade:hover{border-color:var(--lilac);}
.vamilio-app .tutor-grade.is-sel{background:var(--plum);border-color:var(--plum);color:#fff;}

.vamilio-app .tutor-topic{width:100%;box-sizing:border-box;border:1.6px solid var(--line);border-radius:14px;padding:14px 16px;font:inherit;font-size:max(16px,1em);background:var(--cream);color:var(--ink);transition:.16s;}
.vamilio-app .tutor-topic:focus{outline:none;border-color:var(--plum);background:var(--paper);}
.vamilio-app .tutor-topic-hint{color:var(--muted);font-size:13px;margin:8px 0 0;line-height:1.5;}
.vamilio-app .tutor-start{margin-top:6px;}
.vamilio-app .tutor-start:disabled{background:var(--lilac);box-shadow:none;cursor:not-allowed;}

/* Übungs-Ansicht */
.vamilio-app .tutor-quiz-top{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.vamilio-app .tutor-back{border:0;background:transparent;color:var(--plum);font-family:'Bricolage Grotesque';font-weight:700;font-size:14.5px;cursor:pointer;padding:6px 0;}
.vamilio-app .tutor-where{font-family:'Bricolage Grotesque';font-weight:600;font-size:13.5px;color:var(--muted);}

.vamilio-app .tutor-progressbar{height:6px;background:var(--lilac-soft);border-radius:99px;overflow:hidden;margin-bottom:16px;}
.vamilio-app .tutor-progressbar > span{display:block;height:100%;width:0;background:var(--plum);border-radius:99px;transition:width .4s ease;}

.vamilio-app .tutor-scoreboard{display:flex;gap:10px;margin-bottom:18px;}
.vamilio-app .tutor-score{flex:1;background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:14px;text-align:center;}
.vamilio-app .tutor-score-num{display:block;font-family:'Fraunces',serif;font-size:24px;font-weight:600;color:var(--ink);line-height:1;}
.vamilio-app .tutor-score-lbl{display:block;font-size:12px;color:var(--muted);margin-top:6px;}

.vamilio-app .tutor-card{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r-md);padding:28px;}
.vamilio-app .tutor-card-head{display:flex;align-items:center;gap:11px;margin-bottom:18px;}
.vamilio-app .tutor-buddy{flex:0 0 auto;width:38px;height:38px;border-radius:50%;background:linear-gradient(150deg,var(--plum),var(--orchid));display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 6px 16px rgba(81,48,100,.22);transition:transform .25s,box-shadow .25s;}
.vamilio-app .tutor-buddy svg{width:18px;height:18px;}
.vamilio-app .tutor-buddy.is-think{animation:tutorPulse 1.4s ease-in-out infinite;}
.vamilio-app .tutor-buddy.is-happy{transform:scale(1.08);box-shadow:0 8px 22px rgba(31,157,87,.4);background:linear-gradient(150deg,#1f9d57,#3bbf78);}
@keyframes tutorPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.07);}}
@media (prefers-reduced-motion:reduce){.vamilio-app .tutor-buddy{animation:none;transition:none;}}
.vamilio-app .tutor-buddy-line{font-size:14px;color:var(--muted);font-style:italic;}

.vamilio-app .tutor-q{font-family:'Fraunces',serif;font-size:clamp(21px,3.2vw,27px);font-weight:600;color:var(--ink);margin-bottom:22px;line-height:1.32;}
.vamilio-app .tutor-answer{display:flex;flex-direction:column;gap:9px;}
.vamilio-app .tutor-input{width:100%;box-sizing:border-box;border:1.6px solid var(--line);border-radius:14px;padding:15px 16px;font:inherit;font-size:max(16px,1.05em);background:var(--cream);color:var(--ink);transition:.16s;}
.vamilio-app .tutor-input:focus{outline:none;border-color:var(--plum);background:var(--paper);}
.vamilio-app .tutor-choice{text-align:left;border:1.6px solid var(--line);border-radius:14px;padding:14px 16px;background:var(--cream);font:inherit;font-size:15.5px;font-weight:600;color:var(--ink);cursor:pointer;transition:.15s;}
.vamilio-app .tutor-choice:hover{border-color:var(--lilac);}
.vamilio-app .tutor-choice.is-sel{border-color:var(--plum);background:var(--lilac-soft);}
.vamilio-app .tutor-choice.is-correct{border-color:#1f9d57;background:#edf7f1;color:#0f6b39;}
.vamilio-app .tutor-choice.is-incorrect{border-color:#c2554b;background:#faecea;color:#a23f33;}
.vamilio-app .tutor-feedback{margin-top:18px;padding:15px 17px;border-radius:14px;font-size:14.5px;line-height:1.55;}
.vamilio-app .tutor-feedback.is-right{background:#edf7f1;color:#0f6b39;}
.vamilio-app .tutor-feedback.is-wrong{background:#faecea;color:#a23f33;}
.vamilio-app .tutor-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;align-items:center;}
.vamilio-app .tutor-explain{background:var(--lilac-soft);color:var(--plum);box-shadow:none;margin-left:auto;}
.vamilio-app .tutor-explain:hover{background:var(--lilac);}
.vamilio-app .tutor-ai-out{margin-top:18px;padding:18px 20px;background:var(--cream);border:1px solid var(--line);border-radius:16px;font-size:14.5px;line-height:1.65;white-space:pre-wrap;color:var(--ink);}

@media (max-width:600px){
	.vamilio-app .tutor-subjects{grid-template-columns:repeat(2,1fr);}
	.vamilio-app .tutor-explain{margin-left:0;width:100%;}
	.vamilio-app .tutor-card{padding:20px;}
}


/* ── Testphasen-Banner ─────────────────────────────────────────── */
.vamilio-app .trial-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(100deg,var(--lilac-soft),var(--paper));border:1.5px solid var(--lilac);border-radius:var(--r-sm);padding:14px 18px;margin-bottom:18px;font-size:14.5px;color:var(--ink);}
.vamilio-app .trial-banner svg{width:22px;height:22px;flex:none;fill:var(--plum);}
.vamilio-app .trial-banner a{color:var(--plum);font-weight:700;text-decoration:underline;white-space:nowrap;margin-left:4px;}
.vamilio-app .trial-banner.is-over{background:#fbf0ec;border-color:#e8c5b6;}
.vamilio-app .trial-banner.is-over svg{fill:#b4490f;}
.vamilio-app .trial-banner.is-over a{color:#b4490f;}

/* ── Familien-Einladung: eigener Bereich + Halbpreis ──────────── */
.vamilio-app .fam-inv-cost{font-size:12px;font-weight:600;color:var(--plum);background:var(--lilac-soft);border-radius:99px;padding:2px 9px;margin-left:6px;white-space:nowrap;}
.vamilio-app .fam-invitebox{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r-md);padding:22px;margin:8px 0 18px;}
.vamilio-app .fam-invitebox-h{font-family:'Fraunces',serif;font-size:19px;font-weight:600;color:var(--ink);margin-bottom:4px;}
.vamilio-app .fam-invitebox-sub{font-size:14px;color:var(--muted);line-height:1.5;margin:0 0 14px;}
.vamilio-app .fam-invite-kinds{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap;}
.vamilio-app .fam-invite-kind{flex:1;min-width:200px;display:flex;align-items:flex-start;gap:10px;border:1.5px solid var(--line);border-radius:14px;padding:12px 14px;cursor:pointer;background:var(--cream);transition:border-color .15s,background .15s;}
.vamilio-app .fam-invite-kind:has(input:checked){border-color:var(--plum);background:var(--paper);box-shadow:0 0 0 2px rgba(81,48,100,.12);}
.vamilio-app .fam-invite-kind input{margin-top:3px;accent-color:var(--plum);width:16px;height:16px;flex:none;}
.vamilio-app .fam-invite-kind-body{display:flex;flex-direction:column;gap:2px;}
.vamilio-app .fam-invite-kind-body b{font-size:14.5px;color:var(--ink);}
.vamilio-app .fam-invite-kind-body small{font-size:12.5px;color:var(--muted);line-height:1.45;}
.vamilio-app #fam-invite-cost{display:block;margin-top:4px;color:var(--plum);font-weight:600;}
.vamilio-app .fam-invitebox-form{display:flex;gap:10px;flex-wrap:wrap;}
.vamilio-app .fam-invite-in{flex:1;min-width:160px;box-sizing:border-box;border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;font:inherit;font-size:max(16px,1em);background:var(--cream);color:var(--ink);}
.vamilio-app .fam-invite-in:focus{outline:none;border-color:var(--plum);background:var(--paper);}
.vamilio-app .fam-invite-msg{font-size:13.5px;margin-top:10px;color:var(--muted);}
.vamilio-app .fam-invite-msg.is-ok{color:#0f6b39;}
.vamilio-app .fam-invite-msg.is-error{color:#b4490f;}
.vamilio-app .fam-invite-list{margin-top:16px;}
.vamilio-app .fam-invite-list-h{font-family:'Bricolage Grotesque';font-weight:700;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.vamilio-app .fam-invite-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;font-size:14.5px;color:var(--ink);padding:6px 0;border-bottom:1px solid var(--line);}
.vamilio-app .fam-invite-row em{font-style:normal;color:var(--muted);font-size:13px;}
.vamilio-app .fam-invite-total{margin-top:10px;font-size:14.5px;color:var(--ink);}
.vamilio-app .fam-invite-total b{font-family:'Fraunces',serif;color:var(--plum);}
.vamilio-app .fam-inv-copy{border:0;background:var(--lilac-soft);color:var(--plum);font:inherit;font-weight:600;font-size:13px;border-radius:8px;padding:4px 10px;cursor:pointer;margin-left:4px;}
.vamilio-app .ko-invite-member{margin-top:12px;padding:12px 14px;background:var(--cream);border:1.5px solid var(--line);border-radius:14px;}
.vamilio-app .ko-invite-member-q{font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:8px;}
.vamilio-app .ko-invite-radio{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--ink);margin-right:16px;cursor:pointer;}
.vamilio-app .ko-invite-radio input{accent-color:var(--plum);width:16px;height:16px;}
.vamilio-app #ko-invite-pick{margin-top:10px;width:100%;}
@media (max-width:600px){ .vamilio-app .fam-invite-in{min-width:0;} .vamilio-app .fam-invitebox-form #fam-invite-go{width:100%;} }

/* ── Tagebuch ──────────────────────────────────────────────────── */
.vamilio-app .tb-write{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r-md);padding:22px;margin-bottom:28px;}
.vamilio-app .tb-write-row{display:flex;gap:14px;margin-bottom:12px;flex-wrap:wrap;}
.vamilio-app .tb-fld{display:flex;flex-direction:column;gap:6px;}
.vamilio-app .tb-fld label{font-family:'Bricolage Grotesque';font-weight:700;font-size:12.5px;color:var(--muted);}
.vamilio-app .tb-fld input,.vamilio-app .tb-fld select{border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;font:inherit;font-size:max(16px,15px);background:var(--cream);color:var(--ink);}
.vamilio-app .tb-fld select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:46px;background-image:linear-gradient(var(--line),var(--line)),url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%23513064' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:right 36px center,right 14px center;background-size:1.5px 60%,12px 8px;}
.vamilio-app .tb-fld input:focus,.vamilio-app .tb-fld select:focus{outline:none;border-color:var(--plum);}
.vamilio-app .tb-titel,.vamilio-app .tb-text{width:100%;box-sizing:border-box;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font:inherit;background:var(--cream);color:var(--ink);margin-bottom:12px;}
.vamilio-app .tb-titel{font-size:max(16px,15.5px);font-weight:600;}
.vamilio-app .tb-text{font-size:max(16px,15px);line-height:1.6;resize:vertical;min-height:120px;}
.vamilio-app .tb-grateful-label{display:block;font-family:'Bricolage Grotesque';font-weight:700;font-size:13px;color:var(--plum);margin:2px 0 6px;}
.vamilio-app .tb-grateful-hint{font-weight:400;color:var(--muted);}
.vamilio-app .tb-dankbar{width:100%;box-sizing:border-box;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font:inherit;font-size:max(16px,15px);line-height:1.6;background:var(--cream);color:var(--ink);resize:none;height:150px;margin-bottom:12px;}
.vamilio-app .tb-dankbar:focus{outline:none;border-color:var(--plum);background:var(--paper);}
.vamilio-app .tb-card-grateful{margin-top:8px;padding:8px 12px;background:var(--lilac-soft);border-radius:10px;font-size:14px;line-height:1.5;color:var(--ink);}
.vamilio-app .tb-card-grateful-h{font-weight:700;color:var(--plum);}
.vamilio-app .tb-titel:focus,.vamilio-app .tb-text:focus{outline:none;border-color:var(--plum);background:var(--paper);}
.vamilio-app .tb-write-actions{display:flex;align-items:center;gap:12px;}
.vamilio-app .tb-cancel{background:var(--lilac-soft);color:var(--plum);box-shadow:none;}
.vamilio-app .tb-saved{font-size:13.5px;color:#0f6b39;font-weight:600;}
.vamilio-app .tb-saved.is-error{color:#b4490f;}

.vamilio-app .tb-list-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap;}
.vamilio-app .tb-list-title{font-family:'Fraunces',serif;font-size:20px;font-weight:600;color:var(--ink);margin:0;}
.vamilio-app .tb-export{background:var(--plum);color:#fff;display:inline-flex;align-items:center;gap:8px;text-decoration:none;}
.vamilio-app .tb-export .i{width:16px;height:16px;}
.vamilio-app .tb-export:hover{background:var(--plum-deep);}

.vamilio-app .tb-list{display:flex;flex-direction:column;gap:14px;}
.vamilio-app .tb-empty{color:var(--muted);font-size:14px;}
.vamilio-app .tb-card{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:18px 20px;}
.vamilio-app .tb-card-top{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap;}
.vamilio-app .tb-card-date{font-family:'Bricolage Grotesque';font-weight:700;font-size:13px;color:var(--plum);}
.vamilio-app .tb-card-mood{font-size:12px;color:var(--muted);background:var(--lilac-soft);border-radius:99px;padding:2px 10px;}
.vamilio-app .tb-card-actions{margin-left:auto;display:flex;gap:6px;}
.vamilio-app .tb-card-actions button{border:0;background:transparent;font:inherit;font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:8px;}
.vamilio-app .tb-edit{color:var(--plum);}
.vamilio-app .tb-edit:hover{background:var(--lilac-soft);}
.vamilio-app .tb-del{color:#a23f33;}
.vamilio-app .tb-del:hover{background:#faecea;}
.vamilio-app .tb-card-title{font-family:'Fraunces',serif;font-size:17px;font-weight:600;color:var(--ink);margin:2px 0 8px;}
.vamilio-app .tb-card-body{font-size:14.5px;line-height:1.6;color:var(--ink);}
@media (max-width:600px){
	.vamilio-app .tb-fld{flex:1;}
	.vamilio-app .tb-export{width:100%;justify-content:center;}
	.vamilio-app .tb-list-head{align-items:stretch;}
}

/* ── Paket-Gates: Lock-Box, Leseprobe, Monats-Kontingent ──────── */
.vamilio-app .plan-lock{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:18px 20px;max-width:640px;margin:6px 0 18px;}
.vamilio-app .plan-lock-h{font-weight:800;color:var(--plum);font-size:16px;margin-bottom:6px;}
.vamilio-app .plan-lock p{margin:0 0 12px;color:var(--ink);line-height:1.55;}
.vamilio-app .plan-lock-cta{display:inline-block;background:var(--plum);color:#fff;border-radius:12px;padding:10px 16px;font-weight:800;text-decoration:none;}
.vamilio-app .plan-lock--inline{padding:12px 14px;font-size:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.vamilio-app .plan-lock--inline .plan-lock-cta{padding:7px 12px;font-size:13px;}
.vamilio-app .pl-demo{opacity:.85;pointer-events:none;max-width:980px;}
.vamilio-app .meal-quota-note{background:#FFF6EC;border:1.5px solid #F4C9AC;color:#B4490F;border-radius:12px;padding:9px 12px;font-weight:600;font-size:13.5px;margin:0 0 10px;}
.vamilio-app .meal-quota-note a{color:#B4490F;font-weight:800;}
.vamilio-app .rcp-lese{background:#FFF6EC;border:1.5px solid #F4C9AC;color:#B4490F;border-radius:12px;padding:10px 13px;font-weight:600;margin:0 0 12px;}

/* ── Planer: Monatsansicht (Tabs, Kalender, Agenda) ───────────── */
.vamilio-app .pl-tabs{display:inline-flex;gap:4px;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:4px;margin:0 0 12px;}
.vamilio-app .pl-tab{border:0;background:transparent;border-radius:9px;padding:7px 16px;font:inherit;font-size:13.5px;font-weight:800;color:var(--muted);cursor:pointer;}
.vamilio-app .pl-tab.is-on{background:var(--plum);color:#fff;}
.vamilio-app .plm-cal{width:100%;}
.vamilio-app .plm-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.vamilio-app .plm-wd{text-align:center;font-size:12px;font-weight:800;color:var(--muted);padding:2px 0 6px;}
.vamilio-app .plm-cell{position:relative;border:1.5px solid transparent;background:#fff;border-radius:12px;aspect-ratio:1/1;min-height:42px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;font:inherit;padding:0;}
@media(min-width:980px){.vamilio-app .plm-cell{aspect-ratio:auto;height:96px;}}
.vamilio-app .plm-cell:hover{border-color:var(--line);}
.vamilio-app .plm-num{font-weight:700;color:var(--ink);font-size:14.5px;}
.vamilio-app .plm-cell.is-out{background:transparent;}
.vamilio-app .plm-cell.is-out .plm-num{color:var(--muted);opacity:.45;}
.vamilio-app .plm-cell.is-heute{border-color:var(--plum);}
.vamilio-app .plm-cell.is-sel{background:var(--plum);}
.vamilio-app .plm-cell.is-sel .plm-num{color:#fff;}
.vamilio-app .plm-bars{display:flex;gap:3px;min-height:4px;}
.vamilio-app .plm-bar{width:14px;height:4px;border-radius:99px;display:inline-block;}
.vamilio-app .plm-cell.is-sel .plm-bar{background:#fff !important;opacity:.9;}
.vamilio-app .plm-agenda{width:100%;margin-top:18px;display:flex;flex-direction:column;gap:14px;}
.vamilio-app .plm-day{display:flex;gap:12px;align-items:flex-start;}
.vamilio-app .plm-badge{flex:0 0 44px;text-align:center;color:var(--plum);border-bottom:2.5px solid var(--plum);padding-bottom:5px;margin-top:4px;}
.vamilio-app .plm-badge b{display:block;font-size:19px;line-height:1.05;}
.vamilio-app .plm-badge span{font-size:12px;font-weight:700;}
.vamilio-app .plm-card{flex:1;min-width:0;border:1.5px solid;border-radius:14px;padding:11px 13px;}
.vamilio-app .plm-it{display:flex;align-items:center;gap:8px;cursor:pointer;min-width:0;padding:2px 0;}
.vamilio-app .plm-it-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
.vamilio-app .plm-it .pl-it-titel{font-weight:700;font-size:14.5px;}
.vamilio-app .plm-it-zeit{font-size:12.5px;color:var(--muted);font-weight:600;}
.vamilio-app .plm-it.is-all-done .pl-it-titel{text-decoration:line-through;opacity:.6;}
.vamilio-app .plm-divider{height:1px;background:rgba(0,0,0,.08);margin:8px 0;}
.vamilio-app .plm-empty{padding:10px 2px;}
@media (min-width:761px){
	.vamilio-app .plm-cell{min-height:64px;}
	.vamilio-app .plm-num{font-size:15.5px;}
}

/* ── iOS Safari: Datum/Uhrzeit-Felder bändigen ─────────────────────
   iOS rendert date/time-Inputs mit eigener Mindestbreite (ragen aus
   der Karte), zentriertem Wert und ohne unseren Rahmen. appearance:
   none gibt uns die Kontrolle zurück; min-height verhindert das
   anschließende Zusammenfallen der Feldhöhe. */
.vamilio-app .pl-f input[type="date"],
.vamilio-app .pl-f input[type="time"]{
	-webkit-appearance:none;
	appearance:none;
	min-width:0;
	max-width:100%;
	min-height:47px;
	text-align:left;
}
.vamilio-app .pl-f input[type="date"]::-webkit-date-and-time-value,
.vamilio-app .pl-f input[type="time"]::-webkit-date-and-time-value{
	text-align:left;
	margin:0;
}

/* ── Planer: Erinnerung & Geburtstag ──────────────────────────── */
.vamilio-app .pl-it.is-erinnerung{background:#FFF8E7;}
.vamilio-app .pl-it.is-geb{background:#FDF0F6;}

/* ── Familie: Planer-Einladung ────────────────────────────────── */
.vamilio-app .fam-invite{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px;}
.vamilio-app .fam-inv-btn{border:1.5px solid var(--plum);background:#fff;color:var(--plum);border-radius:10px;padding:6px 12px;font:inherit;font-size:13px;font-weight:800;cursor:pointer;}
.vamilio-app .fam-inv-btn:disabled{opacity:.55;}
.vamilio-app .fam-inv-ok{color:#1F7A3D;font-weight:800;font-size:13.5px;}
.vamilio-app .fam-inv-tipp{color:var(--muted);font-size:12.5px;}
.vamilio-app .fam-inv-msg{font-size:12.5px;color:var(--muted);}
.vamilio-app .fam-inv-copy{border:0;background:transparent;color:var(--plum);font:inherit;font-size:12.5px;font-weight:800;text-decoration:underline;cursor:pointer;padding:0;}

/* ── Konto: Gefahrenzone ──────────────────────────────────────── */
.vamilio-app .panel-danger{border:1.5px solid #E5B4B4;}
.vamilio-app .panel-danger .panel-head h3{color:#b32d2e;}
.vamilio-app .acct-del-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:10px;}
.vamilio-app .acct-del-row .fam-f{max-width:260px;margin:0;}
.vamilio-app .btn-danger{border:1.5px solid #b32d2e;background:#fff;color:#b32d2e;border-radius:12px;padding:10px 16px;font:inherit;font-weight:800;cursor:pointer;}
.vamilio-app .btn-danger:hover{background:#b32d2e;color:#fff;}
.vamilio-app .btn-danger:disabled{opacity:.55;}

/* ── Agenda: eine Karte je Eintrag, in Personenfarbe ──────────── */
.vamilio-app .plm-cards{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px;}
.vamilio-app .plm-cards .plm-card{flex:0 0 auto;}

/* ── Mail-Diagnose unter dem Einladen-Knopf ───────────────────── */
.vamilio-app .fam-inv-err{color:#b32d2e;font-weight:600;display:inline-block;margin-top:4px;}
