/* =====================================================================
   Taskly — Styles. Tokens 1:1 aus design.md.
   ===================================================================== */

:root {
  /* Indigo (Marke) */
  --indigo-50:#EEEEFB; --indigo-100:#E0E0F9; --indigo-200:#C4C3F3;
  --indigo-300:#9F9CEC; --indigo-400:#7C77E6; --indigo-500:#5F58E0;
  --indigo-600:#4F47D6; --indigo-700:#413AB8; --indigo-800:#353093; --indigo-900:#2A2670;

  --color-primary:var(--indigo-600);
  --color-primary-hover:var(--indigo-700);
  --color-primary-subtle:var(--indigo-50);
  --color-on-primary:#FFFFFF;

  --color-bg:#F5F5F7; --color-surface:#FFFFFF; --color-surface-2:#FAFAFC;
  --color-border:#E5E5EA; --color-text:#1D1D1F;
  --color-text-secondary:#6E6E73; --color-text-tertiary:#A1A1A6;

  --color-spark:#F5A623; --color-spark-bright:#FFB93D;
  --color-celebrate:#FF5C8A; --color-xp:var(--indigo-500);
  --color-success:#2FBF71; --color-due-soon:#F2A33C; --color-danger:#E0483D;

  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"SF Pro Text",sans-serif;
  --font-display:"Nunito",var(--font-body);

  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;
  --space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;
  --radius-sm:8px;--radius-md:12px;--radius-lg:16px;
  --radius-xl:20px;--radius-2xl:28px;--radius-full:999px;
  --tap-min:44px; --content-max:480px;

  --shadow-sm:0 1px 2px rgba(0,0,0,.04),0 1px 3px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px rgba(0,0,0,.06),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 32px rgba(0,0,0,.10),0 4px 8px rgba(0,0,0,.05);

  --dur-fast:150ms;--dur-base:220ms;--dur-slow:380ms;--dur-reward:600ms;
  --ease-standard:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(0,0,.2,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);

  /* Domain-Farben */
  --dom-haushalt:#5AC8C8; --dom-privat:var(--indigo-400);
  --dom-business:#7E8AA0; --dom-termin:#C8924A;
}

/* Dark-Tokens (per Klasse referenziert, damit explizit + Auto sie teilen) */
[data-theme="dark"]{
  --color-primary:#6E68F0; --color-primary-hover:#837EF3; --color-primary-subtle:#1E1B3A;
  --color-bg:#000000; --color-surface:#1C1C1E; --color-surface-2:#2C2C2E;
  --color-border:#38383A; --color-text:#F5F5F7;
  --color-text-secondary:#98989D; --color-text-tertiary:#636366;
  --color-spark:#FFB93D; --color-celebrate:#FF6F9C; --color-success:#32D27A; --color-due-soon:#F7B250;
  --color-xp:#7C77E6;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-md:0 4px 16px rgba(0,0,0,.5);
  --shadow-lg:0 16px 40px rgba(0,0,0,.6);
}
/* Auto: System-Dark respektieren, außer der User hat explizit „hell" gewählt (design.md §10) */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]):not([data-theme="dark"]){
    --color-primary:#6E68F0; --color-primary-hover:#837EF3; --color-primary-subtle:#1E1B3A;
    --color-bg:#000000; --color-surface:#1C1C1E; --color-surface-2:#2C2C2E;
    --color-border:#38383A; --color-text:#F5F5F7;
    --color-text-secondary:#98989D; --color-text-tertiary:#636366;
    --color-spark:#FFB93D; --color-celebrate:#FF6F9C; --color-success:#32D27A; --color-due-soon:#F7B250;
  --color-xp:#7C77E6;
    --shadow-sm:0 1px 2px rgba(0,0,0,.4);
    --shadow-md:0 4px 16px rgba(0,0,0,.5);
    --shadow-lg:0 16px 40px rgba(0,0,0,.6);
  }
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-body); background:var(--color-bg); color:var(--color-text);
  -webkit-font-smoothing:antialiased; line-height:1.4;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}
.hidden{display:none !important}

/* Typo */
.display{font-family:var(--font-display);font-weight:800;font-size:34px;line-height:1.18;letter-spacing:-.02em}
.brand{font-family:var(--font-display);font-weight:800;font-size:34px;letter-spacing:-.02em}
.brand-mini{font-family:var(--font-display);font-weight:800;font-size:18px;letter-spacing:-.01em}
.h3{font-family:var(--font-display);font-weight:700;font-size:18px}
.muted{color:var(--color-text-secondary)}
.small{font-size:13px;line-height:1.5}
.error{color:var(--color-danger);font-size:13px;min-height:18px;margin-top:var(--space-2)}

/* Buttons */
.btn{
  font-family:var(--font-body); font-weight:600; font-size:16px;
  min-height:var(--tap-min); padding:0 var(--space-5); border:none; cursor:pointer;
  border-radius:var(--radius-md); transition:transform var(--dur-fast) var(--ease-standard),
    background var(--dur-fast) var(--ease-standard); background:transparent; color:var(--color-text);
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--color-primary);color:var(--color-on-primary);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--color-primary-hover)}
.btn-ghost{color:var(--color-text-secondary)}
.btn-ghost:hover{color:var(--color-text)}
.btn-block{width:100%}
.btn-hero{font-family:var(--font-display);font-weight:800;font-size:22px;min-height:60px;border-radius:var(--radius-xl);padding:0 var(--space-7)}
.icon-btn{width:var(--tap-min);height:var(--tap-min);border:none;background:transparent;color:var(--color-text-secondary);font-size:20px;cursor:pointer;border-radius:var(--radius-full)}

/* Inputs */
input,textarea{
  width:100%;font-family:var(--font-body);font-size:16px;color:var(--color-text);
  background:var(--color-surface-2);border:1px solid var(--color-border);
  border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);outline:none;
  transition:border-color var(--dur-fast);
}
input:focus,textarea:focus{border-color:var(--color-primary)}
textarea{resize:vertical;line-height:1.5}

/* ===== Auth ===== */
.auth{min-height:100svh;display:grid;place-items:center;padding:var(--space-5)}
.auth-card{width:100%;max-width:360px;text-align:center;display:flex;flex-direction:column;gap:var(--space-3);align-items:center}
.auth-form{width:100%;display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}
.seg{display:flex;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:3px;width:100%;margin-top:var(--space-3)}
.seg-btn{flex:1;min-height:38px;border:none;background:transparent;color:var(--color-text-secondary);font-family:var(--font-body);font-weight:600;border-radius:var(--radius-full);cursor:pointer}
.seg-btn.is-active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}

/* ===== App shell ===== */
.app{max-width:var(--content-max);margin:0 auto;min-height:100svh;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  gap:var(--space-3);padding:var(--space-3) var(--space-4);
  background:color-mix(in srgb,var(--color-bg) 82%,transparent);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--color-border);
}
.progress-cluster,.right-cluster{display:flex;align-items:center;gap:var(--space-2)}
.xp-ring{
  --p:0; position:relative; width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:conic-gradient(var(--color-xp) calc(var(--p)*1%), var(--color-border) 0);
}
.xp-ring::after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--color-bg)}
.xp-level{position:relative;z-index:1;font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--color-text);line-height:1}
.streak{display:flex;align-items:center;gap:2px;font-family:var(--font-display);font-weight:700;font-size:15px}
.streak-flame{font-size:14px;filter:grayscale(.1)}
.sparks{display:flex;align-items:center;gap:4px;font-family:var(--font-display);font-weight:700;color:var(--color-spark)}
.spark-ico{color:var(--color-spark)}

.content{flex:1;display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-5) var(--space-4) var(--space-8)}

/* Card */
.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3)}
.braindump-actions{display:flex;gap:var(--space-2);justify-content:flex-end}
.dump-result:empty{display:none}

/* Voice: animierter Equalizer als Aufnahme-Feedback */
.voice-btn{display:inline-flex;align-items:center;gap:var(--space-2);transition:color var(--dur-fast) var(--ease-standard)}
.voice-eq{display:none;align-items:center;gap:3px;height:18px}
.voice-eq i{width:3px;height:18px;border-radius:2px;background:currentColor;transform:scaleY(.22);transform-origin:center;opacity:.85}
.voice-btn.is-listening{color:var(--color-primary)}
.voice-btn.is-listening .voice-eq{display:inline-flex}
.voice-btn.is-listening .voice-eq i{animation:voiceEq 1.1s var(--ease-standard) infinite}
.voice-btn.is-listening .voice-eq i:nth-child(2){animation-delay:.18s}
.voice-btn.is-listening .voice-eq i:nth-child(3){animation-delay:.36s}
.voice-btn.is-listening .voice-eq i:nth-child(4){animation-delay:.10s}
.voice-btn.is-listening .voice-eq i:nth-child(5){animation-delay:.28s}
.voice-btn.is-hearing{color:var(--color-spark)}
.voice-btn.is-hearing .voice-eq i{animation-duration:.42s}
@keyframes voiceEq{0%,100%{transform:scaleY(.22)}50%{transform:scaleY(1)}}
/* Reduced-Motion: Balken statisch sichtbar, Farbe/Label tragen das Feedback */
@media (prefers-reduced-motion:reduce){.voice-btn.is-listening .voice-eq i{transform:scaleY(.6)}}

/* Erfassen (sekundär, einklappbar) */
.braindump-wrap{display:flex;flex-direction:column;gap:var(--space-3)}
.dump-trigger{display:inline-flex;align-items:center;gap:var(--space-2);align-self:center;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-body);font-weight:600;font-size:15px;border-radius:var(--radius-full);padding:0 var(--space-5);min-height:var(--tap-min);cursor:pointer;transition:background var(--dur-fast) var(--ease-standard),color var(--dur-fast)}
.dump-trigger:hover{color:var(--color-text)}
.dump-trigger.open{background:var(--color-primary-subtle);color:var(--color-primary);border-color:var(--color-primary)}
.dump-plus{font-family:var(--font-display);font-weight:800;font-size:20px;line-height:1;display:inline-block;transition:transform var(--dur-base) var(--ease-spring)}
.dump-trigger.open .dump-plus{transform:rotate(45deg)}
.braindump-body{display:flex;flex-direction:column;gap:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-sm);animation:pop var(--dur-base) var(--ease-out)}

/* Kopf-leeren-Sheet (oben verankert → tastatur-sicher) */
.sheet-overlay{position:fixed;inset:0;z-index:60;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;padding:calc(env(safe-area-inset-top) + var(--space-3)) var(--space-4) var(--space-4);animation:fade var(--dur-base) var(--ease-out)}
.sheet{width:100%;max-width:var(--content-max);background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);animation:pop var(--dur-base) var(--ease-spring)}
.sheet-head{display:flex;align-items:center;justify-content:space-between}
.sheet textarea{min-height:120px}
#te-notes{min-height:64px}

/* Aufgaben-Liste */
.task-list{display:flex;flex-direction:column;gap:8px}
.task-row{display:flex;align-items:center;gap:var(--space-3);width:100%;text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 14px;cursor:pointer;font-family:var(--font-body);transition:transform var(--dur-fast) var(--ease-standard)}
.task-row:active{transform:scale(.98)}
.task-row-title{flex:1;font-weight:600;font-size:15px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.task-row-meta{font-size:12px;color:var(--color-text-tertiary);flex:0 0 auto}
.task-row-chev{color:var(--color-text-tertiary);font-size:18px;flex:0 0 auto;line-height:1}
.plan-card[data-task]{cursor:pointer}

/* Edit-Sheet */
.te-group{display:flex;flex-direction:column;gap:var(--space-2)}
.te-group .pill{min-height:38px;padding:0 var(--space-4)}
.te-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);margin-top:var(--space-2)}
.te-delete{color:var(--color-danger)}

/* Konto */
.acc-label{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-top:var(--space-2)}
.acc-pw{margin-top:var(--space-2);border-top:1px solid var(--color-border);padding-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}
.acc-pw summary{cursor:pointer;font-weight:600;color:var(--color-primary);font-size:14px;list-style:none}
.acc-pw summary::-webkit-details-marker{display:none}

/* =====================================================================
   Kosmetisches Frame-System (data-frame) — skalierbar über Custom Properties.
   Jede Variante = 1 Regel: --f-grad (Rahmen-Gradient) · --f-glow · optional --f-corner.
   Layer: ::before = Gradient-Rahmen (mask) · .frame-corners = SVG-Ecken · Content darüber.
   Responsiv (clamp + Tokens), Dark-Mode-kompatibel, nur dezente Motion.
   ===================================================================== */
.hero[data-frame] .hero-card > *{position:relative;z-index:1}
.frame-corners{display:none}

.hero[data-frame="default"] .hero-card{
  box-shadow:var(--shadow-md),
             inset 0 0 0 1px color-mix(in srgb, var(--color-primary) 22%, transparent),
             0 clamp(6px,2vw,12px) clamp(20px,6vw,38px) -14px color-mix(in srgb, var(--color-primary) 50%, transparent);
}

/* Basis aller „geringten" Frames */
.hero[data-frame]:not([data-frame="default"]) .hero-card{
  box-shadow:var(--shadow-md), 0 clamp(8px,3vw,16px) clamp(26px,8vw,46px) -16px var(--f-glow, transparent);
}
.hero[data-frame]:not([data-frame="default"]) .hero-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;z-index:0;pointer-events:none;
  padding:clamp(2px,0.7vw,3px);
  background:var(--f-grad, linear-gradient(135deg, var(--color-primary), var(--color-primary)));
  background-size:220% 220%;
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  animation:frameShift 10s ease-in-out infinite;
}
@keyframes frameShift{0%,100%{background-position:0% 50%; opacity:.92} 50%{background-position:100% 50%; opacity:1}}

.hero[data-frame]:not([data-frame="default"]) .frame-corners{
  display:block;position:absolute;inset:0;z-index:2;pointer-events:none;border-radius:inherit;
  animation:frameShimmer 6s ease-in-out infinite;
}
.hero[data-frame]:not([data-frame="default"]) .frame-corners span{
  position:absolute; width:clamp(22px,8vw,44px); aspect-ratio:1;
  background:var(--f-corner, none) center/contain no-repeat;
}
.frame-corners span:nth-child(1){top:clamp(5px,1.5vw,9px);left:clamp(5px,1.5vw,9px);transform:rotate(0deg)}
.frame-corners span:nth-child(2){top:clamp(5px,1.5vw,9px);right:clamp(5px,1.5vw,9px);transform:rotate(90deg)}
.frame-corners span:nth-child(3){bottom:clamp(5px,1.5vw,9px);right:clamp(5px,1.5vw,9px);transform:rotate(180deg)}
.frame-corners span:nth-child(4){bottom:clamp(5px,1.5vw,9px);left:clamp(5px,1.5vw,9px);transform:rotate(270deg)}
@keyframes frameShimmer{0%,100%{opacity:.9;filter:drop-shadow(0 0 0 transparent)} 50%{opacity:1;filter:drop-shadow(0 0 clamp(2px,1vw,4px) var(--f-glow, transparent))}}

/* Eck-Ornamente */
:root{
  --corner-samurai:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48' fill='none'%3E%3Cpath d='M6 27 V13 Q6 6 13 6 H27' stroke='%23D9A85C' stroke-width='2.4' stroke-linecap='round'/%3E%3Cpath d='M13.5 13.5 q7.5 0 10.5 -5.5' stroke='%23B5854A' stroke-width='1.5' stroke-linecap='round' opacity='0.85'/%3E%3Ccircle cx='12' cy='12' r='2.2' fill='%23EBCE8F'/%3E%3C/svg%3E");
  --corner-sakura:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg transform='translate(14,14)'%3E%3Cellipse rx='2.3' ry='4.3' transform='rotate(0) translate(0 -4.5)' fill='%23F4A6C6'/%3E%3Cellipse rx='2.3' ry='4.3' transform='rotate(72) translate(0 -4.5)' fill='%23F4A6C6'/%3E%3Cellipse rx='2.3' ry='4.3' transform='rotate(144) translate(0 -4.5)' fill='%23F4A6C6'/%3E%3Cellipse rx='2.3' ry='4.3' transform='rotate(216) translate(0 -4.5)' fill='%23F4A6C6'/%3E%3Cellipse rx='2.3' ry='4.3' transform='rotate(288) translate(0 -4.5)' fill='%23F4A6C6'/%3E%3Ccircle r='1.8' fill='%23F8D24A'/%3E%3C/g%3E%3C/svg%3E");
  --corner-star:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath d='M14 6 l2.6 5.3 5.8 0.8 -4.2 4.1 1 5.8 -5.2 -2.7 -5.2 2.7 1 -5.8 -4.2 -4.1 5.8 -0.8 z' fill='%23F5C84B'/%3E%3C/svg%3E");
  --corner-gear:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg transform='translate(14,14)' fill='none' stroke='%23CBA06A' stroke-width='2' stroke-linecap='round'%3E%3Ccircle r='6.5'/%3E%3Cpath d='M0 -9 V-7 M0 9 V7 M-9 0 H-7 M9 0 H7 M-6 -6 l1.3 1.3 M6 6 l-1.3 -1.3 M6 -6 l-1.3 1.3 M-6 6 l1.3 -1.3'/%3E%3C/g%3E%3Ccircle cx='14' cy='14' r='2.4' fill='%23CBA06A'/%3E%3C/svg%3E");
}

:root{
  --corner-snow:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg transform='translate(14,14)' stroke='%239AD8F0' stroke-width='1.6' stroke-linecap='round'%3E%3Cpath d='M0 -8 V8 M-7 -4 L7 4 M-7 4 L7 -4'/%3E%3Cpath d='M0 -8 l2.4 2 M0 -8 l-2.4 2 M0 8 l2.4 -2 M0 8 l-2.4 -2'/%3E%3C/g%3E%3C/svg%3E");
  --corner-gem:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg transform='translate(13,13)'%3E%3Cpath d='M0 -5 L5 0 L0 6 L-5 0 Z' fill='%23F5C84B'/%3E%3Cpath d='M-5 0 H5' stroke='%23B8860B' stroke-width='0.7'/%3E%3C/g%3E%3C/svg%3E");
  --corner-wave:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg transform='translate(13,13)' fill='none' stroke='%237DD3FC' stroke-width='1.6' stroke-linecap='round'%3E%3Cpath d='M-7 4 A7 7 0 0 1 7 4'/%3E%3Cpath d='M-4 4 A4 4 0 0 1 4 4'/%3E%3C/g%3E%3C/svg%3E");
}

/* ---- Varianten ---- */
.hero[data-frame="premium"]{--f-grad:linear-gradient(135deg,#A78BFA,#F5C46B 45%,#C9A0FF 75%,#A78BFA);--f-glow:color-mix(in srgb,#8B5CF6 60%,transparent)}
.hero[data-frame="platin"]{--f-grad:linear-gradient(135deg,#AEB6C2,#FFFFFF 50%,#C9D2DE);--f-glow:color-mix(in srgb,#C9D2DE 55%,transparent)}
.hero[data-frame="gold"]{--f-grad:linear-gradient(135deg,#B8860B,#F5D272 50%,#C8924A);--f-glow:color-mix(in srgb,#E8B84B 55%,transparent)}
.hero[data-frame="samurai"]{--f-grad:linear-gradient(135deg,#8A5E38,#E9C887 35%,#C8924A 60%,#F0D9A0);--f-glow:color-mix(in srgb,var(--color-spark) 55%,transparent);--f-corner:var(--corner-samurai)}
.hero[data-frame="sakura"]{--f-grad:linear-gradient(135deg,#E07BA6,#FCE3EC 50%,#F49AC1);--f-glow:color-mix(in srgb,#F49AC1 55%,transparent);--f-corner:var(--corner-sakura)}
.hero[data-frame="seigaiha"]{--f-grad:linear-gradient(135deg,#2A4E86,#9BC3F0 50%,#3E6BB0);--f-glow:color-mix(in srgb,#3E6BB0 55%,transparent)}
.hero[data-frame="zen"]{--f-grad:linear-gradient(135deg,#1A1A1A,#9A9A9A 50%,#2A2A2A);--f-glow:color-mix(in srgb,#FFFFFF 18%,transparent)}
.hero[data-frame="neon"]{--f-grad:linear-gradient(135deg,#22D3EE,#A855F7 50%,#EC4899);--f-glow:color-mix(in srgb,#A855F7 55%,transparent)}
.hero[data-frame="matrix"]{--f-grad:linear-gradient(135deg,#065F46,#86EFAC 50%,#16A34A);--f-glow:color-mix(in srgb,#22C55E 50%,transparent)}
.hero[data-frame="holo"]{--f-grad:linear-gradient(135deg,#67E8F9,#C4B5FD 40%,#FBCFE8 70%,#67E8F9);--f-glow:color-mix(in srgb,#A5B4FC 55%,transparent)}
.hero[data-frame="messing"]{--f-grad:linear-gradient(135deg,#7A5230,#D9A85C 50%,#A6763B);--f-glow:color-mix(in srgb,#C8924A 55%,transparent);--f-corner:var(--corner-gear)}
.hero[data-frame="kupfer"]{--f-grad:linear-gradient(135deg,#7A3B22,#E08A5B 50%,#B05A33);--f-glow:color-mix(in srgb,#C56A3D 55%,transparent)}
.hero[data-frame="uhrwerk"]{--f-grad:linear-gradient(135deg,#5A4632,#CBA06A 50%,#8A6A42);--f-glow:color-mix(in srgb,#A6824E 55%,transparent);--f-corner:var(--corner-gear)}
.hero[data-frame="rose"]{--f-grad:linear-gradient(135deg,#C44569,#F9C5D1 50%,#E5687F);--f-glow:color-mix(in srgb,#E5687F 55%,transparent);--f-corner:var(--corner-sakura)}
.hero[data-frame="lavendel"]{--f-grad:linear-gradient(135deg,#7E5BB5,#D7C4F0 50%,#9D7BD8);--f-glow:color-mix(in srgb,#9D7BD8 55%,transparent)}
.hero[data-frame="wiese"]{--f-grad:linear-gradient(135deg,#3E7A4E,#BFE3A8 50%,#5DA86B);--f-glow:color-mix(in srgb,#6FBF73 50%,transparent)}
.hero[data-frame="held-lila"]{--f-grad:linear-gradient(135deg,#6D28D9,#C4B5FD 50%,#7C3AED);--f-glow:color-mix(in srgb,#7C3AED 55%,transparent);--f-corner:var(--corner-star)}
.hero[data-frame="held-gold"]{--f-grad:linear-gradient(135deg,#B8860B,#FBE08A 50%,#D9A521);--f-glow:color-mix(in srgb,#F5C84B 55%,transparent);--f-corner:var(--corner-star)}
.hero[data-frame="held-gruen"]{--f-grad:linear-gradient(135deg,#15803D,#86EFAC 50%,#16A34A);--f-glow:color-mix(in srgb,#22C55E 50%,transparent);--f-corner:var(--corner-star)}
/* Galaxy */
.hero[data-frame="nebula"]{--f-grad:linear-gradient(135deg,#6D28D9,#DB2777 45%,#2563EB);--f-glow:color-mix(in srgb,#7C3AED 55%,transparent)}
.hero[data-frame="sternennacht"]{--f-grad:linear-gradient(135deg,#1E293B,#6366F1 50%,#0F172A);--f-glow:color-mix(in srgb,#6366F1 55%,transparent);--f-corner:var(--corner-star)}
.hero[data-frame="supernova"]{--f-grad:linear-gradient(135deg,#F59E0B,#EC4899 50%,#7C3AED);--f-glow:color-mix(in srgb,#EC4899 55%,transparent)}
/* Frost */
.hero[data-frame="eiskristall"]{--f-grad:linear-gradient(135deg,#67E8F9,#FFFFFF 50%,#A5F3FC);--f-glow:color-mix(in srgb,#67E8F9 55%,transparent);--f-corner:var(--corner-snow)}
.hero[data-frame="polarlicht"]{--f-grad:linear-gradient(135deg,#22D3EE,#34D399 45%,#A78BFA);--f-glow:color-mix(in srgb,#34D399 50%,transparent)}
.hero[data-frame="frostglas"]{--f-grad:linear-gradient(135deg,#93C5FD,#E0F2FE 50%,#BAE6FD);--f-glow:color-mix(in srgb,#93C5FD 55%,transparent);--f-corner:var(--corner-snow)}
/* Halloween */
.hero[data-frame="kuerbis"]{--f-grad:linear-gradient(135deg,#EA580C,#FB923C 45%,#1C1917);--f-glow:color-mix(in srgb,#EA580C 55%,transparent)}
.hero[data-frame="geist"]{--f-grad:linear-gradient(135deg,#7C3AED,#A3E635 55%,#312E81);--f-glow:color-mix(in srgb,#A3E635 50%,transparent)}
.hero[data-frame="spuk"]{--f-grad:linear-gradient(135deg,#1C1917,#9333EA 50%,#4C1D95);--f-glow:color-mix(in srgb,#9333EA 55%,transparent)}
/* Winter */
.hero[data-frame="tanne"]{--f-grad:linear-gradient(135deg,#166534,#DC2626 50%,#14532D);--f-glow:color-mix(in srgb,#DC2626 50%,transparent)}
.hero[data-frame="schnee"]{--f-grad:linear-gradient(135deg,#BAE6FD,#FFFFFF 50%,#7DD3FC);--f-glow:color-mix(in srgb,#BAE6FD 55%,transparent);--f-corner:var(--corner-snow)}
.hero[data-frame="lebkuchen"]{--f-grad:linear-gradient(135deg,#92400E,#FCD34D 50%,#B45309);--f-glow:color-mix(in srgb,#FCD34D 50%,transparent)}
/* Royal */
.hero[data-frame="purpur"]{--f-grad:linear-gradient(135deg,#581C87,#C084FC 50%,#7E22CE);--f-glow:color-mix(in srgb,#C084FC 55%,transparent);--f-corner:var(--corner-gem)}
.hero[data-frame="goldkrone"]{--f-grad:linear-gradient(135deg,#B8860B,#FDE68A 50%,#D97706);--f-glow:color-mix(in srgb,#FDE68A 55%,transparent);--f-corner:var(--corner-gem)}
.hero[data-frame="saphir"]{--f-grad:linear-gradient(135deg,#1E3A8A,#93C5FD 50%,#1E40AF);--f-glow:color-mix(in srgb,#3B82F6 55%,transparent);--f-corner:var(--corner-gem)}
/* Ozean */
.hero[data-frame="tiefsee"]{--f-grad:linear-gradient(135deg,#0C4A6E,#22D3EE 50%,#0E7490);--f-glow:color-mix(in srgb,#22D3EE 55%,transparent)}
.hero[data-frame="koralle"]{--f-grad:linear-gradient(135deg,#0D9488,#FB7185 50%,#14B8A6);--f-glow:color-mix(in srgb,#FB7185 55%,transparent)}
.hero[data-frame="welle"]{--f-grad:linear-gradient(135deg,#0369A1,#7DD3FC 50%,#0284C7);--f-glow:color-mix(in srgb,#38BDF8 55%,transparent);--f-corner:var(--corner-wave)}
/* Drache */
.hero[data-frame="smaragddrache"]{--f-grad:linear-gradient(135deg,#065F46,#FCD34D 50%,#047857);--f-glow:color-mix(in srgb,#10B981 55%,transparent)}
.hero[data-frame="feuerdrache"]{--f-grad:linear-gradient(135deg,#7F1D1D,#FB923C 50%,#DC2626);--f-glow:color-mix(in srgb,#F97316 55%,transparent)}
.hero[data-frame="schattendrache"]{--f-grad:linear-gradient(135deg,#1E1B4B,#7C3AED 50%,#0F0F23);--f-glow:color-mix(in srgb,#7C3AED 55%,transparent)}
/* Arcane */
.hero[data-frame="runen"]{--f-grad:linear-gradient(135deg,#4C1D95,#22D3EE 50%,#6D28D9);--f-glow:color-mix(in srgb,#22D3EE 55%,transparent);--f-corner:var(--corner-star)}
.hero[data-frame="kristallmagie"]{--f-grad:linear-gradient(135deg,#7C3AED,#F0ABFC 50%,#A21CAF);--f-glow:color-mix(in srgb,#F0ABFC 55%,transparent)}
.hero[data-frame="hexerei"]{--f-grad:linear-gradient(135deg,#14532D,#A855F7 55%,#166534);--f-glow:color-mix(in srgb,#A855F7 55%,transparent)}
/* Streak-Glut (Status, ab 30 Tagen) */
.hero[data-frame="glut"]{--f-grad:linear-gradient(135deg,#7F1D1D,#FB923C 40%,#DC2626 70%,#F59E0B);--f-glow:color-mix(in srgb,#F97316 65%,transparent)}

/* Rahmen-Shop (Vorschau-Kacheln) */
.frame-shop{display:flex;flex-direction:column;gap:var(--space-3)}
.frame-cat{font-family:var(--font-display);font-weight:800;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary);margin-top:var(--space-4)}
.frame-cat:first-child{margin-top:0}
.frame-tile{display:flex;flex-direction:column;gap:var(--space-2)}
.ft-preview{pointer-events:none;gap:0}
.ft-preview .hero-card{padding:var(--space-5) var(--space-4);min-height:clamp(64px,18vw,92px);justify-content:center;animation:none}
.ft-mini{font-family:var(--font-display);font-weight:800;font-size:clamp(15px,4.5vw,18px);color:var(--color-text)}
.ft-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}
.ft-name{font-weight:700;font-size:15px}
.frame-tile.equipped .ft-name{color:var(--color-primary)}
.ft-state{font-family:var(--font-display);font-weight:800;color:var(--color-success)}
.ft-locked{font-size:12px;font-weight:700;color:var(--color-spark)}
.ft-btn{min-height:38px;padding:0 var(--space-4);flex:0 0 auto}
.lb-frame-prev{width:min(78vw,300px);pointer-events:none}
.lb-frame-prev .hero-card{padding:var(--space-5);min-height:90px;justify-content:center;animation:none}

/* ===== Tanuki-Customizing-Hub ===== */
.tanuki-showcase{margin-bottom:var(--space-2)}
.tanuki-showcase .hero-card{padding:var(--space-6) var(--space-5);gap:var(--space-2)}
.tanuki-xl{width:clamp(140px,42vw,200px);height:auto}
.cust-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}
.cust-cat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-family:var(--font-body);color:var(--color-text-secondary);transition:border-color var(--dur-fast),background var(--dur-fast),color var(--dur-fast)}
.cust-cat.is-active{border-color:var(--color-primary);background:var(--color-primary-subtle);color:var(--color-primary)}
.cust-cat .cc-ic{font-size:22px;line-height:1}
.cust-cat .cc-lb{font-size:12px;font-weight:600}
.cust-panel{margin-top:var(--space-2);display:flex;flex-direction:column;gap:var(--space-3)}

/* Kompakte Kisten */
.boxes-compact{display:flex;flex-direction:column;gap:var(--space-2)}
.box-card-compact{display:flex;align-items:center;gap:var(--space-3);width:100%;text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:10px 12px;cursor:pointer;font-family:var(--font-body);transition:transform var(--dur-fast)}
.box-card-compact:active{transform:scale(.99)}
.box-card-compact .box-pochi{width:48px;height:48px}
.bc-info{flex:1;min-width:0}
.bc-bar{height:5px;border-radius:var(--radius-full);background:var(--color-surface-2);overflow:hidden;margin:5px 0}
.bc-bar span{display:block;height:100%;background:var(--color-primary);border-radius:inherit}
.bc-price{font-family:var(--font-display);font-weight:800;color:var(--color-spark);flex:0 0 auto}
.box-card-compact.complete .bc-price{color:var(--color-success)}

/* Box-Modal */
#bm-img{align-self:center;width:clamp(120px,40vw,170px)}
#bm-rates{justify-content:center}
.bm-foot{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-2)}
.fprev{position:relative;width:54px;height:54px;flex:0 0 auto}
.fprev .hero{width:54px}
.fprev .hero-card{min-height:54px;padding:0;animation:none;gap:0}
.fprev:not(.owned){opacity:.6}
.fprev.owned::after{content:"✓";position:absolute;right:-4px;top:-4px;width:18px;height:18px;border-radius:50%;background:var(--color-success);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center;z-index:4}

/* Garderobe gesperrt */
.outfit-tile{position:relative}
.outfit-tile.locked{opacity:.45;cursor:default}
.ot-lock{position:absolute;top:6px;right:6px;font-size:12px}

/* Platzhalter (Animationen / Icons / Items) */
.cust-ph{text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);align-items:center}
.cust-ph .ph-ic{font-size:40px}
.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);width:100%;margin-top:var(--space-3)}
.slot-tile{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-4) var(--space-2);background:var(--color-surface-2);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary)}
.slot-tile .slot-ic{font-size:20px;color:var(--color-text-tertiary)}
.slot-nm{font-size:12px;font-weight:600}
.slot-soon{font-size:10px;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}

/* Onboarding (Erststart) */
.onboarding{align-items:center;text-align:center;gap:var(--space-4)}
.onb-title{font-family:var(--font-display);font-weight:800;font-size:22px;line-height:1.2}
.onb-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);width:100%;text-align:left;margin:var(--space-1) 0}
.onb-list li{display:flex;gap:var(--space-3);align-items:center;line-height:1.3}
.onb-list li>span{font-size:22px;flex:0 0 auto;width:28px;text-align:center}

/* Hero */
.hero{display:flex;flex-direction:column;gap:var(--space-5)}
.hero-prompt{font-family:var(--font-display);font-weight:700;font-size:17px;line-height:1.4;color:var(--color-text);margin:0}
.hero-greeting{font-family:var(--font-display);font-weight:700;font-size:clamp(17px,4.6vw,20px);line-height:1.35;color:var(--color-text);margin:0;max-width:24ch}
.mic-btn{position:absolute;right:-6px;bottom:4px;width:46px;height:46px;border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-primary);border:1px solid var(--color-border);box-shadow:var(--shadow-md);display:grid;place-items:center;cursor:pointer;z-index:3;transition:transform var(--dur-fast) var(--ease-standard),background var(--dur-fast)}
.mic-btn:hover{background:var(--color-primary-subtle)}
.mic-btn:active{transform:scale(.92)}
.mic-btn svg{width:22px;height:22px}
.filter-toggle{background:none;border:none;color:var(--color-text-tertiary);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;padding:6px 10px;display:inline-flex;align-items:center;gap:5px}
.filter-toggle:hover{color:var(--color-text-secondary)}
.filter-toggle::after{content:"›";display:inline-block;font-weight:800;transition:transform var(--dur-base) var(--ease-standard)}
.filter-toggle.open::after{transform:rotate(90deg)}
.quick{display:flex;flex-direction:column;gap:var(--space-4);width:100%;text-align:left}
.quick-group{display:flex;flex-direction:column;gap:var(--space-2)}
.quick-q{font-size:14px;font-weight:600;color:var(--color-text-secondary)}
.pill-row{display:flex;gap:var(--space-2);flex-wrap:wrap}
.pill{
  min-height:var(--tap-min);padding:0 var(--space-4);border-radius:var(--radius-full);
  background:var(--color-surface-2);border:1px solid var(--color-border);
  color:var(--color-text-secondary);font-family:var(--font-body);font-weight:600;cursor:pointer;
  transition:all var(--dur-fast) var(--ease-standard);
}
.pill.is-active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}

.hero-card{
  position:relative;isolation:isolate;
  background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);
  box-shadow:var(--shadow-md);padding:var(--space-7) var(--space-5);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:var(--space-4);
  animation:pop var(--dur-slow) var(--ease-spring);
}
.btn-hero{margin:var(--space-2) 0}
.pick-reason{display:flex;align-items:center;gap:var(--space-2);justify-content:center;color:var(--color-text-secondary);font-size:15px}
/* Tanuki „schreibt…" — WhatsApp-artige Tipp-Punkte bis die KI-Begründung da ist */
#pick-reason{min-height:1.3em;display:inline-flex;align-items:center}
.reason-in{animation:reasonIn .28s var(--ease-standard)}
@keyframes reasonIn{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}
.typing{display:inline-flex;align-items:center;gap:5px}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--color-text-secondary);opacity:.4;animation:typingDot 1.2s var(--ease-standard) infinite}
.typing i:nth-child(2){animation-delay:.18s}
.typing i:nth-child(3){animation-delay:.36s}
@keyframes typingDot{0%,60%,100%{transform:translateY(0);opacity:.35}30%{transform:translateY(-4px);opacity:.9}}
.pick .display{margin:var(--space-2) 0}
.pick-meta{display:flex;gap:var(--space-2);flex-wrap:wrap;justify-content:center}
.chip{font-size:13px;font-weight:600;padding:5px 12px;border-radius:var(--radius-full);background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text-secondary);display:inline-flex;align-items:center;gap:5px}
.chip .dot{width:8px;height:8px;border-radius:50%}
.chip-xp{color:var(--color-xp);border-color:color-mix(in srgb,var(--color-xp) 30%,transparent)}
.pick-actions{width:100%;display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}
.pick-secondary{display:flex;gap:var(--space-2);justify-content:center}
.empty-msg{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--color-text)}

/* Tanuki */
.tanuki{display:block;object-fit:contain}
.tanuki-sm{width:28px;height:28px}
.tanuki-md{width:72px;height:72px}
.tanuki-lg{width:124px;height:124px}
.tanuki-happy{animation:bounce var(--dur-reward) var(--ease-spring)}

/* Lebendiger Hero-Tanuki */
.tanuki-stage{position:relative;display:flex;justify-content:center;align-items:flex-end;min-height:132px}
#hero-tanuki{cursor:pointer;-webkit-tap-highlight-color:transparent}
.tanuki-idle{animation:idleBob 3.2s ease-in-out infinite}
.tanuki-poke{animation:bounce var(--dur-reward) var(--ease-spring)}
@keyframes idleBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.tanuki-bubble{position:absolute;bottom:calc(100% - 8px);left:50%;transform:translateX(-50%) translateY(8px) scale(.92);
  background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-md);
  border-radius:var(--radius-lg);padding:8px 14px;font-family:var(--font-body);font-weight:600;font-size:14px;
  color:var(--color-text);white-space:nowrap;opacity:0;pointer-events:none;z-index:3;
  transition:opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-spring)}
.tanuki-bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--color-surface)}
.tanuki-bubble.show{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}

/* Reward */
.reward-overlay{position:fixed;inset:0;z-index:50;display:grid;place-items:center;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);animation:fade var(--dur-base) var(--ease-out)}
.reward-card{position:relative;background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);padding:var(--space-7) var(--space-6);text-align:center;width:min(90vw,360px);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);animation:pop var(--dur-reward) var(--ease-spring)}
.reward-xp{font-family:var(--font-display);font-weight:800;font-size:40px;color:var(--color-xp)}
.reward-msg{color:var(--color-text-secondary)}
.reward-extra{display:flex;flex-direction:column;gap:6px}
.reward-badge{font-family:var(--font-display);font-weight:700;color:var(--color-celebrate)}
.reward-spark{font-family:var(--font-display);font-weight:700;color:var(--color-spark)}

/* Bottom nav */
.bottom-nav{position:sticky;bottom:0;display:flex;background:color-mix(in srgb,var(--color-bg) 82%,transparent);backdrop-filter:saturate(180%) blur(12px);border-top:1px solid var(--color-border);padding-bottom:env(safe-area-inset-bottom)}
.nav-item{flex:1;min-height:52px;border:none;background:transparent;color:var(--color-text-tertiary);font-family:var(--font-body);font-weight:600;font-size:13px;cursor:pointer}
.nav-item.is-active{color:var(--color-primary)}

/* Confetti */
.confetti{position:absolute;inset:0;overflow:hidden;pointer-events:none;border-radius:var(--radius-2xl)}
.confetti i{position:absolute;top:-10px;width:8px;height:12px;border-radius:2px;animation:fall var(--dur-reward) ease-in forwards}

@keyframes pop{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes bounce{0%{transform:translateY(0)}30%{transform:translateY(-12px)}60%{transform:translateY(0)}80%{transform:translateY(-5px)}100%{transform:translateY(0)}}
@keyframes fall{to{transform:translateY(320px) rotate(360deg);opacity:0}}

/* ===== Raritäten ===== */
:root{
  --rar-gewoehnlich:#9AA0A6; --rar-selten:#3E9BE8;
  --rar-episch:var(--indigo-500); --rar-legendaer:var(--color-spark);
}
[data-rarity="gewoehnlich"]{--rar:var(--rar-gewoehnlich)}
[data-rarity="selten"]{--rar:var(--rar-selten)}
[data-rarity="episch"]{--rar:var(--rar-episch)}
[data-rarity="legendaer"]{--rar:var(--rar-legendaer)}

/* ===== Shop ===== */
.shop-head{display:flex;align-items:center;justify-content:space-between}
.h1-shop{font-family:var(--font-display);font-weight:800;font-size:28px}
.sparks-big{font-size:22px}
.boxes{display:flex;flex-direction:column;gap:var(--space-4)}
.box-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}
.box-top{display:flex;align-items:center;gap:var(--space-3)}
.box-emoji{font-size:36px}
.box-title{font-family:var(--font-display);font-weight:700;font-size:18px}
.box-rates{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px}
.rate{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);color:var(--rar);border:1px solid color-mix(in srgb,var(--rar) 35%,transparent);background:color-mix(in srgb,var(--rar) 10%,transparent)}
.box-preview{display:flex;gap:var(--space-2);overflow-x:auto;padding:2px}
.prev{position:relative;flex:0 0 auto;width:54px;height:54px;border-radius:var(--radius-md);background:var(--color-surface-2);border:2px solid var(--rar);display:grid;place-items:center}
.prev img{width:46px;height:46px;object-fit:contain}
.prev.owned::after{content:"✓";position:absolute;right:-4px;top:-4px;width:18px;height:18px;border-radius:50%;background:var(--color-success);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center}
.prev:not(.owned) img{opacity:.85}
.box-buy{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}
.box-cost{font-family:var(--font-display);font-weight:800;color:var(--color-spark)}
.box-progress{font-size:12px;color:var(--color-text-tertiary);margin-top:3px}
.box-complete{font-size:12px;font-weight:800;color:var(--color-success);margin-top:2px}
.box-done{font-family:var(--font-display);font-weight:800;color:var(--color-success)}
.box-card.complete{opacity:.94}
.btn[disabled]{opacity:.45;pointer-events:none}

/* Garderobe */
.garderobe-title{margin-top:var(--space-3)}
.garderobe{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}
.outfit-tile{position:relative;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-2);text-align:center;cursor:pointer;transition:transform var(--dur-fast) var(--ease-standard)}
.outfit-tile:active{transform:scale(.96)}
.outfit-tile[data-rarity]{border-color:color-mix(in srgb,var(--rar) 55%,var(--color-border))}
.outfit-tile.equipped{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 35%,transparent)}
.outfit-tile img{width:100%;aspect-ratio:1;object-fit:contain}
.outfit-tile .ot-name{font-size:11px;font-weight:600;color:var(--color-text-secondary);margin-top:4px;line-height:1.2}
.outfit-tile .ot-eq{position:absolute;top:6px;right:6px;font-size:10px;font-weight:800;color:var(--color-primary)}
.outfit-tile.base{display:flex;flex-direction:column;align-items:center;justify-content:center;border-style:dashed}

/* ===== Lootbox-Reveal ===== */
.lootbox-card{position:relative;background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);padding:var(--space-7) var(--space-6);text-align:center;width:min(90vw,360px);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);animation:pop var(--dur-reward) var(--ease-spring)}
.lb-closed,.lb-reveal{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}
.lb-box{font-size:88px;animation:shake 1.2s var(--ease-standard) infinite}
.lb-reveal{position:relative}
.rarity-burst{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,var(--rar) 0%,transparent 68%);opacity:.5;filter:blur(6px);animation:burst var(--dur-reward) var(--ease-spring)}
.lb-reveal .tanuki{position:relative;z-index:1}
.lb-rarity{font-family:var(--font-display);font-weight:800;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--rar)}
.lb-name{font-family:var(--font-display);font-weight:800;font-size:22px}
.lb-dupe{color:var(--color-spark)}
.lb-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2)}
.lb-close{margin-top:var(--space-1)}

@keyframes shake{0%,100%{transform:rotate(0)}20%{transform:rotate(-8deg) scale(1.04)}40%{transform:rotate(8deg) scale(1.04)}60%{transform:rotate(-6deg)}80%{transform:rotate(6deg)}}
@keyframes burst{from{transform:translateX(-50%) scale(.3);opacity:0}to{transform:translateX(-50%) scale(1);opacity:.5}}

/* ===== Pochibukuro-Umschläge ===== */
.pochi{width:150px;height:auto;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(0,0,0,.18))}
.box-pochi{width:60px;height:60px;object-fit:contain;flex:0 0 auto}
.lb-opening{display:flex;justify-content:center}
.pochi-wiggle{animation:shake 1.3s var(--ease-standard) infinite;cursor:pointer}
.pochi-burst{animation:pochiBurst .85s var(--ease-spring)}
.pochi-pop{animation:pochiPop var(--dur-reward) var(--ease-spring)}
@keyframes pochiBurst{0%{transform:scale(.6) rotate(-4deg);opacity:0}40%{opacity:1}60%{transform:scale(1.12) rotate(3deg)}100%{transform:scale(1) rotate(0)}}
@keyframes pochiPop{0%{transform:scale(.7)}55%{transform:scale(1.15)}100%{transform:scale(1)}}

/* Glücksumschlag im Reward-Pop */
.envelope{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);margin-top:var(--space-1)}
.env-cap{font-size:13px;font-weight:600;color:var(--color-text-secondary)}
.envelope .pochi{width:120px}
.env-sparks{font-family:var(--font-display);font-weight:800;font-size:30px;color:var(--color-spark);animation:pop var(--dur-reward) var(--ease-spring)}

/* ===== Wochen-Plan ===== */
.week{display:flex;flex-direction:column;gap:var(--space-3)}
.day{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4)}
.day.today{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 22%,transparent)}
.day-head{display:flex;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2)}
.day-wd{font-family:var(--font-display);font-weight:800;font-size:16px}
.day-date{font-size:13px;color:var(--color-text-tertiary)}
.day-badge{margin-left:auto;font-size:11px;font-weight:800;color:var(--color-primary);background:var(--color-primary-subtle);padding:2px 8px;border-radius:var(--radius-full)}
.day-body{display:flex;flex-direction:column;gap:6px}
.day-empty{font-size:13px;color:var(--color-text-tertiary);padding:2px 0}
.plan-card{display:flex;align-items:center;gap:var(--space-2);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 10px}
.plan-card[data-type="termin"]{border-left:3px solid var(--dom-termin)}
.plan-card.done{opacity:.5}
.plan-card.done .plan-title{text-decoration:line-through}
.dom-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.plan-title{font-size:14px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.plan-meta{font-size:11px;color:var(--color-text-tertiary);flex:0 0 auto}

/* ===== Plan: Wochen-Leiste + Tageskarten (Me+-Stil) ===== */
.plan-actions{display:flex;align-items:center;gap:var(--space-2)}
.quick-add{width:44px;height:44px;flex:0 0 auto;border:none;border-radius:var(--radius-full);background:var(--color-primary);color:var(--color-on-primary);font-size:28px;font-weight:600;line-height:1;cursor:pointer;box-shadow:var(--shadow-sm);display:grid;place-items:center;transition:transform var(--dur-fast) var(--ease-standard),background var(--dur-fast)}
.quick-add:hover{background:var(--color-primary-hover)}
.quick-add:active{transform:scale(.92)}
.weekstrip{display:flex;gap:4px;justify-content:space-between;margin:6px 0 4px}
.wd{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;padding:8px 0 6px;border:none;background:transparent;cursor:pointer;font-family:var(--font-body);border-radius:var(--radius-lg);transition:background var(--dur-fast)}
.wd-name{font-size:12px;font-weight:700;color:var(--color-text-tertiary)}
.wd-num{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--color-text);border:2px solid transparent;transition:background var(--dur-fast),color var(--dur-fast),border-color var(--dur-fast)}
.wd.today:not(.sel) .wd-num{border-color:var(--color-primary)}
.wd.sel .wd-num{background:var(--color-primary);color:var(--color-on-primary);box-shadow:var(--shadow-sm)}
.wd.sel .wd-name{color:var(--color-primary)}
.wd-dots{display:flex;gap:3px;height:6px;align-items:center}
.wd-dots i{width:5px;height:5px;border-radius:50%}

.day-tasks{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}
.dsec-title{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--color-text-secondary);margin:var(--space-3) 2px var(--space-1)}
.dsec-title:first-child{margin-top:0}
.dcard{display:flex;align-items:center;gap:var(--space-3);border-radius:var(--radius-lg);padding:13px 14px;border:1px solid transparent;cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);transition:transform var(--dur-fast) var(--ease-standard)}
.dcard:active{transform:scale(.985)}
.dcard-ico{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-size:24px;flex:0 0 auto;background:color-mix(in srgb,#fff 55%,transparent)}
[data-theme="dark"] .dcard-ico,:root:not([data-theme="light"]) .dcard-ico{background:color-mix(in srgb,#000 28%,transparent)}
.dcard-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.dcard-title{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dcard-sub{font-size:12px;font-weight:700;color:var(--color-text-secondary)}
.dcard-check{width:30px;height:30px;border-radius:50%;border:2px solid color-mix(in srgb,var(--color-text-tertiary) 55%,transparent);background:transparent;flex:0 0 auto;display:grid;place-items:center;color:#fff;font-size:17px;cursor:pointer;transition:background var(--dur-fast),border-color var(--dur-fast)}
.dcard.done{opacity:.62}
.dcard.done .dcard-title{text-decoration:line-through}
.dcard.done .dcard-check{background:var(--color-success);border-color:var(--color-success)}
.day-empty-big{text-align:center;color:var(--color-text-tertiary);font-size:16px;padding:48px 0 32px}

/* Toast */
.toast{position:fixed;left:50%;bottom:96px;transform:translate(-50%,16px);z-index:60;
  background:var(--color-text);color:var(--color-bg);font-weight:700;font-size:14px;
  padding:12px 20px;border-radius:var(--radius-full);box-shadow:var(--shadow-lg);
  opacity:0;pointer-events:none;transition:opacity var(--dur-base),transform var(--dur-base) var(--ease-out);max-width:88vw;text-align:center}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* ===== Streak-Eis-Banner ===== */
.ice-banner{background:color-mix(in srgb,var(--rar-selten) 14%,var(--color-surface));border:1px solid color-mix(in srgb,var(--rar-selten) 40%,transparent);color:var(--color-text);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-size:14px;line-height:1.45}

/* ===== Freunde + Leaderboard ===== */
.friend-code{font-family:var(--font-display);font-weight:800;font-size:30px;letter-spacing:.12em;color:var(--color-primary);text-align:center;background:var(--color-primary-subtle);border-radius:var(--radius-md);padding:var(--space-3);user-select:all}
.add-friend{display:flex;gap:var(--space-2)}
.add-friend input{text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.add-friend .btn{flex:0 0 auto}
.windows{display:flex;gap:8px;flex-wrap:wrap}
.windows .pill{min-height:38px;padding:0 var(--space-4)}
.req-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;margin-bottom:8px}
.req-actions{display:flex;gap:6px}
.req-actions .btn{min-height:36px;padding:0 var(--space-3);font-size:14px}
.leaderboard{display:flex;flex-direction:column;gap:8px}
.lb-row{display:flex;align-items:center;gap:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px}
.lb-row.me{border-color:var(--color-primary);background:var(--color-primary-subtle)}
.lb-rank{font-family:var(--font-display);font-weight:800;width:28px;flex:0 0 auto;text-align:center}
.lb-name{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-streak{font-size:13px;font-weight:700;flex:0 0 auto}
.lb-lvl{font-size:12px;color:var(--color-text-secondary);flex:0 0 auto}
.lb-xp{font-size:12px;color:var(--color-text-tertiary);flex:0 0 auto;min-width:54px;text-align:right}
.lb-rescue{min-height:34px;padding:0 var(--space-3);font-size:13px;color:var(--color-celebrate);flex:0 0 auto}

@media (prefers-reduced-motion:reduce){*{animation:none !important;transition-duration:.01ms !important}}
