/* ============================================================
   VELVET LEDGER — Velvet Boudoir Edition
   Wärmer · Spielerischer · Sinnlich · Vertrauenswürdig
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=Inter:wght@300;400;500;600;700&family=Pinyon+Script&display=swap');

:root{
  /* Warme Boudoir-Palette */
  --bg-deep:#13080d;
  --bg-base:#1a0c12;
  --bg-panel:#251420;
  --bg-elev:#2e1827;
  --bg-elev-2:#3a1f31;

  --border:#4a2b3d;
  --border-soft:#3a2030;
  --border-warm:#5a3045;

  --rose:#d4506a;
  --rose-bright:#e87990;
  --rose-deep:#a83755;

  --plum:#4a1942;
  --plum-bright:#6b2660;

  --burgundy:#6b1b35;
  --burgundy-bright:#8c2745;
  --burgundy-deep:#3d0e1e;

  --rose-gold:#d4a574;
  --rose-gold-bright:#e8c094;
  --rose-gold-deep:#a07d52;
  --champagne:#f5d9b4;

  --cream:#f5e8d6;
  --cream-dim:#d8c4ad;
  --muted:#b89880;
  --muted-dim:#7a6354;

  --success:#7fa385;
  --danger:#c64560;
  --warning:#e8c094;

  --candle: #ffd9b0;     /* warm candle glow */
  --candle-soft: rgba(255,217,176,.12);

  --shadow-deep: 0 24px 70px rgba(0,0,0,.7), 0 8px 24px rgba(0,0,0,.5);
  --shadow-card: 0 6px 24px rgba(0,0,0,.45), inset 0 1px 0 rgba(232,192,148,.06);
  --shadow-glow: 0 0 40px rgba(212,80,106,.15), 0 0 80px rgba(212,165,116,.08);
  --shadow-inset: inset 0 1px 3px rgba(0,0,0,.6);

  --r-sm:6px;
  --r-md:10px;
  --r-lg:18px;
  --r-pill:999px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}

body{
  font-family:'Inter',-apple-system,sans-serif;
  font-weight:400;
  color:var(--cream);
  background:
    radial-gradient(ellipse 80% 60% at 20% 0%, rgba(212,80,106,.15) 0%, transparent 60%),
    radial-gradient(ellipse 90% 70% at 80% 100%, rgba(74,25,66,.35) 0%, transparent 60%),
    radial-gradient(ellipse at 50% 50%, var(--bg-base) 0%, var(--bg-deep) 90%);
  min-height:100vh;
  line-height:1.55;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Sanfte Velvet-Textur Overlay */
body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.06;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .95  0 0 0 0 .8  0 0 0 0 .65  0 0 0 .9 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Pulsierende Kerzen-Lichter im Hintergrund */
body::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(circle at 12% 18%, var(--candle-soft) 0px, transparent 180px),
    radial-gradient(circle at 88% 82%, var(--candle-soft) 0px, transparent 220px);
  animation: candleFlicker 6s ease-in-out infinite alternate;
}

@keyframes candleFlicker {
  0%,100%{ opacity:1 }
  50%   { opacity:.7 }
}

a{color:var(--rose-gold);text-decoration:none;transition:color .2s}
a:hover{color:var(--rose-gold-bright)}

button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

h1,h2,h3,h4{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  letter-spacing:.005em;
  color:var(--cream);
}
h1{font-size:2.6rem;line-height:1.05}
h2{font-size:1.9rem;line-height:1.2}
h3{font-size:1.35rem;font-weight:600}
h4{font-size:1rem;font-weight:600;font-family:'Inter',sans-serif;letter-spacing:.08em;text-transform:uppercase;color:var(--rose-gold)}

.serif{font-family:'Cormorant Garamond',serif}
.italic{font-style:italic}
.script{font-family:'Pinyon Script', cursive; font-weight:400}
.rose-gold{color:var(--rose-gold)}
.rose{color:var(--rose)}
.muted{color:var(--muted)}
.cream{color:var(--cream)}
.small{font-size:.85rem}
.uppercase{text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:600}

/* ============================================================ TRUST BAR */
.trust-bar{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.4rem .8rem;
  background:rgba(127,163,133,.08);
  border:1px solid rgba(127,163,133,.2);
  border-radius:var(--r-pill);
  font-size:.72rem;
  letter-spacing:.1em;
  color:var(--success);
}
.trust-bar svg{width:12px;height:12px}
.trust-row{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  margin:1rem 0;
}
.trust-row .trust-bar{font-size:.68rem}

/* ============================================================ LOGIN */
.login-wrap{
  position:relative;
  z-index:1;
  min-height:100vh;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  align-items:stretch;
}
@media(max-width:900px){.login-wrap{grid-template-columns:1fr}}

.login-hero{
  position:relative;
  padding:4rem 3.5rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:hidden;
  background:
    radial-gradient(circle at 30% 30%, rgba(232,121,144,.18), transparent 60%),
    linear-gradient(135deg, rgba(74,25,66,.4), rgba(19,8,13,.6));
}
.login-hero::before{
  content:'';
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(115deg, transparent 0, transparent 28px, rgba(212,165,116,.025) 28px, rgba(212,165,116,.025) 29px),
    repeating-linear-gradient(75deg, transparent 0, transparent 28px, rgba(232,121,144,.022) 28px, rgba(232,121,144,.022) 29px);
  pointer-events:none;
}
.login-hero::after{
  content:'';
  position:absolute;
  width:520px;height:520px;
  right:-180px;bottom:-180px;
  background:radial-gradient(circle, rgba(212,80,106,.25), transparent 70%);
  filter:blur(20px);
  pointer-events:none;
}
@media(max-width:900px){.login-hero{padding:3rem 2rem; min-height:30vh}}

.hero-eyebrow{
  font-size:.7rem;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--rose-gold);
  margin-bottom:1.2rem;
  font-weight:500;
}
.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:4.2rem;
  font-weight:400;
  line-height:1;
  color:var(--cream);
  margin-bottom:.5rem;
  font-style:italic;
}
.hero-title b{
  font-style:normal;
  font-weight:600;
  background:linear-gradient(135deg, var(--rose-gold-bright), var(--rose-bright));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero-script{
  font-family:'Pinyon Script', cursive;
  font-size:2.2rem;
  color:var(--rose-bright);
  margin:.3rem 0 1.4rem;
  display:block;
  line-height:1;
  text-shadow:0 0 30px rgba(232,121,144,.4);
}
.hero-tag{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.2rem;
  color:var(--cream-dim);
  max-width:440px;
  line-height:1.5;
  margin-bottom:2rem;
}
.hero-trust{
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
  margin-top:auto;
  position:relative;
  z-index:2;
}

.login-form-wrap{
  display:grid;
  place-items:center;
  padding:3rem 2rem;
  position:relative;
}
.login-card{
  width:100%;
  max-width:420px;
  background:linear-gradient(180deg, var(--bg-elev) 0%, var(--bg-panel) 100%);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2.8rem 2.4rem 2.2rem;
  box-shadow:var(--shadow-deep), var(--shadow-glow);
  position:relative;
  overflow:hidden;
}
.login-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-gold) 30%, var(--rose-bright) 50%, var(--rose-gold) 70%, transparent);
  opacity:.7;
}
.login-card::after{
  content:'';
  position:absolute;
  inset:6px;
  border:1px solid rgba(232,192,148,.08);
  border-radius:calc(var(--r-lg) - 4px);
  pointer-events:none;
}

.wax-seal{
  width:88px;height:88px;
  margin:0 auto 1.2rem;
  position:relative;
  display:flex;
  align-items:center;justify-content:center;
}
.wax-seal::before{
  content:'';
  position:absolute;
  inset:-8px;
  background:radial-gradient(circle, rgba(232,121,144,.3), transparent 60%);
  filter:blur(12px);
  animation: sealGlow 4s ease-in-out infinite alternate;
}
@keyframes sealGlow {
  0%   { opacity:.6; transform:scale(.95) }
  100% { opacity:1; transform:scale(1.05) }
}
.wax-seal svg{width:100%;height:100%;position:relative;z-index:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}

.brand-title{
  text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-size:2.4rem;
  font-weight:500;
  letter-spacing:.04em;
  color:var(--cream);
  margin-bottom:.2rem;
  font-style:italic;
}
.brand-title b{
  font-weight:600;
  font-style:normal;
  color:var(--rose-gold);
}
.brand-sub{
  text-align:center;
  font-size:.7rem;
  letter-spacing:.4em;
  color:var(--muted);
  text-transform:uppercase;
  margin-bottom:1.8rem;
}

.divider{
  position:relative;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--rose-gold-deep), transparent);
  margin:1.6rem 0;
  opacity:.6;
}
.divider.with-ornament::after{
  content:'❦';
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  background:var(--bg-elev);
  padding:0 .8rem;
  color:var(--rose-gold);
  font-size:.9rem;
}

.field{margin-bottom:1.1rem}
.field label{
  display:block;
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.5rem;
  font-weight:500;
}
.field input, .field textarea, .field select{
  width:100%;
  background:var(--bg-deep);
  border:1px solid var(--border);
  color:var(--cream);
  padding:.9rem 1.1rem;
  border-radius:var(--r-sm);
  font-family:inherit;
  font-size:.95rem;
  transition:border-color .25s, box-shadow .25s, background .25s;
  box-shadow:var(--shadow-inset);
}
.field input::placeholder{color:var(--muted-dim);font-style:italic}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none;
  border-color:var(--rose-gold);
  background:var(--bg-base);
  box-shadow:var(--shadow-inset), 0 0 0 3px rgba(212,165,116,.12), 0 0 24px rgba(212,80,106,.1);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.85rem 1.5rem;
  border-radius:var(--r-sm);
  font-weight:500;
  font-size:.92rem;
  letter-spacing:.04em;
  transition:transform .15s, box-shadow .25s, filter .2s, background .2s, color .2s;
  cursor:pointer;
  border:1px solid transparent;
  position:relative;
  overflow:hidden;
}
.btn::before{
  content:'';
  position:absolute;
  top:0;left:-100%;
  width:60%; height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transition:left .6s;
}
.btn:hover::before{left:140%}

.btn-primary{
  background:linear-gradient(180deg, var(--rose) 0%, var(--burgundy) 100%);
  color:var(--cream);
  border-color:var(--burgundy-deep);
  box-shadow: 0 2px 0 var(--burgundy-deep), 0 6px 20px rgba(212,80,106,.35), inset 0 1px 0 rgba(255,255,255,.12);
}
.btn-primary:hover{
  filter:brightness(1.1) saturate(1.05);
  transform:translateY(-1px);
  box-shadow: 0 2px 0 var(--burgundy-deep), 0 10px 28px rgba(212,80,106,.45), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-gold{
  background:linear-gradient(180deg, var(--rose-gold-bright), var(--rose-gold-deep));
  color:#2a0e1e;
  font-weight:600;
  border-color:var(--rose-gold-deep);
  box-shadow: 0 2px 0 rgba(0,0,0,.3), 0 6px 18px rgba(212,165,116,.3), inset 0 1px 0 rgba(255,255,255,.3);
}
.btn-gold:hover{filter:brightness(1.08) saturate(1.05);transform:translateY(-1px)}
.btn-ghost{
  background:transparent;
  color:var(--cream);
  border-color:var(--border);
}
.btn-ghost:hover{border-color:var(--rose-gold);color:var(--rose-gold);background:rgba(212,165,116,.04)}
.btn-danger{
  background:var(--bg-elev);
  color:var(--danger);
  border-color:rgba(198,69,96,.4);
}
.btn-danger:hover{background:var(--burgundy-deep);color:var(--cream)}
.btn-block{width:100%}
.btn-sm{padding:.5rem .9rem;font-size:.82rem}
.btn-row{display:flex;gap:.5rem;flex-wrap:wrap}
.btn-pulse{animation: btnPulse 2.4s ease-in-out infinite}
@keyframes btnPulse{
  0%,100%{box-shadow: 0 2px 0 var(--burgundy-deep), 0 6px 20px rgba(212,80,106,.35), 0 0 0 0 rgba(232,121,144,.4)}
  50%   {box-shadow: 0 2px 0 var(--burgundy-deep), 0 6px 20px rgba(212,80,106,.45), 0 0 0 8px rgba(232,121,144,0)}
}

.demo-roles{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:.5rem;
  margin-top:.6rem;
}
.demo-roles button{
  padding:.7rem .3rem;
  background:var(--bg-elev-2);
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
  color:var(--cream-dim);
  font-size:.78rem;
  transition:all .2s;
  text-align:center;
  position:relative;
  font-weight:500;
}
.demo-roles button:hover{
  border-color:var(--rose-gold);
  background:var(--bg-elev);
  color:var(--rose-gold-bright);
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(212,80,106,.2);
}
.demo-roles .role-mini{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;
  font-style:italic;
  margin-bottom:2px;
}
.demo-roles .role-tag{
  display:block;
  font-size:.6rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
}
.demo-hint{
  font-size:.7rem;
  color:var(--muted-dim);
  text-align:center;
  margin-top:1.2rem;
  letter-spacing:.06em;
  font-style:italic;
}

/* ============================================================ APP SHELL */
.app{
  position:relative;
  z-index:1;
  min-height:100vh;
  display:grid;
  grid-template-columns:280px minmax(0, 1fr);
}

.sidebar{
  background:linear-gradient(180deg, var(--bg-panel) 0%, var(--bg-base) 100%);
  border-right:1px solid var(--border-soft);
  padding:1.5rem 0;
  display:flex;
  flex-direction:column;
  position:sticky;
  top:0;
  height:100vh;
}
.sidebar::before{
  content:'';
  position:absolute;
  top:0; left:0; bottom:0; width:1px;
  background:linear-gradient(180deg, transparent, var(--rose-gold) 30%, var(--rose) 50%, var(--rose-gold) 70%, transparent);
  opacity:.3;
}

.sidebar-header{
  padding:0 1.5rem 1.5rem;
  border-bottom:1px solid var(--border-soft);
}
.sidebar-brand{
  display:flex;align-items:center;gap:.7rem;
}
.sidebar-brand svg{width:36px;height:36px;filter:drop-shadow(0 0 8px rgba(212,80,106,.4))}
.sidebar-brand-text{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;
  font-weight:500;
  color:var(--rose-gold);
  letter-spacing:.04em;
  font-style:italic;
}
.sidebar-brand-text b{font-style:normal;font-weight:600;color:var(--rose-bright)}

.sidebar-user{
  margin-top:1.1rem;
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.04em;
  display:flex;
  align-items:center;
  gap:.5rem;
}
.sidebar-user b{color:var(--cream);font-weight:500;font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-style:italic}
.sec-icon{
  width:14px;height:14px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--success);
}

.nav{padding:1rem 0;flex:1;overflow-y:auto}
.nav-section{
  font-size:.65rem;
  text-transform:uppercase;
  letter-spacing:.25em;
  color:var(--muted-dim);
  padding:1rem 1.5rem .5rem;
  font-weight:600;
}
.nav-item{
  display:flex;
  align-items:center;
  gap:.8rem;
  padding:.7rem 1.5rem;
  color:var(--cream-dim);
  cursor:pointer;
  font-size:.93rem;
  border-left:2px solid transparent;
  transition:all .2s;
  width:100%;
  text-align:left;
  position:relative;
}
.nav-item:hover{
  background:rgba(232,121,144,.05);
  color:var(--rose-gold-bright);
  padding-left:1.75rem;
}
.nav-item.active{
  background:linear-gradient(90deg, rgba(212,80,106,.18), transparent 80%);
  border-left-color:var(--rose);
  color:var(--rose-gold-bright);
}
.nav-item.active::after{
  content:'';
  position:absolute;
  right:1rem; top:50%;
  width:6px;height:6px;
  border-radius:50%;
  background:var(--rose-bright);
  transform:translateY(-50%);
  box-shadow:0 0 10px var(--rose-bright);
}
.nav-item .ico{
  width:22px;height:22px;
  display:inline-flex;
  align-items:center;justify-content:center;
  opacity:.85;
  font-family:'Cormorant Garamond',serif;
  font-size:1.1rem;
  font-style:italic;
}
.nav-item.active .ico{color:var(--rose-bright)}
.nav-badge{
  margin-left:auto;
  background:linear-gradient(180deg, var(--rose), var(--burgundy));
  color:var(--cream);
  font-size:.65rem;
  font-weight:600;
  padding:2px 8px;
  border-radius:var(--r-pill);
  letter-spacing:.05em;
  box-shadow:0 2px 6px rgba(212,80,106,.4);
}
.sidebar-footer{
  padding:1rem 1.5rem;
  border-top:1px solid var(--border-soft);
}
.sidebar-footer .trust-bar{
  width:100%;
  justify-content:center;
  margin-bottom:.6rem;
}

.main{
  padding:2.5rem 3rem 4rem;
  max-width:1500px;
  width:100%;
  min-width:0;
  position:relative;
  overflow-x:hidden;
}

.page-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:2rem;
  padding-bottom:1.4rem;
  border-bottom:1px solid var(--border-soft);
  gap:1rem;
}
.page-header h1{
  font-size:2.6rem;
  letter-spacing:.005em;
  font-style:italic;
  font-weight:400;
}
.page-header h1 b{font-style:normal;font-weight:600;color:var(--rose-gold)}
.page-header h1 .sub{
  display:block;
  font-size:.75rem;
  font-family:'Inter',sans-serif;
  font-style:normal;
  color:var(--rose);
  letter-spacing:.35em;
  text-transform:uppercase;
  margin-bottom:.4rem;
  font-weight:500;
}

/* ============================================================ TABS */
/* Wrapper um Tabs mit Fade-Edges + Pfeilen */
.tabs-wrap{
  position:relative;
  margin-bottom:2rem;
  border-bottom:1px solid var(--border-soft);
}
.tabs-wrap::before,
.tabs-wrap::after{
  content:'';
  position:absolute;
  top:0; bottom:1px;
  width:48px;
  pointer-events:none;
  z-index:2;
  opacity:0;
  transition:opacity .25s;
}
.tabs-wrap::before{
  left:0;
  background:linear-gradient(90deg, var(--bg-base) 0%, var(--bg-base) 10%, transparent 100%);
}
.tabs-wrap::after{
  right:0;
  background:linear-gradient(270deg, var(--bg-base) 0%, var(--bg-base) 10%, transparent 100%);
}
.tabs-wrap.can-scroll-left::before{opacity:1}
.tabs-wrap.can-scroll-right::after{opacity:1}

.tabs-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:32px; height:32px;
  border-radius:50%;
  background:linear-gradient(180deg, var(--rose), var(--burgundy));
  color:var(--champagne);
  border:1px solid var(--rose-gold-deep);
  display:grid; place-items:center;
  cursor:pointer;
  z-index:3;
  font-size:1rem;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s, transform .15s;
  box-shadow:0 2px 10px rgba(0,0,0,.5);
}
.tabs-arrow:hover{filter:brightness(1.15)}
.tabs-arrow:active{transform:translateY(-50%) scale(.92)}
.tabs-arrow.left{left:2px}
.tabs-arrow.right{right:2px}
.tabs-wrap.can-scroll-left .tabs-arrow.left,
.tabs-wrap.can-scroll-right .tabs-arrow.right{
  opacity:1;
  pointer-events:auto;
}

.tabs{
  display:flex;
  gap:.25rem;
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
  scroll-behavior:smooth;
}
.tabs::-webkit-scrollbar{display:none}
.tabs-wrap .tabs{border-bottom:none}
.tab{
  padding:.9rem 1.3rem;
  font-size:.82rem;
  letter-spacing:.1em;
  color:var(--muted);
  border:none;
  background:none;
  cursor:pointer;
  position:relative;
  white-space:nowrap;
  transition:color .2s;
  font-weight:500;
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;
  font-style:italic;
  letter-spacing:.02em;
}
.tab:hover{color:var(--cream)}
.tab.active{color:var(--rose-gold-bright)}
.tab.active::after{
  content:'';
  position:absolute;
  bottom:-1px;left:10%;right:10%;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-bright) 20%, var(--rose-gold) 50%, var(--rose-bright) 80%, transparent);
  border-radius:2px;
  box-shadow:0 0 12px rgba(232,121,144,.5);
}
.tab .tab-count{
  display:inline-block;
  margin-left:.4rem;
  font-size:.7rem;
  color:var(--muted-dim);
  font-weight:400;
  font-family:'Inter',sans-serif;
  font-style:normal;
}
.tab.active .tab-count{color:var(--rose-gold-deep)}

/* ============================================================ CARDS / GRID */
.grid{display:grid;gap:1.3rem}
.grid-stats{grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));margin-bottom:2.5rem}
.grid-cols-2{grid-template-columns:1fr 1fr}
.grid-cols-3{grid-template-columns:repeat(3, 1fr)}
@media(max-width:900px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}}

.card{
  background:linear-gradient(180deg, var(--bg-elev) 0%, var(--bg-panel) 100%);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  padding:1.5rem;
  box-shadow:var(--shadow-card);
  position:relative;
  transition:border-color .2s, transform .2s;
}
.card:hover{border-color:var(--border-warm)}
.card-title{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.1rem;
  padding-bottom:.8rem;
  border-bottom:1px solid var(--border-soft);
}
.card-title h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;
  color:var(--rose-gold-bright);
  letter-spacing:.02em;
  font-style:italic;
  font-weight:500;
}

.stat{
  padding:1.5rem;
  text-align:left;
  position:relative;
  overflow:hidden;
}
.stat::before{
  content:'';
  position:absolute;
  top:-30%; right:-20%;
  width:140px; height:140px;
  background:radial-gradient(circle, rgba(212,80,106,.12), transparent 70%);
  pointer-events:none;
}
.stat-label{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.5rem;
  font-weight:600;
}
.stat-value{
  font-family:'Cormorant Garamond',serif;
  font-size:3rem;
  font-weight:500;
  background:linear-gradient(135deg, var(--rose-gold-bright), var(--rose-bright));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  line-height:1;
}
.stat-foot{
  margin-top:.6rem;
  font-size:.78rem;
  color:var(--muted);
  font-style:italic;
}

/* ============================================================ LIST ITEMS */
.list{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.list-item{
  display:flex;
  align-items:center;
  gap:1rem;
  padding:.95rem 1.1rem;
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
  transition:border-color .2s, transform .15s, background .2s, box-shadow .2s;
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.list-item::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, transparent, rgba(232,121,144,.04), transparent);
  transform:translateX(-100%);
  transition:transform .6s;
}
.list-item:hover{
  border-color:var(--rose-gold);
  transform:translateX(2px);
  box-shadow:0 4px 18px rgba(212,80,106,.15);
}
.list-item:hover::before{transform:translateX(100%)}
.list-item.done{opacity:.6}
.list-item.done .list-title{text-decoration:line-through;text-decoration-color:var(--rose-gold-deep)}
.list-item.overdue{border-left:3px solid var(--danger); box-shadow: -3px 0 14px rgba(198,69,96,.15)}
.list-item.upcoming{border-left:3px solid var(--rose-gold)}

.check{
  width:24px;height:24px;
  border:1.5px solid var(--border-warm);
  border-radius:50%;
  flex-shrink:0;
  display:grid;place-items:center;
  transition:all .25s;
  background:var(--bg-deep);
}
.list-item:hover .check{
  border-color:var(--rose-gold);
  box-shadow:0 0 0 4px rgba(212,165,116,.1);
}
.list-item.done .check{
  background:linear-gradient(135deg, var(--rose-gold), var(--rose-gold-deep));
  border-color:var(--rose-gold);
  box-shadow:0 0 12px rgba(212,165,116,.5);
}
.list-item.done .check::after{
  content:'';
  width:10px;height:5px;
  border-left:2px solid var(--bg-deep);
  border-bottom:2px solid var(--bg-deep);
  transform:rotate(-45deg) translateY(-2px);
}

.list-body{flex:1;min-width:0;position:relative;z-index:1}
.list-title{font-weight:500;color:var(--cream);font-size:.96rem}
.list-meta{
  display:flex;gap:.7rem;flex-wrap:wrap;
  margin-top:.3rem;
  font-size:.76rem;
  color:var(--muted);
  align-items:center;
}
.list-meta .tag{
  padding:2px 9px;border-radius:var(--r-pill);
  background:var(--bg-elev-2);
  border:1px solid var(--border-soft);
  font-size:.7rem;
  font-weight:500;
}
.tag-prio-hoch{color:var(--danger);border-color:rgba(198,69,96,.4);background:rgba(198,69,96,.1)}
.tag-prio-mittel{color:var(--rose-gold-bright);border-color:var(--rose-gold-deep);background:rgba(212,165,116,.08)}
.tag-prio-niedrig{color:var(--muted)}

.list-action{
  display:flex;gap:.3rem;
  opacity:.55;
  transition:opacity .15s;
  position:relative;
  z-index:1;
}
.list-item:hover .list-action{opacity:1}
@media(hover:none){
  /* Touch-Geraete: Buttons immer sichtbar */
  .list-action{opacity:.9}
}
.icon-btn.task-photo{
  color:var(--rose-gold-bright);
  background:rgba(212,165,116,.08);
  border:1px solid var(--rose-gold-deep);
}
.icon-btn.task-photo:hover{
  background:linear-gradient(180deg, var(--rose-gold), var(--rose-gold-deep));
  color:var(--bg-deep);
}
.icon-btn{
  width:32px;height:32px;
  display:grid;place-items:center;
  border-radius:var(--r-sm);
  color:var(--muted);
  transition:all .2s;
  font-size:1rem;
}
.icon-btn:hover{color:var(--rose-gold-bright);background:var(--bg-elev-2)}

/* ============================================================ DAMEN-PORTRAIT-CARDS */
.dame-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(340px, 1fr));
  gap:1.8rem;
}
.dame-card{
  background:linear-gradient(180deg, var(--bg-elev) 0%, var(--bg-panel) 100%);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  padding:0;
  overflow:hidden;
  cursor:pointer;
  transition:transform .3s cubic-bezier(.25,.8,.25,1), border-color .25s, box-shadow .3s;
  position:relative;
}
.dame-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-gold) 30%, var(--rose) 50%, var(--rose-gold) 70%, transparent);
  opacity:.6;
}
.dame-card::after{
  /* Schleifen-Akzent oben rechts (Ribbon) */
  content:'';
  position:absolute;
  top:0; right:18px;
  width:24px; height:38px;
  background:linear-gradient(180deg, var(--rose), var(--burgundy));
  clip-path:polygon(0 0, 100% 0, 100% 100%, 50% 75%, 0 100%);
  box-shadow:0 4px 8px rgba(0,0,0,.4);
  opacity:.85;
}
.dame-card:hover{
  transform:translateY(-6px);
  border-color:var(--rose-gold);
  box-shadow: 0 24px 60px rgba(0,0,0,.55), 0 0 40px rgba(212,80,106,.15);
}
.dame-card-portrait{
  position:relative;
  height:200px;
  background:
    radial-gradient(circle at 50% 40%, rgba(232,121,144,.25), transparent 65%),
    linear-gradient(135deg, var(--burgundy) 0%, var(--plum) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.dame-card-portrait::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(115deg, transparent 0, transparent 16px, rgba(212,165,116,.04) 16px, rgba(212,165,116,.04) 17px);
}
.portrait-monogram{
  font-family:'Pinyon Script', cursive;
  font-size:7rem;
  line-height:1;
  color:var(--champagne);
  text-shadow:0 4px 20px rgba(0,0,0,.5), 0 0 40px rgba(255,217,176,.4);
  position:relative;
  z-index:2;
}
.portrait-ring{
  position:absolute;
  width:150px; height:150px;
  border:1px solid rgba(245,217,180,.3);
  border-radius:50%;
  z-index:1;
}
.portrait-ring.outer{width:180px;height:180px;border-color:rgba(245,217,180,.15)}

.dame-card-body{
  padding:1.4rem 1.5rem 1rem;
  text-align:center;
}
.dame-name{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;
  font-weight:500;
  color:var(--cream);
  letter-spacing:.03em;
  font-style:italic;
  margin-bottom:.1rem;
}
.dame-tag{
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--rose-gold);
  margin-bottom:1rem;
  font-weight:500;
}
.dame-stats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:.4rem;
}
.dame-stats > div{
  padding:.55rem .25rem;
  border-radius:var(--r-sm);
  background:var(--bg-deep);
  border:1px solid var(--border-soft);
  transition:border-color .2s;
}
.dame-card:hover .dame-stats > div{border-color:var(--border-warm)}
.dame-stats .n{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;
  font-weight:600;
  color:var(--rose-gold-bright);
  line-height:1;
}
.dame-stats .l{
  font-size:.6rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:.35rem;
}
.dame-card-foot{
  padding:.9rem 1.5rem;
  border-top:1px solid var(--border-soft);
  display:flex;align-items:center;justify-content:space-between;
  font-size:.76rem;
  color:var(--muted);
  font-style:italic;
}
.dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--success);
  margin-right:.45rem;
  box-shadow:0 0 10px var(--success);
}
.dot.warn{background:var(--warning);box-shadow:0 0 10px var(--warning)}
.dot.danger{background:var(--danger);box-shadow:0 0 10px var(--danger)}

/* Avatar (kompakt fuer Profile-Header etc.) */
.avatar{
  width:54px;height:54px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--burgundy), var(--plum));
  display:grid;place-items:center;
  font-family:'Pinyon Script', cursive;
  font-size:2rem;
  color:var(--champagne);
  border:2px solid var(--rose-gold-deep);
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.4), inset 0 1px 0 rgba(245,217,180,.15);
  position:relative;
}
.avatar.lg{width:84px;height:84px;font-size:3rem}
.avatar.xl{width:140px;height:140px;font-size:5rem}
.avatar.sm{width:36px;height:36px;font-size:1.2rem}

/* Avatar mit Upload-UI */
.avatar-wrap{position:relative;display:inline-block;flex-shrink:0}
.avatar-wrap.editable .avatar{cursor:pointer; transition:filter .2s}
.avatar-wrap.editable:hover .avatar{filter:brightness(1.08)}
.avatar-edit, .avatar-del{
  position:absolute;
  width:34px; height:34px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--rose), var(--burgundy));
  border:2px solid var(--bg-base);
  color:var(--champagne);
  display:grid;
  place-items:center;
  font-size:.95rem;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,.5);
  transition:transform .15s, filter .2s;
  z-index:2;
}
.avatar-edit{bottom:0; right:0}
.avatar-del{top:0; right:0; background:linear-gradient(135deg, var(--danger), var(--burgundy-deep)); font-size:.85rem}
.avatar-edit:hover, .avatar-del:hover{transform:scale(1.1); filter:brightness(1.15)}

/* Portrait mit Foto (Damen-Karte) */
.portrait-photo{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:1;
}
.dame-card-portrait.has-photo::after{
  /* Sanfter Vignette-Effekt fuer Foto */
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(19,8,13,.45));
  z-index:1;
  pointer-events:none;
}
.dame-card-portrait.has-photo .portrait-ring{display:none}

/* ============================================================ DETAIL HEADER (Dame-Profil) */
.profile-head{
  display:flex;
  gap:1.8rem;
  align-items:center;
  padding:2rem;
  background:
    radial-gradient(circle at 80% 20%, rgba(212,80,106,.12), transparent 50%),
    linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  margin-bottom:1.8rem;
  position:relative;
  overflow:hidden;
}
.profile-head::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-gold) 30%, var(--rose-bright) 50%, var(--rose-gold) 70%, transparent);
  opacity:.7;
}
.profile-meta{flex:1}
.profile-meta h2{
  font-size:2.6rem;
  margin-bottom:.2rem;
  color:var(--cream);
  font-style:italic;
  font-weight:500;
}
.profile-meta .sub{
  font-size:.72rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--rose-gold);
  margin-bottom:.6rem;
  font-weight:500;
}
.profile-meta .desc{
  color:var(--cream-dim);
  font-size:1rem;
  max-width:640px;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:300;
  line-height:1.6;
}
.profile-meta .since{
  font-size:.78rem;
  color:var(--muted);
  margin-top:.6rem;
  letter-spacing:.04em;
  font-style:italic;
}

/* ============================================================ TIMELINE / Tagebuch */
.timeline{display:flex;flex-direction:column;gap:1.4rem;position:relative;padding-left:1.8rem}
.timeline::before{
  content:'';
  position:absolute;
  left:7px;top:.6rem;bottom:.6rem;
  width:1px;
  background:linear-gradient(180deg, transparent, var(--rose-gold-deep) 8%, var(--rose-gold-deep) 92%, transparent);
  opacity:.5;
}
.tl-entry{position:relative}
.tl-entry::before{
  content:'';
  position:absolute;
  left:-1.8rem;top:.65rem;
  width:15px;height:15px;
  border-radius:50%;
  background:radial-gradient(circle, var(--rose-bright), var(--burgundy));
  box-shadow:0 0 0 4px var(--bg-base), 0 0 12px var(--rose);
}
.tl-date{
  font-size:.74rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--rose-gold);
  margin-bottom:.45rem;
  font-weight:600;
}
.tl-body{
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
  padding:1.1rem 1.3rem;
  position:relative;
}
.tl-body::before{
  content:'';
  position:absolute;
  left:-7px; top:14px;
  width:14px; height:14px;
  background:var(--bg-elev);
  border-left:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
  transform:rotate(45deg);
}
.tl-body p{
  color:var(--cream);font-size:.96rem;line-height:1.7;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:400;
}
.tl-body p + p{margin-top:.6rem}

/* ============================================================ GALLERY (Beweise) — Polaroid-Style */
.gallery{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
  gap:1.3rem;
}
.gallery-item{
  aspect-ratio:1/1.15;
  background:var(--cream);
  border-radius:4px;
  overflow:hidden;
  position:relative;
  display:flex;
  flex-direction:column;
  cursor:pointer;
  transition:transform .25s, box-shadow .25s;
  padding:8px 8px 0;
  box-shadow:0 6px 20px rgba(0,0,0,.5), inset 0 0 0 1px rgba(255,255,255,.5);
  transform:rotate(-1.5deg);
}
.gallery-item:nth-child(even){transform:rotate(1.2deg)}
.gallery-item:nth-child(3n){transform:rotate(-.5deg)}
.gallery-item:hover{
  transform:rotate(0) scale(1.04);
  box-shadow:0 16px 40px rgba(0,0,0,.6);
  z-index:2;
}
.gallery-item .photo{
  flex:1;
  background:
    radial-gradient(circle at 50% 40%, rgba(232,121,144,.45), transparent 60%),
    linear-gradient(135deg, var(--burgundy) 0%, var(--plum) 100%);
  display:grid;
  place-items:center;
  color:var(--champagne);
  font-family:'Pinyon Script', cursive;
  font-size:3rem;
  text-shadow:0 0 20px rgba(0,0,0,.4);
  position:relative;
}
.gallery-item .photo::after{
  content:'';
  position:absolute; inset:0;
  background:repeating-linear-gradient(115deg, transparent 0 14px, rgba(255,255,255,.04) 14px 15px);
}
.gallery-item .caption{
  padding:10px 4px 12px;
  text-align:center;
  font-family:'Pinyon Script', cursive;
  color:var(--bg-deep);
  font-size:1rem;
  line-height:1.1;
}
.gallery-item .caption small{
  display:block;
  font-family:'Inter',sans-serif;
  font-size:.62rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:#888;
  margin-top:2px;
}
.gallery-del{
  position:absolute;
  top:10px; right:10px;
  width:26px; height:26px;
  border-radius:50%;
  background:rgba(19,8,13,.88);
  color:var(--danger);
  border:1px solid rgba(198,69,96,.5);
  display:grid; place-items:center;
  font-size:.8rem;
  cursor:pointer;
  opacity:0;
  transition:opacity .2s, transform .15s, background .15s, color .15s;
  z-index:4;
}
.gallery-item:hover .gallery-del{opacity:1}
.gallery-del:hover{transform:scale(1.12); background:var(--danger); color:var(--cream); border-color:var(--danger)}

/* ============================================================ KALENDER */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-soft);border:1px solid var(--border-soft);border-radius:var(--r-sm);overflow:hidden}
.cal-head, .cal-day{background:var(--bg-elev);padding:.55rem;min-height:96px;font-size:.78rem}
.cal-head{
  text-align:center;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.68rem;
  color:var(--rose-gold);
  background:var(--bg-panel);
  min-height:auto;
  padding:.75rem .5rem;
}
.cal-day{
  display:flex;flex-direction:column;gap:.2rem;
  cursor:pointer;
  transition:background .2s;
}
.cal-day:hover{background:var(--bg-elev-2)}
.cal-day.outside{opacity:.25}
.cal-day.today{
  background:radial-gradient(circle at 50% 40%, rgba(212,80,106,.25), var(--bg-elev) 70%);
  box-shadow:inset 0 0 0 1px var(--rose);
}
.cal-day .day-num{font-weight:600;color:var(--cream-dim);margin-bottom:.2rem}
.cal-day.today .day-num{color:var(--rose-gold-bright)}
.cal-event{
  display:block;
  font-size:.7rem;
  padding:3px 6px;
  border-radius:4px;
  background:linear-gradient(180deg, var(--rose), var(--burgundy));
  color:var(--cream);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  box-shadow:0 2px 4px rgba(0,0,0,.3);
}
.cal-event.gold{background:linear-gradient(180deg, var(--rose-gold-bright), var(--rose-gold-deep));color:var(--bg-deep)}

/* ============================================================ LIMITS */
.limits-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.3rem;
}
@media(max-width:700px){.limits-grid{grid-template-columns:1fr}}
.limit-box{
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  padding:1.5rem;
  position:relative;
  overflow:hidden;
}
.limit-box.hard{border-left:3px solid var(--danger)}
.limit-box.soft{border-left:3px solid var(--rose-gold)}
.limit-box.hard::before, .limit-box.soft::before{
  content:'';
  position:absolute;
  top:-30%; right:-30%;
  width:200px; height:200px;
  pointer-events:none;
}
.limit-box.hard::before{background:radial-gradient(circle, rgba(198,69,96,.1), transparent 70%)}
.limit-box.soft::before{background:radial-gradient(circle, rgba(212,165,116,.1), transparent 70%)}
.limit-box h4{margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.limit-box ul{list-style:none}
.limit-box li{
  padding:.55rem 0;
  border-bottom:1px solid var(--border-soft);
  font-size:.93rem;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:400;
}
.limit-box li:last-child{border-bottom:none}
.limit-box li::before{
  content:'❦';
  color:var(--rose-gold);
  margin-right:.6rem;
  font-style:normal;
}
.limit-box .lock-note{
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid var(--border-soft);
  font-size:.72rem;
  color:var(--muted);
  display:flex;
  align-items:center;
  gap:.4rem;
  letter-spacing:.06em;
}

/* ============================================================ STREAK BADGE */
.streak{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:3px 10px;
  border-radius:var(--r-pill);
  font-size:.72rem;
  background:linear-gradient(135deg, var(--rose-bright), var(--burgundy));
  color:var(--champagne);
  font-weight:600;
  border:1px solid var(--rose-gold-deep);
  box-shadow:0 2px 6px rgba(212,80,106,.3);
  letter-spacing:.02em;
}
.streak::before{content:'\1F525';font-size:.85rem}

/* ============================================================ FILTER BAR / CHIPS */
.filter-bar{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  align-items:center;
  margin-bottom:1.4rem;
}
.chip{
  padding:.5rem .95rem;
  border-radius:var(--r-pill);
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  color:var(--muted);
  font-size:.78rem;
  cursor:pointer;
  transition:all .2s;
  letter-spacing:.04em;
  font-weight:500;
}
.chip:hover{border-color:var(--rose-gold);color:var(--cream);transform:translateY(-1px)}
.chip.active{
  background:linear-gradient(180deg, var(--rose), var(--burgundy));
  color:var(--champagne);
  border-color:var(--rose-gold-deep);
  box-shadow:0 4px 12px rgba(212,80,106,.3);
}

/* ============================================================ EMPTY */
.empty{
  text-align:center;
  padding:3.5rem 1.5rem;
  color:var(--muted);
}
.empty h3{
  font-family:'Cormorant Garamond',serif;
  color:var(--cream);
  margin-bottom:.6rem;
  font-style:italic;
  font-size:1.6rem;
}
.empty p{font-style:italic; font-family:'Cormorant Garamond',serif; font-size:1.05rem}
.empty::before{
  content:'❦';
  display:block;
  font-size:2rem;
  color:var(--rose-gold);
  margin-bottom:.8rem;
}

/* ============================================================ MODAL */
.modal-back{
  position:fixed;inset:0;
  background:rgba(19,8,13,.78);
  backdrop-filter:blur(8px);
  display:none;
  z-index:50;
  align-items:center;justify-content:center;
  padding:1rem;
}
.modal-back.open{display:flex}
.modal{
  width:100%;
  max-width:580px;
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--border);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-deep), var(--shadow-glow);
  max-height:90vh;
  overflow-y:auto;
  position:relative;
}
.modal::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-gold) 30%, var(--rose-bright) 50%, var(--rose-gold) 70%, transparent);
  opacity:.8;
}
.modal-head{
  padding:1.5rem 1.6rem 1rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid var(--border-soft);
}
.modal-head h3{
  color:var(--rose-gold-bright);
  font-size:1.7rem;
  font-style:italic;
  font-weight:500;
}
.modal-body{padding:1.4rem 1.6rem}
.modal-foot{
  padding:1.1rem 1.6rem;
  display:flex;
  justify-content:flex-end;
  gap:.6rem;
  border-top:1px solid var(--border-soft);
  background:var(--bg-panel);
}
.fields-row{display:flex;gap:1rem}
.fields-row > *{flex:1}

/* ============================================================ TOAST / WACHSSIEGEL-Bestaetigung */
.toast{
  position:fixed;
  bottom:2rem;left:50%;
  transform:translateX(-50%) translateY(120%);
  padding:1rem 1.8rem;
  background:linear-gradient(180deg, var(--rose), var(--burgundy));
  border:1px solid var(--rose-gold);
  border-radius:var(--r-md);
  color:var(--champagne);
  font-size:1rem;
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  letter-spacing:.02em;
  box-shadow:var(--shadow-deep), 0 0 40px rgba(212,80,106,.3);
  transition:transform .35s cubic-bezier(.25,1.5,.5,1);
  z-index:100;
  display:flex;
  align-items:center;
  gap:.7rem;
}
.toast::before{
  content:'❦';
  font-style:normal;
  font-size:1.1rem;
  color:var(--rose-gold-bright);
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ============================================================ NACHRICHTEN */
.msg-list{
  display:flex;
  flex-direction:column;
  gap:.8rem;
  margin-bottom:1.5rem;
  padding:1rem;
  background:var(--bg-base);
  border-radius:var(--r-md);
  border:1px solid var(--border-soft);
  min-height:200px;
}
.msg{
  align-self:flex-start;
  max-width:75%;
  padding:.9rem 1.2rem;
  border-radius:18px 18px 18px 4px;
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  box-shadow:var(--shadow-card);
  position:relative;
}
.msg.mine{
  align-self:flex-end;
  background:linear-gradient(135deg, var(--rose), var(--burgundy));
  border-color:var(--rose-gold-deep);
  border-radius:18px 18px 4px 18px;
  color:var(--champagne);
}
.msg-text{font-size:.95rem;line-height:1.5}
.msg.mine .msg-text{color:var(--champagne)}
.msg-meta{
  font-size:.7rem;
  color:var(--muted);
  margin-top:.4rem;
  font-style:italic;
  letter-spacing:.04em;
}
.msg.mine .msg-meta{color:var(--cream-dim);opacity:.85}

/* ============================================================ MOBILE */
@media(max-width:800px){
  .app{grid-template-columns:1fr}
  .sidebar{
    position:fixed;
    left:-300px;
    width:280px;
    z-index:30;
    transition:left .25s;
  }
  .sidebar.open{left:0}
  .main{padding:1.3rem}
  .page-header{flex-direction:column;align-items:flex-start;gap:.8rem}
  .page-header h1{font-size:1.9rem}
  h1{font-size:1.9rem}
  .stat-value{font-size:2.2rem}
  .hero-title{font-size:2.8rem}
  .mobile-burger{display:flex !important}
}
.mobile-burger{
  display:none;
  width:42px;height:42px;
  align-items:center;justify-content:center;
  border-radius:var(--r-sm);
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  color:var(--rose-gold);
  cursor:pointer;
}

/* Mobile-Header (Burger + Brand + Logout) */
.mobile-header{
  display:none;
  align-items:center;
  justify-content:space-between;
  padding:.7rem .8rem;
  background:linear-gradient(180deg, var(--bg-panel), var(--bg-base));
  border-bottom:1px solid var(--border-soft);
  margin:-1.3rem -1.3rem 1rem;
  position:sticky;
  top:0;
  z-index:25;
  backdrop-filter:blur(8px);
}
.mobile-header .mobile-brand{
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem;
  color:var(--rose-gold);
  letter-spacing:.04em;
  font-style:italic;
}
.mobile-header .mobile-brand b{font-style:normal;font-weight:600;color:var(--rose-bright)}
.mobile-logout{
  width:42px; height:42px;
  display:grid; place-items:center;
  border-radius:var(--r-sm);
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  color:var(--danger);
  cursor:pointer;
  transition:all .2s;
}
.mobile-logout:hover{background:var(--burgundy-deep); color:var(--cream)}

/* Backdrop wenn Sidebar offen */
.sidebar-backdrop{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(19,8,13,.72);
  backdrop-filter:blur(4px);
  z-index:29;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s;
}
@media(max-width:800px){
  .mobile-header{display:flex}
  .mobile-burger{display:flex}
  .sidebar-backdrop{display:block}
  .sidebar-backdrop.open{opacity:1; pointer-events:auto}
  .sidebar.open{left:0; box-shadow:8px 0 32px rgba(0,0,0,.6)}
}

/* Avatar-Hint Overlay */
.avatar-hint{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:radial-gradient(circle, rgba(19,8,13,.85) 30%, rgba(19,8,13,0) 100%);
  display:grid; place-items:center;
  color:var(--rose-gold-bright);
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.05em;
  opacity:0;
  transition:opacity .25s;
  pointer-events:none;
  font-family:'Inter',sans-serif;
}
.avatar-wrap.editable:hover .avatar-hint,
.avatar-wrap.editable:focus-within .avatar-hint{opacity:1}
@media(hover:none){
  /* Touch-Geraete: Hint dauerhaft sichtbar als Plus-Indikator */
  .avatar-wrap.editable .avatar-hint{
    opacity:.85;
    inset:auto;
    bottom:-4px; right:-4px;
    width:38px; height:38px;
    border-radius:50%;
    background:linear-gradient(135deg, var(--rose), var(--burgundy));
    border:2px solid var(--bg-base);
    box-shadow:0 4px 12px rgba(0,0,0,.5);
    color:var(--champagne);
    font-size:1.1rem;
    pointer-events:none;
  }
  /* Auf Touch: Text ausblenden, nur Icon */
  .avatar-wrap.editable .avatar-hint::after{content:'📷'}
  .avatar-wrap.editable .avatar-hint{font-size:0}
  .avatar-wrap.editable .avatar-hint::after{font-size:1.1rem}
}

/* ============================================================ SCROLLBAR */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-deep)}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg, var(--rose-gold-deep), var(--burgundy));
  border-radius:5px;
  border:2px solid var(--bg-deep);
}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg, var(--rose-gold), var(--rose))}

/* ============================================================
   ============ V3 FEATURE-KOMPONENTEN ===========
   ============================================================ */

/* ============================================================ CURSOR GLOW */
.cursor-glow{
  position:fixed;
  pointer-events:none;
  width:380px; height:380px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(232,121,144,.08) 0%, transparent 65%);
  transform:translate(-50%,-50%);
  z-index:0;
  transition:opacity .4s;
  mix-blend-mode:screen;
}

/* ============================================================ ROSEN-KONTO */
.rosen-balance{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.5rem 1rem;
  background:linear-gradient(135deg, rgba(212,80,106,.18), rgba(74,25,66,.4));
  border:1px solid var(--rose-gold-deep);
  border-radius:var(--r-pill);
  font-weight:500;
  font-size:.92rem;
  color:var(--champagne);
  box-shadow:0 4px 14px rgba(212,80,106,.2), inset 0 1px 0 rgba(255,255,255,.06);
  letter-spacing:.04em;
}
.rosen-balance .num{
  font-family:'Cormorant Garamond',serif;
  font-size:1.4rem;
  font-weight:600;
  color:var(--rose-gold-bright);
  line-height:1;
}
.rosen-balance .rose-ico{
  font-size:1.15rem;
  filter:drop-shadow(0 0 6px rgba(232,121,144,.7));
}
.rosen-balance .label{
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--cream-dim);
}
.rosen-balance.compact{padding:.35rem .8rem; font-size:.85rem}
.rosen-balance.compact .num{font-size:1.15rem}

.rosen-cost{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:3px 9px;
  border-radius:var(--r-pill);
  background:rgba(232,121,144,.1);
  color:var(--rose-bright);
  font-size:.78rem;
  font-weight:500;
  border:1px solid rgba(232,121,144,.3);
}

.task-reward{
  font-size:.72rem;
  color:var(--rose-bright);
  display:inline-flex;
  align-items:center;
  gap:.25rem;
}

/* ============================================================ CHARM-HALSBAND */
.necklace{
  position:relative;
  padding:1.5rem 0 2rem;
  margin:1.5rem 0;
}
.necklace-chain{
  position:absolute;
  top:0; left:5%; right:5%;
  height:50px;
  border:1.5px solid transparent;
  border-top-color:var(--rose-gold-deep);
  border-radius:50% / 100% 100% 0 0;
  pointer-events:none;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));
}
.necklace-chain::before{
  content:'';
  position:absolute;
  inset:0;
  border:.5px solid transparent;
  border-top-color:var(--rose-gold);
  border-radius:inherit;
  opacity:.6;
}
.charm-row{
  display:flex;
  justify-content:center;
  align-items:flex-end;
  gap:.6rem;
  flex-wrap:wrap;
  position:relative;
  padding-top:30px;
}
.charm{
  width:54px; height:54px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--rose-gold-bright), var(--rose-gold-deep) 70%, var(--burgundy));
  display:grid;
  place-items:center;
  font-family:'Pinyon Script', cursive;
  font-size:1.6rem;
  color:var(--bg-deep);
  cursor:pointer;
  transition:transform .25s, box-shadow .25s;
  box-shadow:0 4px 10px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.4), inset 0 -1px 0 rgba(0,0,0,.3);
  position:relative;
  z-index:2;
  flex-shrink:0;
}
.charm::before{
  content:'';
  position:absolute;
  top:-12px; left:50%;
  width:1px; height:14px;
  background:linear-gradient(180deg, transparent, var(--rose-gold-deep));
  transform:translateX(-50%);
}
.charm:hover{
  transform:translateY(4px) rotate(-3deg) scale(1.1);
  box-shadow:0 8px 20px rgba(212,80,106,.4), 0 0 20px rgba(232,192,148,.3), inset 0 1px 0 rgba(255,255,255,.4);
}
.charm.locked{
  background:radial-gradient(circle at 35% 30%, var(--bg-elev), var(--bg-deep) 80%);
  color:var(--muted-dim);
  opacity:.4;
  cursor:default;
}
.charm.locked:hover{transform:none;box-shadow:0 4px 10px rgba(0,0,0,.45)}
.charm-tooltip{
  position:absolute;
  bottom:calc(100% + 16px);
  left:50%;
  transform:translateX(-50%);
  padding:.55rem .85rem;
  background:var(--bg-deep);
  border:1px solid var(--rose-gold-deep);
  border-radius:var(--r-sm);
  font-size:.78rem;
  color:var(--cream);
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s;
  box-shadow:var(--shadow-deep);
  z-index:10;
  font-family:'Inter',sans-serif;
  font-weight:500;
}
.charm-tooltip::after{
  content:'';
  position:absolute;
  top:100%; left:50%;
  transform:translateX(-50%);
  border:6px solid transparent;
  border-top-color:var(--rose-gold-deep);
}
.charm-tooltip small{
  display:block;
  font-size:.7rem;
  color:var(--muted);
  font-style:italic;
  margin-top:2px;
  font-weight:400;
}
.charm:hover .charm-tooltip{opacity:1}

/* ============================================================ WACHS-SIEGEL-PRESS */
.wax-press-back{
  position:fixed;inset:0;
  background:rgba(19,8,13,.85);
  backdrop-filter:blur(10px);
  display:none;
  z-index:60;
  align-items:center;justify-content:center;
}
.wax-press-back.open{display:flex}
.wax-press-card{
  text-align:center;
  padding:3rem 2.5rem;
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-deep), var(--shadow-glow);
  max-width:380px;
}
.wax-press-card h3{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--rose-gold-bright);
  font-size:1.6rem;
  margin-bottom:.5rem;
}
.wax-press-card p{color:var(--muted); font-size:.9rem; margin-bottom:1.8rem; font-style:italic}
.wax-stamp{
  width:140px; height:140px;
  margin:0 auto;
  cursor:pointer;
  position:relative;
  user-select:none;
  transition:transform .15s;
}
.wax-stamp:active{transform:scale(.96)}
.wax-stamp svg{width:100%;height:100%;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}
.wax-progress{
  width:140px;
  height:4px;
  background:var(--bg-deep);
  border-radius:2px;
  margin:1.5rem auto 0;
  overflow:hidden;
  position:relative;
}
.wax-progress-fill{
  height:100%;
  width:0%;
  background:linear-gradient(90deg, var(--rose-gold), var(--rose-bright));
  border-radius:2px;
  transition:width .05s linear;
  box-shadow:0 0 8px var(--rose-bright);
}
.wax-press-card .hint{
  font-size:.72rem;
  color:var(--muted-dim);
  margin-top:1rem;
  letter-spacing:.1em;
}

/* ============================================================ BEWERTUNGSSTEMPEL */
.stamp{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:4px 12px;
  border-radius:4px;
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  transform:rotate(-2deg);
  font-family:'Inter',sans-serif;
  position:relative;
  border:2px solid currentColor;
  background:transparent;
}
.stamp::before{
  content:'';
  position:absolute;
  inset:-3px;
  border-radius:6px;
  pointer-events:none;
  opacity:.4;
  box-shadow:inset 0 0 0 1px currentColor;
}
.stamp.lob          { color:var(--success);   transform:rotate(-3deg)}
.stamp.anerkannt    { color:var(--rose-gold); transform:rotate(2deg)}
.stamp.unzureichend { color:var(--danger);    transform:rotate(-1deg)}

.stamp-picker{
  display:flex;
  gap:.4rem;
  margin-top:.5rem;
}
.stamp-picker button{
  padding:4px 10px;
  border:1px solid var(--border);
  background:var(--bg-elev-2);
  border-radius:4px;
  font-size:.7rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  cursor:pointer;
  color:var(--muted);
  transition:all .15s;
}
.stamp-picker button:hover{color:var(--cream); border-color:var(--rose-gold-deep)}
.stamp-picker button.selected{background:var(--burgundy);color:var(--cream);border-color:var(--rose-gold)}

/* ============================================================ TAROT-KARTEN */
.tarot-deck{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  justify-content:center;
  padding:1.5rem 0;
  perspective:1000px;
}
.tarot-card{
  width:120px; height:180px;
  border-radius:var(--r-md);
  position:relative;
  cursor:pointer;
  transform-style:preserve-3d;
  transition:transform .8s cubic-bezier(.5,1.5,.5,1), translate .25s;
}
.tarot-card:hover{translate:0 -8px}
.tarot-card .face{
  position:absolute;
  inset:0;
  border-radius:var(--r-md);
  backface-visibility:hidden;
  display:flex;
  flex-direction:column;
  padding:.8rem;
  border:1px solid var(--rose-gold-deep);
  box-shadow:0 6px 18px rgba(0,0,0,.5);
}
.tarot-back{
  background:
    radial-gradient(circle at 30% 30%, var(--rose), transparent 50%),
    radial-gradient(circle at 70% 70%, var(--plum), transparent 50%),
    linear-gradient(135deg, var(--burgundy), var(--plum));
  display:grid; place-items:center;
}
.tarot-back::before{
  content:'';
  position:absolute;
  inset:6px;
  border:1px solid rgba(232,192,148,.3);
  border-radius:calc(var(--r-md) - 4px);
}
.tarot-back::after{
  content:'❦';
  font-size:2.2rem;
  color:var(--champagne);
  text-shadow:0 0 12px rgba(232,192,148,.5);
  font-family:'Cormorant Garamond',serif;
}
.tarot-front{
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  transform:rotateY(180deg);
  text-align:center;
}
.tarot-front .tarot-symbol{
  font-family:'Pinyon Script', cursive;
  font-size:3rem;
  color:var(--rose-gold-bright);
  text-shadow:0 0 20px rgba(232,121,144,.4);
  flex:1;
  display:grid; place-items:center;
}
.tarot-front .tarot-name{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:.85rem;
  color:var(--cream);
  border-top:1px solid var(--border-soft);
  padding-top:.5rem;
}
.tarot-card.flipped{transform:rotateY(180deg)}

/* ============================================================ STREAK-HEATMAP */
.heatmap{
  display:grid;
  grid-template-columns:repeat(45, 14px);
  grid-auto-rows:14px;
  gap:3px;
  margin-top:.8rem;
  overflow-x:auto;
  overflow-y:hidden;
  padding-bottom:4px;
}
.heatmap-cell{
  width:14px; height:14px;
  background:var(--bg-deep);
  border:1px solid var(--border-soft);
  border-radius:2px;
  position:relative;
  transition:transform .15s;
}
.heatmap-cell:hover{transform:scale(1.4); z-index:5}
.heatmap-cell.kept-0{background:linear-gradient(135deg, rgba(232,121,144,.15), rgba(232,121,144,.25));border-color:rgba(232,121,144,.3)}
.heatmap-cell.kept-1{background:linear-gradient(135deg, rgba(212,80,106,.45), rgba(212,80,106,.65));border-color:var(--rose-deep)}
.heatmap-cell.kept-streak{background:linear-gradient(135deg, var(--rose-bright), var(--rose));border-color:var(--rose-gold);box-shadow:0 0 6px rgba(232,121,144,.4)}
.heatmap-legend{
  display:flex;
  align-items:center;
  gap:.5rem;
  margin-top:.6rem;
  font-size:.72rem;
  color:var(--muted);
}
.heatmap-legend .swatch{
  width:12px; height:12px;
  border-radius:2px;
  display:inline-block;
}
.heatmap-legend .swatch.miss{background:var(--bg-deep);border:1px solid var(--border-soft)}
.heatmap-legend .swatch.keep{background:rgba(212,80,106,.55)}
.heatmap-legend .swatch.streak{background:var(--rose-bright)}

.regel-row{
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  padding:1.1rem 1.3rem;
  margin-bottom:.8rem;
  transition:border-color .2s;
}
.regel-row:hover{border-color:var(--border-warm)}
.regel-row-head{
  display:flex;
  align-items:center;
  gap:1rem;
  margin-bottom:.6rem;
}
.regel-row-head .check{flex-shrink:0}
.regel-row-head .titel{flex:1; font-weight:500;color:var(--cream)}
.regel-row-head .titel small{
  display:block;
  font-size:.72rem;
  color:var(--muted);
  margin-top:2px;
  font-weight:400;
  letter-spacing:.04em;
}

/* ============================================================ STIMMUNGS-TRACKER */
.mood-picker{
  display:flex;
  gap:.5rem;
  margin-top:.8rem;
  align-items:center;
}
.mood-picker .label{
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-right:.3rem;
}
.mood-opt{
  width:42px; height:42px;
  border-radius:50%;
  background:var(--bg-elev);
  border:1px solid var(--border);
  display:grid; place-items:center;
  font-size:1.2rem;
  cursor:pointer;
  transition:all .2s;
  color:var(--muted);
}
.mood-opt:hover{border-color:var(--rose-gold); color:var(--cream); transform:scale(1.1)}
.mood-opt.selected{
  background:linear-gradient(135deg, var(--rose), var(--burgundy));
  border-color:var(--rose-gold);
  color:var(--champagne);
  box-shadow:0 4px 12px rgba(212,80,106,.3);
}

.mood-badge{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:2px 8px 2px 6px;
  border-radius:var(--r-pill);
  background:var(--bg-elev-2);
  font-size:.72rem;
  color:var(--cream-dim);
  border:1px solid var(--border-soft);
}
.mood-badge .ico{
  width:18px; height:18px;
  border-radius:50%;
  display:grid; place-items:center;
  font-size:.9rem;
}
.mood-rose   .ico{background:rgba(232,121,144,.2); color:var(--rose-bright)}
.mood-flamme .ico{background:rgba(232,192,148,.2); color:var(--rose-gold-bright)}
.mood-wachs  .ico{background:rgba(255,217,176,.15); color:var(--champagne)}
.mood-dornen .ico{background:rgba(198,69,96,.2);  color:var(--danger)}
.mood-asche  .ico{background:rgba(124,99,84,.2);  color:var(--muted)}

/* ============================================================ VOICE-NOTE PLAYER */
.voice-bubble{
  display:flex;
  align-items:center;
  gap:.7rem;
  padding:.6rem .9rem;
  min-width:200px;
}
.voice-play{
  width:36px; height:36px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  display:grid; place-items:center;
  cursor:pointer;
  color:inherit;
  transition:background .15s;
}
.voice-play:hover{background:rgba(255,255,255,.18)}
.voice-wave{
  flex:1;
  display:flex;
  align-items:center;
  gap:2px;
  height:24px;
}
.voice-wave span{
  flex:1;
  background:currentColor;
  border-radius:1px;
  opacity:.65;
}
.voice-dur{
  font-size:.74rem;
  font-family:'Inter', monospace;
  letter-spacing:.04em;
  opacity:.8;
  font-variant-numeric:tabular-nums;
}

.voice-record{
  display:flex;
  align-items:center;
  gap:.7rem;
  padding:.7rem 1rem;
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  margin-top:.6rem;
}
.voice-record .rec-btn{
  width:42px;height:42px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--rose), var(--burgundy));
  color:var(--champagne);
  border:none;
  cursor:pointer;
  display:grid; place-items:center;
  box-shadow:0 4px 12px rgba(212,80,106,.3);
  transition:all .2s;
}
.voice-record .rec-btn:hover{transform:scale(1.05)}
.voice-record .rec-btn.recording{
  background:linear-gradient(135deg, var(--danger), var(--burgundy));
  animation: recPulse 1.5s ease-in-out infinite;
}
@keyframes recPulse{
  0%,100%{box-shadow:0 4px 12px rgba(198,69,96,.3), 0 0 0 0 rgba(198,69,96,.5)}
  50%   {box-shadow:0 4px 12px rgba(198,69,96,.5), 0 0 0 12px rgba(198,69,96,0)}
}

/* ============================================================ RITUAL-BRIEFE */
.brief{
  background:
    repeating-linear-gradient(180deg, transparent 0, transparent 38px, rgba(255,217,176,.04) 38px, rgba(255,217,176,.04) 39px),
    linear-gradient(180deg, #2e1c25 0%, #281620 100%);
  border:1px solid var(--rose-gold-deep);
  border-radius:var(--r-md);
  padding:2rem 2.4rem;
  margin-bottom:1.5rem;
  position:relative;
  box-shadow:0 6px 24px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,217,176,.08);
}
.brief::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-gold) 30%, var(--rose-gold-bright) 50%, var(--rose-gold) 70%, transparent);
  opacity:.6;
}
.brief-meta{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:1.2rem;
  padding-bottom:.8rem;
  border-bottom:1px dashed var(--border-soft);
}
.brief-from{
  font-size:.7rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--rose-gold);
  font-weight:500;
}
.brief-date{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--muted);
  font-size:.9rem;
}
.brief-anrede{
  font-family:'Pinyon Script', cursive;
  font-size:2.4rem;
  color:var(--rose-gold-bright);
  line-height:1;
  margin-bottom:1.2rem;
  text-shadow:0 0 16px rgba(232,121,144,.2);
}
.brief-text{
  font-family:'Cormorant Garamond',serif;
  font-size:1.08rem;
  line-height:1.7;
  color:var(--cream);
  font-style:italic;
  font-weight:400;
  white-space:pre-line;
}
.brief-signatur{
  text-align:right;
  margin-top:1.4rem;
  font-family:'Pinyon Script', cursive;
  font-size:1.6rem;
  color:var(--rose-gold-bright);
}

.brief-compose{
  border-style:dashed;
  border-color:var(--border-warm);
  background:var(--bg-panel);
}

/* ============================================================ AUDIT-LOG */
.audit-list{
  display:flex;
  flex-direction:column;
  gap:.4rem;
}
.audit-entry{
  display:flex;
  align-items:center;
  gap:.8rem;
  padding:.65rem 1rem;
  background:var(--bg-elev);
  border-radius:var(--r-sm);
  border:1px solid var(--border-soft);
  font-size:.86rem;
  color:var(--cream-dim);
  transition:border-color .15s;
}
.audit-entry:hover{border-color:var(--border-warm)}
.audit-date{
  font-size:.72rem;
  color:var(--muted);
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.audit-actor{
  font-weight:600;
  color:var(--rose-gold);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  min-width:60px;
}
.audit-text{flex:1}

/* ============================================================ HEUTE-KARTE */
.today-hero{
  background:
    radial-gradient(circle at 70% 20%, rgba(212,80,106,.2), transparent 50%),
    linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--rose-gold-deep);
  border-radius:var(--r-lg);
  padding:2.2rem 2.4rem;
  margin-bottom:1.8rem;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-card), 0 0 40px rgba(212,80,106,.1);
}
.today-hero::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-bright) 30%, var(--rose-gold-bright) 50%, var(--rose-bright) 70%, transparent);
}
.today-greeting{
  font-family:'Cormorant Garamond',serif;
  font-size:.9rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--rose-gold);
  margin-bottom:.5rem;
  font-weight:500;
}
.today-date{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:2.4rem;
  color:var(--cream);
  font-weight:400;
  margin-bottom:.3rem;
  line-height:1;
}
.today-date b{
  font-style:normal;
  font-weight:600;
  background:linear-gradient(135deg, var(--rose-gold-bright), var(--rose-bright));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.today-sub{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--muted);
  font-size:1.05rem;
}

.today-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:1.4rem;
  margin-top:1.5rem;
}
@media(max-width:800px){.today-grid{grid-template-columns:1fr}}

.today-block{
  background:var(--bg-deep);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  padding:1.2rem 1.4rem;
}
.today-block h4{
  margin-bottom:1rem;
  display:flex;
  align-items:center;
  gap:.5rem;
}

/* ============================================================ SELF-DESTRUCT BADGE */
.expires-badge{
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  padding:2px 8px;
  background:rgba(124,99,84,.15);
  border:1px solid rgba(184,152,128,.3);
  border-radius:var(--r-pill);
  font-size:.7rem;
  color:var(--muted);
  font-style:italic;
}

/* ============================================================ SHOP / ANGEBOTE */
.reward-shop{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:1rem;
  margin-top:1rem;
}
.reward-card{
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  padding:1.3rem;
  position:relative;
  overflow:hidden;
  transition:transform .2s, border-color .2s;
}
.reward-card:hover{border-color:var(--rose-gold); transform:translateY(-2px)}
.reward-card::before{
  content:'';
  position:absolute;
  top:-30%; right:-20%;
  width:160px; height:160px;
  background:radial-gradient(circle, rgba(212,80,106,.12), transparent 70%);
}
.reward-card .title{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.25rem;
  color:var(--cream);
  margin-bottom:.6rem;
}
.reward-card .reward-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:1rem;
}
.reward-card.affordable{border-color:var(--rose-gold-deep)}
.reward-card.affordable::after{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--rose-gold), transparent);
  opacity:.7;
}

/* ============================================================
   VORLIEBEN — Bewertungs-Skala + Wizard
   ============================================================ */

.rating-scale-legend{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.5rem;
  padding:1rem 1.4rem;
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  margin-bottom:1.5rem;
  flex-wrap:wrap;
}
.rating-scale-legend .leg{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.3rem;
  min-width:88px;
  flex:1;
}
.rating-scale-legend .leg .rd{
  width:42px;height:42px;
  border-radius:50%;
  display:grid;place-items:center;
  font-size:1.3rem;
  border:1px solid var(--border);
  background:var(--bg-deep);
  color:var(--muted);
}
.rating-scale-legend .leg .lbl{
  font-size:.7rem;
  letter-spacing:.05em;
  color:var(--muted);
  text-align:center;
  line-height:1.2;
}
.rating-scale-legend .leg.extra{border-left:1px dashed var(--border); padding-left:1rem}

/* Aktive Skala neben dem Eintrag */
.rating-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.9rem 1.2rem;
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  margin-bottom:.5rem;
  transition:border-color .15s, background .15s;
  flex-wrap:wrap;
}

/* Title-Wrapper in rating-row */
.rating-row-titlewrap{
  flex:1;
  min-width:160px;
}

/* Mobile: Titel oben, Buttons darunter */
@media(max-width:680px){
  .rating-row{
    flex-direction:column;
    align-items:stretch;
    gap:.5rem;
    padding:.7rem .9rem;
  }
  .rating-row-titlewrap{
    min-width:0;
    width:100%;
  }
  .rating-buttons{
    justify-content:space-between;
    gap:.2rem;
    width:100%;
  }
  .rating-btn{
    width:44px; height:44px;
    font-size:1.15rem;
    flex:1 1 auto;
    max-width:48px;
  }
  .rating-divider{display:none}
  .rating-scale-legend{
    padding:.7rem .5rem;
    gap:.25rem;
  }
  .rating-scale-legend .leg{
    min-width:0;
    flex:1 1 calc(33% - .5rem);
  }
  .rating-scale-legend .leg .rd{
    width:32px; height:32px;
    font-size:.95rem;
  }
  .rating-scale-legend .leg .lbl{
    font-size:.6rem;
    letter-spacing:.02em;
  }
  .rating-scale-legend .leg.extra{
    border-left:none;
    padding-left:0;
    border-top:1px dashed var(--border);
    padding-top:.5rem;
    flex-basis:100%;
    margin-top:.3rem;
  }
  /* Wizard kompakter */
  .wizard-wrap{padding:1.5rem 1rem}
  .wizard-title{font-size:1.8rem}
  .wizard-step-title{font-size:1.4rem}
  .wizard-foot{flex-direction:column; gap:1rem; align-items:stretch}
  .wizard-foot .btn-row{justify-content:space-between}
  /* Hero-Header schmaler */
  .profile-head{flex-direction:column; text-align:center; padding:1.4rem 1rem}
  .profile-head > div:last-child{align-items:center !important}
  .profile-meta h2{font-size:1.9rem}
  .profile-meta .desc{font-size:.95rem}
  /* Charm-Halsband ist breit -> erlaube horizontal-scroll */
  .charm-row{overflow-x:auto; overflow-y:hidden; flex-wrap:nowrap; justify-content:flex-start; padding:0 1rem}
  .necklace-chain{display:none}
}
.rating-row.has-rating{background:linear-gradient(90deg, rgba(212,80,106,.06), var(--bg-elev) 70%); border-color:var(--border-warm)}
.rating-row.is-tabu{border-left:3px solid var(--danger)}
.rating-row.is-love{border-left:3px solid var(--rose-bright); background:linear-gradient(90deg, rgba(232,121,144,.1), var(--bg-elev) 70%)}
.rating-row.is-try{border-left:3px solid var(--rose-gold-bright)}

.rating-row .rt-title{
  flex:1;
  font-weight:500;
  color:var(--cream);
  font-size:.96rem;
  min-width:160px;
}
.rating-row .rt-current{
  font-size:.74rem;
  color:var(--muted);
  margin-top:.15rem;
  font-style:italic;
  letter-spacing:.02em;
  display:block;
}
.rating-row.is-tabu .rt-current{color:var(--danger)}
.rating-row.is-love .rt-current{color:var(--rose-bright)}
.rating-row.is-try .rt-current{color:var(--rose-gold-bright)}

.rating-buttons{
  display:flex;
  gap:.35rem;
  flex-wrap:nowrap;
}
.rating-btn{
  width:40px; height:40px;
  border-radius:50%;
  display:grid;place-items:center;
  font-size:1.15rem;
  border:1.5px solid var(--border);
  background:var(--bg-deep);
  color:var(--muted-dim);
  cursor:pointer;
  transition:all .2s;
  flex-shrink:0;
  font-family:'Inter',sans-serif;
}
.rating-btn:hover{
  border-color:var(--rose-gold);
  color:var(--cream);
  transform:translateY(-2px);
}
.rating-btn[data-rating="1"]:hover, .rating-btn[data-rating="1"].active{
  background:radial-gradient(circle, rgba(198,69,96,.4), rgba(198,69,96,.15));
  border-color:var(--danger);
  color:var(--danger);
  box-shadow:0 0 12px rgba(198,69,96,.3);
}
.rating-btn[data-rating="2"]:hover, .rating-btn[data-rating="2"].active{
  background:rgba(184,152,128,.15);
  border-color:var(--muted);
  color:var(--cream-dim);
}
.rating-btn[data-rating="3"]:hover, .rating-btn[data-rating="3"].active{
  background:rgba(245,232,214,.08);
  border-color:var(--cream-dim);
  color:var(--cream);
}
.rating-btn[data-rating="4"]:hover, .rating-btn[data-rating="4"].active{
  background:radial-gradient(circle, rgba(212,165,116,.3), rgba(212,165,116,.1));
  border-color:var(--rose-gold);
  color:var(--rose-gold-bright);
  box-shadow:0 0 12px rgba(212,165,116,.25);
}
.rating-btn[data-rating="5"]:hover, .rating-btn[data-rating="5"].active{
  background:radial-gradient(circle, rgba(232,121,144,.45), rgba(212,80,106,.2));
  border-color:var(--rose-bright);
  color:var(--cream);
  box-shadow:0 0 16px rgba(232,121,144,.4);
}
.rating-btn[data-rating="ausprobieren"]:hover, .rating-btn[data-rating="ausprobieren"].active{
  background:radial-gradient(circle, rgba(232,192,148,.35), rgba(212,165,116,.15));
  border-color:var(--rose-gold-bright);
  color:var(--rose-gold-bright);
  box-shadow:0 0 12px rgba(232,192,148,.4);
}
.rating-btn .sep-mark{
  display:inline-block;
  width:1px;height:24px;
  background:var(--border);
  margin:0 .3rem;
  flex-shrink:0;
}
.rating-divider{
  width:1px;
  height:36px;
  background:linear-gradient(180deg, transparent, var(--border), transparent);
  margin:0 .25rem;
  align-self:center;
  flex-shrink:0;
}

/* ============================================================ WIZARD */
.wizard-wrap{
  background:linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
  border:1px solid var(--rose-gold-deep);
  border-radius:var(--r-lg);
  padding:2.5rem 2.8rem;
  box-shadow:var(--shadow-card), 0 0 60px rgba(212,80,106,.12);
  position:relative;
  overflow:hidden;
  margin-bottom:2rem;
}
.wizard-wrap::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--rose-gold) 20%, var(--rose-bright) 50%, var(--rose-gold) 80%, transparent);
  opacity:.7;
}

.wizard-head{
  margin-bottom:2rem;
  text-align:center;
}
.wizard-eyebrow{
  font-size:.7rem;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:var(--rose-gold);
  margin-bottom:.5rem;
  font-weight:500;
}
.wizard-title{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:2.6rem;
  color:var(--cream);
  margin-bottom:.4rem;
  line-height:1.1;
}
.wizard-title b{
  font-style:normal;
  font-weight:600;
  background:linear-gradient(135deg, var(--rose-gold-bright), var(--rose-bright));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.wizard-intro{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.1rem;
  color:var(--cream-dim);
  max-width:580px;
  margin:0 auto;
  line-height:1.6;
}

.wizard-progress{
  display:flex;
  gap:.5rem;
  justify-content:center;
  margin:1.5rem 0;
}
.wizard-progress .step{
  width:36px;height:8px;
  border-radius:4px;
  background:var(--bg-deep);
  border:1px solid var(--border-soft);
  transition:all .3s;
}
.wizard-progress .step.done{
  background:linear-gradient(90deg, var(--rose-gold-deep), var(--rose-gold));
  border-color:var(--rose-gold);
}
.wizard-progress .step.current{
  background:linear-gradient(90deg, var(--rose), var(--rose-bright));
  border-color:var(--rose-bright);
  box-shadow:0 0 8px rgba(232,121,144,.5);
  width:48px;
}

.wizard-step-info{
  text-align:center;
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:.6rem;
}
.wizard-step-title{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.8rem;
  color:var(--rose-gold-bright);
  text-align:center;
  margin-bottom:.4rem;
}
.wizard-step-intro{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.02rem;
  color:var(--muted);
  text-align:center;
  margin-bottom:1.5rem;
  max-width:560px;
  margin-left:auto;margin-right:auto;
}

.wizard-list{
  display:flex;
  flex-direction:column;
  gap:.4rem;
}

.wizard-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid var(--border-soft);
}
.wizard-counter{
  font-size:.85rem;
  color:var(--muted);
  font-style:italic;
}
.wizard-counter b{color:var(--rose-gold-bright); font-weight:500}

/* Banner: Vorlieben noch nicht ausgefüllt */
.vor-banner{
  display:flex;
  align-items:center;
  gap:1.2rem;
  padding:1.2rem 1.5rem;
  background:linear-gradient(90deg, rgba(212,80,106,.15), rgba(74,25,66,.3));
  border:1px solid var(--rose-gold);
  border-radius:var(--r-md);
  margin-bottom:1.5rem;
  box-shadow:0 4px 16px rgba(212,80,106,.15);
  position:relative;
  overflow:hidden;
}
.vor-banner::before{
  content:'';
  position:absolute;
  top:0;left:0;bottom:0;
  width:4px;
  background:linear-gradient(180deg, var(--rose-bright), var(--rose-gold));
}
.vor-banner .ico{
  width:48px;height:48px;
  border-radius:50%;
  background:radial-gradient(circle, var(--rose), var(--burgundy));
  display:grid;place-items:center;
  flex-shrink:0;
  font-family:'Pinyon Script', cursive;
  font-size:1.7rem;
  color:var(--champagne);
  box-shadow:0 0 16px rgba(232,121,144,.3);
}
.vor-banner .body{flex:1}
.vor-banner .body h4{
  margin-bottom:.2rem;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.25rem;
  text-transform:none;
  letter-spacing:.01em;
  font-weight:500;
}
.vor-banner .body p{
  font-size:.88rem;
  color:var(--cream-dim);
  font-style:italic;
}

/* Vorlieben-Anzeige (read-only Liste) */
.vor-section{
  margin-bottom:2rem;
}
.vor-section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:1rem;
  padding-bottom:.6rem;
  border-bottom:1px solid var(--border-soft);
}
.vor-section-head h3{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--rose-gold-bright);
  font-size:1.6rem;
  font-weight:500;
}
.vor-section-count{
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.04em;
}

.vor-list{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:.5rem;
}
.vor-pill{
  display:flex;
  align-items:center;
  gap:.7rem;
  padding:.55rem .8rem;
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  border-radius:var(--r-sm);
  font-size:.88rem;
  color:var(--cream);
}
.vor-pill .vr-circle{
  width:28px; height:28px;
  border-radius:50%;
  display:grid;place-items:center;
  font-size:.95rem;
  flex-shrink:0;
}
.vor-pill .vr-name{flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}

.vor-pill.r1{border-left:3px solid var(--danger)}
.vor-pill.r1 .vr-circle{background:rgba(198,69,96,.15); color:var(--danger)}
.vor-pill.r2 .vr-circle{background:rgba(184,152,128,.1); color:var(--muted)}
.vor-pill.r3 .vr-circle{background:rgba(245,232,214,.08); color:var(--cream-dim)}
.vor-pill.r4{border-left:3px solid var(--rose-gold)}
.vor-pill.r4 .vr-circle{background:rgba(212,165,116,.15); color:var(--rose-gold-bright)}
.vor-pill.r5{border-left:3px solid var(--rose-bright); background:linear-gradient(90deg, rgba(232,121,144,.08), var(--bg-elev) 70%)}
.vor-pill.r5 .vr-circle{background:radial-gradient(circle, rgba(232,121,144,.5), rgba(212,80,106,.2)); color:var(--cream); box-shadow:0 0 8px rgba(232,121,144,.3)}
.vor-pill.try{border-left:3px solid var(--rose-gold-bright)}
.vor-pill.try .vr-circle{background:radial-gradient(circle, rgba(232,192,148,.4), rgba(212,165,116,.1)); color:var(--rose-gold-bright)}

/* Tabs in der Vorlieben-Übersicht (Kategorie-Filter) */
.vor-cat-tabs{
  display:flex;
  gap:.4rem;
  flex-wrap:wrap;
  margin-bottom:1.5rem;
}
.vor-cat-tab{
  padding:.5rem 1rem;
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  border-radius:var(--r-pill);
  color:var(--muted);
  font-size:.82rem;
  cursor:pointer;
  transition:all .2s;
}
.vor-cat-tab:hover{border-color:var(--rose-gold); color:var(--cream)}
.vor-cat-tab.active{
  background:linear-gradient(180deg, var(--rose), var(--burgundy));
  color:var(--champagne);
  border-color:var(--rose-gold);
  box-shadow:0 2px 8px rgba(212,80,106,.3);
}

/* Übersichts-Kacheln: 5 Stufen-Zähler */
.vor-summary{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:.6rem;
  margin-bottom:1.5rem;
}
@media(max-width:700px){.vor-summary{grid-template-columns:repeat(3,1fr)}}
.vor-sum-card{
  text-align:center;
  padding:1rem .5rem;
  background:var(--bg-elev);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
}
.vor-sum-card.tabu{border-color:rgba(198,69,96,.4)}
.vor-sum-card.love{border-color:var(--rose-bright); background:linear-gradient(180deg, rgba(232,121,144,.1), var(--bg-elev))}
.vor-sum-card.try{border-color:var(--rose-gold-bright)}
.vor-sum-card .n{
  font-family:'Cormorant Garamond',serif;
  font-size:2rem;
  font-weight:600;
  color:var(--rose-gold-bright);
  line-height:1;
}
.vor-sum-card.tabu .n{color:var(--danger)}
.vor-sum-card.love .n{color:var(--rose-bright)}
.vor-sum-card .lbl{
  font-size:.7rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:.4rem;
}

/* ============================================================ KEYBOARD-HINT (Panic) */
.panic-hint{
  position:fixed;
  bottom:1rem;
  right:1rem;
  font-size:.65rem;
  color:var(--muted-dim);
  letter-spacing:.1em;
  text-transform:uppercase;
  z-index:5;
  opacity:.4;
  pointer-events:none;
}

