/* ════════════════════════════════════════════════════════════════
   Blütenpfad · cozy Animal-Crossing-Botanik-Feldbuch
   ════════════════════════════════════════════════════════════════ */
:root{
  --paper:#fbf5e6; --paper-2:#f3e9d2; --card:#fffdf6; --card-2:#fff8e9;
  --ink:#4a4a37; --ink-soft:#8a886e; --ink-faint:#b3ad93;
  --leaf:#82ad52; --leaf-d:#5f8a39; --leaf-l:#a9d27f; --leaf-pale:#e8f1d6;
  --corn:#6e8fd6; --poppy:#ec7a64; --butter:#f3c34c; --lav:#a48fd0;
  --blossom:#ef9bbd; --sky:#86c0e6; --honey:#e9a94e;
  --border:#e7d9b6; --border-d:#d9c79b;
  --shadow:rgba(120,96,46,.16); --shadow-d:rgba(120,96,46,.28);
  --r:22px; --r-lg:30px; --r-sm:14px;
  --font-d:"Fredoka","Baloo 2","Quicksand",system-ui,sans-serif;
  --font-b:"Nunito","Quicksand",system-ui,-apple-system,sans-serif;
  --tab-h:74px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
/* hidden muss display gewinnen: .sheet-wrap/.modal-wrap/.bloom setzen display:flex/grid
   und würden sonst das [hidden]-Attribut überstimmen → Overlays bleiben sichtbar */
[hidden]{display:none!important}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-b); color:var(--ink);
  background:
    radial-gradient(120% 80% at 50% -10%, #fefaef 0%, var(--paper) 45%, var(--paper-2) 100%) fixed;
  min-height:100dvh; overflow-x:hidden;
  padding-bottom:calc(var(--tab-h) + env(safe-area-inset-bottom));
  -webkit-text-size-adjust:100%;
}

/* ── dekorativer Hintergrund ── */
.bg-decor{position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden}
.grain{position:absolute; inset:0; width:100%; height:100%; opacity:.05; mix-blend-mode:multiply}
.float{position:absolute; font-size:2.4rem; opacity:.5; filter:drop-shadow(0 4px 6px rgba(0,0,0,.06)); animation:sway 9s ease-in-out infinite}
.float.l1{top:8%; left:-2%; font-size:3.2rem; animation-duration:11s}
.float.p1{top:18%; right:4%; animation-delay:-2s}
.float.l2{top:52%; left:3%; font-size:2.8rem; animation-delay:-4s; animation-duration:13s}
.float.p2{top:66%; right:-1%; font-size:3rem; animation-delay:-1s}
.float.p3{top:38%; left:46%; font-size:1.8rem; opacity:.35; animation-delay:-6s}
@keyframes sway{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-22px) rotate(8deg)}}

/* ── Layout ── */
main{position:relative; z-index:1; max-width:680px; margin:0 auto; padding:0 16px 28px}
.view{display:none; animation:viewIn .4s cubic-bezier(.2,.8,.3,1)}
.view.active{display:block}
@keyframes viewIn{from{opacity:0; transform:translateY(10px)}to{opacity:1; transform:none}}

/* ── Topbar ── */
.topbar{
  position:relative; z-index:2; max-width:680px; margin:0 auto;
  padding:calc(env(safe-area-inset-top) + 14px) 18px 14px; display:flex;
  align-items:center; gap:14px; flex-wrap:wrap;
}
.brand{display:flex; align-items:center; gap:12px; flex:1 1 auto}
.logo{display:grid; place-items:center; width:60px; height:60px; border-radius:50%;
  background:radial-gradient(circle at 38% 32%, #fff, var(--leaf-pale));
  box-shadow:0 6px 0 var(--border-d), 0 10px 18px var(--shadow); flex:0 0 auto}
.logo svg{animation:bob 4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-3px) rotate(2deg)}}
.brand-txt h1{font-family:var(--font-d); font-weight:700; font-size:1.7rem; margin:0; line-height:1;
  color:var(--leaf-d); letter-spacing:.3px; text-shadow:0 2px 0 #fff}
.brand-txt p{margin:3px 0 0; font-size:.82rem; color:var(--ink-soft); font-weight:600}

.stats{display:flex; gap:8px}
.stat{background:var(--card); border:2px solid var(--border); border-bottom-width:4px;
  border-radius:16px; padding:6px 12px; text-align:center; min-width:58px; box-shadow:0 3px 8px var(--shadow)}
.stat b{font-family:var(--font-d); font-size:1.25rem; color:var(--leaf-d); display:block; line-height:1}
.stat span{font-size:.64rem; color:var(--ink-soft); font-weight:700; text-transform:uppercase; letter-spacing:.4px}
.stat.to-harvest b{color:var(--honey)}

/* ── Cards ── */
.card{background:var(--card); border:2px solid var(--border); border-radius:var(--r-lg);
  padding:20px; margin:14px 0; box-shadow:0 6px 0 var(--border), 0 14px 24px var(--shadow); position:relative}
.card h2{font-family:var(--font-d); font-weight:600; font-size:1.4rem; margin:.2em 0 .15em; color:var(--ink)}
.card h3{font-family:var(--font-d); font-weight:600; font-size:1.1rem; margin:0; color:var(--ink)}
.muted{color:var(--ink-soft)} .hint{font-size:.8rem; color:var(--ink-faint); margin:.5em 0 0; text-align:center}
.card-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:12px}
.link{background:none; border:none; color:var(--leaf-d); font-family:var(--font-d); font-weight:600; font-size:.9rem; cursor:pointer}

.reveal{animation:pop .5s cubic-bezier(.2,.9,.3,1.2) both; animation-delay:var(--d,0s)}
@keyframes pop{from{opacity:0; transform:translateY(16px) scale(.97)}to{opacity:1; transform:none}}

/* Hero */
.hero{text-align:center; overflow:hidden;
  background:linear-gradient(170deg, var(--card) 0%, var(--card-2) 100%)}
.hero-art{display:flex; justify-content:center; gap:6px; font-size:1.9rem; margin-bottom:2px}
.hero-art span{animation:bob 3.5s ease-in-out infinite}
.hero-art span:nth-child(2){animation-delay:.3s}.hero-art span:nth-child(3){animation-delay:.6s}.hero-art span:nth-child(4){animation-delay:.9s}
.hero-actions{display:flex; flex-direction:column; gap:12px; margin-top:18px}

/* ── Buttons (chunky AC-Stil) ── */
.btn{font-family:var(--font-d); font-weight:600; font-size:1rem; border-radius:18px;
  border:2px solid var(--border-d); border-bottom-width:6px; background:linear-gradient(#fff,#fbf3df);
  color:var(--ink); padding:12px 18px; cursor:pointer; transition:transform .08s, border-bottom-width .08s, box-shadow .15s;
  display:inline-flex; align-items:center; justify-content:center; gap:9px; box-shadow:0 5px 12px var(--shadow)}
.btn .bi{font-size:1.25em}
.btn:active{transform:translateY(3px); border-bottom-width:3px}
.btn.big{padding:16px 20px; font-size:1.12rem; border-radius:20px}
.btn.sm{padding:8px 13px; font-size:.85rem; border-bottom-width:4px; border-radius:14px}
.btn-primary{background:linear-gradient(var(--leaf-l),var(--leaf)); border-color:var(--leaf-d);
  color:#fff; text-shadow:0 1px 1px rgba(60,80,30,.4)}
.btn-soft{background:linear-gradient(#fff,#f4eede)}
.btn-honey{background:linear-gradient(#f7d27e,var(--honey)); border-color:#c98a2b; color:#5a3c12; text-shadow:0 1px 0 rgba(255,255,255,.4)}
.btn-danger{background:linear-gradient(#f6b8ac,#e87a64); border-color:#c2533c; color:#5a2418}

/* GPS-Chip */
.gps-chip{display:inline-flex; align-items:center; gap:8px; margin:14px auto 0; padding:7px 14px;
  background:var(--leaf-pale); border:2px solid #cfe3ac; border-radius:999px; font-size:.85rem;
  font-weight:700; color:var(--leaf-d)}
.gps-chip .dot{width:9px; height:9px; border-radius:50%; background:var(--leaf); box-shadow:0 0 0 0 rgba(130,173,82,.6); animation:pulse 1.8s infinite}
.gps-chip.searching .dot{background:var(--honey)}
.gps-chip.off .dot{background:var(--ink-faint); animation:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(130,173,82,.5)}70%{box-shadow:0 0 0 10px rgba(130,173,82,0)}100%{box-shadow:0 0 0 0 rgba(130,173,82,0)}}

/* Tips */
.tips{margin:10px 0 0; padding-left:22px; line-height:1.55; font-size:.92rem; color:var(--ink)}
.tips li{margin-bottom:7px}
.tips li::marker{color:var(--leaf); font-weight:800}

/* Recent strip */
.recent-strip{display:flex; gap:10px; overflow-x:auto; padding-bottom:4px; scroll-snap-type:x mandatory}
.recent-strip::-webkit-scrollbar{height:0}
.rec{flex:0 0 auto; width:96px; scroll-snap-align:start; cursor:pointer}
.rec img{width:96px; height:96px; object-fit:cover; border-radius:16px; border:2px solid var(--border);
  box-shadow:0 4px 8px var(--shadow); display:block}
.rec span{display:block; font-size:.72rem; font-weight:700; margin-top:4px; color:var(--ink);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-align:center}
.empty-mini{color:var(--ink-faint); font-size:.9rem; margin:6px 0}

/* ── Segmented controls / Toolbar ── */
.map-toolbar,.journal-toolbar{display:flex; align-items:center; gap:10px; margin:14px 0; flex-wrap:wrap}
.seg{display:inline-flex; background:var(--paper-2); border:2px solid var(--border); border-radius:14px; padding:3px; gap:3px}
.seg-btn{font-family:var(--font-d); font-weight:600; font-size:.85rem; border:none; background:none;
  color:var(--ink-soft); padding:7px 13px; border-radius:11px; cursor:pointer; transition:.15s}
.seg-btn.active{background:var(--card); color:var(--leaf-d); box-shadow:0 2px 6px var(--shadow)}
.chip-toggle{display:inline-flex; align-items:center; gap:8px; font-family:var(--font-d); font-weight:600;
  font-size:.85rem; color:var(--ink-soft); background:var(--card); border:2px solid var(--border);
  border-radius:14px; padding:7px 13px; cursor:pointer}
.chip-toggle .cbox{width:16px; height:16px; border-radius:6px; border:2px solid var(--border-d); background:#fff; transition:.15s}
.chip-toggle.on{color:var(--honey); border-color:var(--honey)}
.chip-toggle.on .cbox{background:var(--honey); border-color:var(--honey); box-shadow:inset 0 0 0 2px #fff}

/* ── Karte ── */
#map{height:60dvh; min-height:240px; border-radius:var(--r-lg);
  border:3px solid var(--border-d); box-shadow:0 8px 22px var(--shadow); overflow:hidden; background:#dbe8d2}
.leaflet-container{font-family:var(--font-b)}
.flower-pin{position:relative; display:grid; place-items:center; width:38px; height:38px; border-radius:50% 50% 50% 4px;
  transform:rotate(45deg); border:2.5px solid #fff; box-shadow:0 4px 8px rgba(0,0,0,.3); font-size:1rem}
.flower-pin span{transform:rotate(-45deg)}
.flower-pin.done{filter:grayscale(.35) brightness(1.04)}
.flower-pin.done::after{content:"✓"; position:absolute; transform:rotate(-45deg) translate(11px,-13px);
  font-size:.7rem; background:var(--leaf-d); color:#fff; border-radius:50%; width:16px; height:16px;
  display:grid; place-items:center; border:2px solid #fff}
.leaflet-popup-content-wrapper{border-radius:18px; border:2px solid var(--border); box-shadow:0 8px 20px var(--shadow-d)}
.leaflet-popup-content{margin:10px 12px; font-family:var(--font-b)}
.pop{width:160px; text-align:center}
.pop img{width:100%; height:100px; object-fit:cover; border-radius:12px; margin-bottom:7px}
.pop b{font-family:var(--font-d); color:var(--ink); display:block}
.pop small{color:var(--ink-soft)}
.pop button{margin-top:8px; width:100%}
.marker-cluster{background:rgba(130,173,82,.35); border-radius:50%}
.marker-cluster div{width:34px; height:34px; margin:3px; border-radius:50%; display:grid; place-items:center;
  background:var(--leaf); color:#fff; font-family:var(--font-d); font-weight:600; box-shadow:0 3px 8px rgba(0,0,0,.25)}
.marker-cluster span{line-height:1}

/* ── Feldbuch ── */
#journal-body{margin-top:6px}
.grid{display:grid; grid-template-columns:repeat(2,1fr); gap:13px}
.find{background:var(--card); border:2px solid var(--border); border-radius:var(--r); overflow:hidden;
  box-shadow:0 5px 0 var(--border), 0 10px 18px var(--shadow); cursor:pointer; position:relative;
  transition:transform .12s; animation:pop .45s cubic-bezier(.2,.9,.3,1.2) both}
.find:active{transform:scale(.97)}
.find .ph{position:relative; aspect-ratio:1/1; overflow:hidden; background:var(--leaf-pale)}
.find .ph img{width:100%; height:100%; object-fit:cover; display:block}
.find .body{padding:9px 11px 11px}
.find .nm{font-family:var(--font-d); font-weight:600; font-size:.98rem; color:var(--ink); line-height:1.1;
  display:flex; align-items:center; gap:5px}
.find .meta{font-size:.72rem; color:var(--ink-soft); margin-top:3px; display:flex; align-items:center; gap:5px; flex-wrap:wrap}
.badge{position:absolute; top:8px; right:8px; padding:3px 9px; border-radius:999px; font-size:.68rem;
  font-family:var(--font-d); font-weight:600; box-shadow:0 2px 6px rgba(0,0,0,.18)}
.badge.harvest{background:var(--leaf-d); color:#fff}
.badge.open{background:var(--butter); color:#6b4e12}
.no-loc{color:var(--poppy)}

/* Dex-Gruppen */
.dex-group{margin-bottom:18px}
.dex-head{display:flex; align-items:center; gap:9px; margin:0 2px 9px}
.dex-head .e{font-size:1.5rem}
.dex-head b{font-family:var(--font-d); font-size:1.05rem; color:var(--ink)}
.dex-head .cnt{margin-left:auto; background:var(--leaf-pale); color:var(--leaf-d); font-family:var(--font-d);
  font-weight:600; font-size:.78rem; padding:3px 11px; border-radius:999px; border:2px solid #cfe3ac}

.empty{text-align:center; color:var(--ink-faint); font-size:1rem; padding:48px 20px; line-height:1.6}

/* ── Tabbar ── */
.tabbar{position:fixed; left:0; right:0; bottom:0; z-index:30; height:calc(var(--tab-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom); display:flex; background:rgba(255,253,246,.92);
  backdrop-filter:blur(12px); border-top:2px solid var(--border); box-shadow:0 -6px 18px var(--shadow)}
.tab{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
  background:none; border:none; cursor:pointer; color:var(--ink-soft); font-family:var(--font-d);
  font-weight:600; font-size:.74rem; padding-top:8px; transition:.15s}
.tab .ti{font-size:1.5rem; transition:transform .2s; filter:grayscale(.5) opacity(.7)}
.tab.active{color:var(--leaf-d)}
.tab.active .ti{transform:translateY(-3px) scale(1.18); filter:none}
.tab.active::before{content:""; position:absolute; top:0; width:44px; height:4px; border-radius:0 0 6px 6px; background:var(--leaf)}

/* ── Sheet ── */
.sheet-wrap,.modal-wrap{position:fixed; inset:0; z-index:50; display:flex}
.sheet-backdrop,.modal-backdrop{position:absolute; inset:0; background:rgba(74,64,40,.42); backdrop-filter:blur(3px); animation:fade .25s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet-wrap{align-items:flex-end}
.sheet{position:relative; width:100%; max-width:680px; margin:0 auto; max-height:92dvh;
  background:var(--paper); border-radius:28px 28px 0 0; border:2px solid var(--border); border-bottom:none;
  box-shadow:0 -10px 40px rgba(74,64,40,.3); display:flex; flex-direction:column;
  animation:sheetUp .38s cubic-bezier(.2,.85,.25,1)}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:none}}
.sheet-grip{width:44px; height:5px; border-radius:3px; background:var(--border-d); margin:10px auto 0}
.sheet-head{display:flex; align-items:center; justify-content:space-between; padding:6px 20px 8px}
.sheet-head h2{font-family:var(--font-d); font-weight:600; font-size:1.3rem; margin:0; color:var(--ink)}
.sheet-body{overflow-y:auto; padding:6px 20px 14px; -webkit-overflow-scrolling:touch}
.sheet-foot{padding:12px 20px calc(14px + env(safe-area-inset-bottom)); border-top:2px solid var(--border); background:var(--card)}
.sheet-foot .btn{width:100%}
.x{background:var(--card); border:2px solid var(--border); width:36px; height:36px; border-radius:50%;
  font-size:1rem; color:var(--ink-soft); cursor:pointer; line-height:1}
.x.floating{position:absolute; top:12px; right:12px; z-index:5; box-shadow:0 3px 8px var(--shadow)}

/* Specimen-Foto mit Washi-Tape */
.specimen{position:relative; margin:4px auto 14px; width:fit-content; max-width:100%; transform:rotate(-1deg)}
.specimen img{display:block; width:100%; max-width:320px; max-height:46dvh; object-fit:cover;
  border-radius:10px; border:6px solid #fff; box-shadow:0 8px 20px var(--shadow-d)}
.tape{position:absolute; width:74px; height:26px; background:rgba(243,195,76,.55); top:-10px; z-index:2;
  box-shadow:0 2px 5px rgba(0,0,0,.12)}
.tape-l{left:14px; transform:rotate(-8deg)} .tape-r{right:14px; transform:rotate(7deg); background:rgba(239,155,189,.5)}
.queue-badge{position:absolute; bottom:8px; right:8px; background:var(--ink); color:#fff; font-family:var(--font-d);
  font-weight:600; font-size:.78rem; padding:4px 11px; border-radius:999px; z-index:3; transform:rotate(1deg)}

.loc-row{display:flex; align-items:center; gap:9px; padding:10px 13px; background:var(--leaf-pale);
  border:2px solid #cfe3ac; border-radius:14px; font-size:.86rem; font-weight:700; color:var(--leaf-d); margin-bottom:14px}
.loc-row .dot{width:9px; height:9px; border-radius:50%; background:var(--leaf)}
.loc-row.warn{background:#fdeee9; border-color:#f4c4b8; color:var(--poppy)}
.loc-row.warn .dot{background:var(--poppy)}

.fld-label{display:block; font-family:var(--font-d); font-weight:600; font-size:.92rem; color:var(--ink); margin:4px 0 8px}
.species-search{display:flex; gap:8px; margin-bottom:10px}
.species-search input,.custom-species input,#sheet-notes,#species-custom{
  width:100%; font-family:var(--font-b); font-size:1rem; color:var(--ink);
  background:#fff; border:2px solid var(--border); border-radius:14px; padding:11px 14px; outline:none; transition:.15s}
.species-search input:focus,.custom-species input:focus,#sheet-notes:focus{border-color:var(--leaf); box-shadow:0 0 0 4px var(--leaf-pale)}
#sheet-notes{resize:vertical; line-height:1.4}
.custom-species{margin:10px 0 4px}

.chips{display:flex; flex-wrap:wrap; gap:8px; max-height:172px; overflow-y:auto; padding:2px; margin-bottom:4px}
.chip{display:inline-flex; align-items:center; gap:6px; padding:8px 13px; border-radius:999px; cursor:pointer;
  font-family:var(--font-d); font-weight:500; font-size:.88rem; color:var(--ink); background:#fff;
  border:2px solid var(--border); transition:transform .1s,.15s}
.chip .sw{width:12px; height:12px; border-radius:50%; box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.1)}
.chip:active{transform:scale(.94)}
.chip.sel{color:#fff; border-color:transparent; box-shadow:0 3px 8px var(--shadow)}

/* ── Detail-Modal ── */
.modal-wrap{align-items:center; justify-content:center; padding:16px}
.modal{position:relative; width:100%; max-width:520px; max-height:90dvh; overflow-y:auto;
  background:var(--paper); border:2px solid var(--border); border-radius:26px;
  box-shadow:0 20px 50px rgba(74,64,40,.4); animation:pop .35s cubic-bezier(.2,.9,.3,1.15)}
.detail-hero{position:relative}
.detail-hero img{width:100%; max-height:48dvh; object-fit:cover; display:block; background:var(--leaf-pale)}
.detail-hero .veil{position:absolute; inset:auto 0 0 0; height:70px; background:linear-gradient(transparent,var(--paper))}
.detail-main{position:relative; z-index:2; margin-top:-22px; padding:18px 20px 20px; background:var(--paper); border-radius:22px 22px 0 0}
.detail-title{font-family:var(--font-d); font-weight:700; font-size:1.6rem; color:var(--ink); margin:0; display:flex; align-items:center; gap:8px}
.detail-sci{font-style:italic; color:var(--ink-soft); font-size:.92rem; margin:2px 0 0}
.info-grid{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:16px 0}
.info{background:var(--card); border:2px solid var(--border); border-radius:14px; padding:10px 12px}
.info .k{font-size:.68rem; text-transform:uppercase; letter-spacing:.5px; color:var(--ink-faint); font-weight:800}
.info .v{font-family:var(--font-d); font-weight:500; font-size:.96rem; color:var(--ink); margin-top:2px}
.info.full{grid-column:1/-1}
.seed-pill{display:inline-flex; align-items:center; gap:6px; background:var(--butter); color:#6b4e12;
  font-family:var(--font-d); font-weight:600; padding:3px 11px; border-radius:999px; font-size:.82rem}
.detail-mini-map{height:150px; border-radius:14px; border:2px solid var(--border); overflow:hidden; margin:4px 0 14px}
.detail-actions{display:flex; flex-wrap:wrap; gap:9px}
.detail-actions .btn{flex:1 1 auto}
.detail-note{background:var(--card-2); border:2px dashed var(--border-d); border-radius:14px; padding:11px 13px;
  font-size:.92rem; color:var(--ink); margin:4px 0 14px; line-height:1.45}
.detail-note::before{content:"✎ "; color:var(--ink-faint)}

/* ── Bloom + Toast ── */
/* per ID, damit die Klasse "bloom" nicht mit den Timeline-Blütezellen (.ym.bloom) kollidiert */
#bloom{position:fixed; inset:0; z-index:80; pointer-events:none; display:grid; place-items:center}
#bloom .big-flower{font-size:5rem; animation:bloomIn 1s cubic-bezier(.2,1.3,.4,1) forwards}
@keyframes bloomIn{0%{transform:scale(0) rotate(-120deg); opacity:0}45%{transform:scale(1.25) rotate(10deg); opacity:1}70%{transform:scale(1) rotate(0)}100%{transform:scale(1.1); opacity:0}}
.petal-burst{position:absolute; font-size:1.5rem; animation:burst .95s ease-out forwards}
@keyframes burst{0%{transform:translate(0,0) scale(.4); opacity:1}100%{transform:translate(var(--tx),var(--ty)) scale(1) rotate(var(--rot)); opacity:0}}

.toast{position:fixed; left:50%; bottom:calc(var(--tab-h) + 22px + env(safe-area-inset-bottom)); transform:translateX(-50%) translateY(20px);
  z-index:90; background:var(--ink); color:#fff; font-family:var(--font-d); font-weight:500; font-size:.95rem;
  padding:12px 20px; border-radius:999px; box-shadow:0 10px 24px rgba(0,0,0,.3); opacity:0; transition:.35s; max-width:90vw; text-align:center}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}

/* loader */
.spinner{display:inline-block; width:16px; height:16px; border:3px solid rgba(255,255,255,.4); border-top-color:#fff; border-radius:50%; animation:spin .7s linear infinite; vertical-align:-3px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ════════════════════════════════════════════════════════════════
   Sammlung · Steckbrief · Erkennung  (Overhaul)
   ════════════════════════════════════════════════════════════════ */

/* Recent-Strip jetzt als <button> */
.recent-strip .rec{background:none; border:none; padding:0; font:inherit; color:inherit; text-align:center}

/* ── Sammlungs-Fortschritt (Sammeln) ── */
.progress-card{display:block; width:100%; text-align:left; font:inherit; color:inherit; cursor:pointer; -webkit-appearance:none; appearance:none}
.progress-card:active{transform:translateY(2px)}
.pc-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:4px}
.pc-count{font-family:var(--font-d); font-weight:600; color:var(--ink-soft); font-size:.95rem}
.pc-count b{font-size:1.5rem; color:var(--leaf-d)}
.pc-bar{height:15px; background:var(--paper-2); border:2px solid var(--border); border-radius:999px; overflow:hidden; margin:6px 0 9px}
.pc-fill{height:100%; min-width:6px; background:linear-gradient(90deg, var(--leaf-l), var(--leaf)); border-radius:999px; transition:width .7s cubic-bezier(.2,.8,.3,1); box-shadow:inset 0 -3px 0 rgba(0,0,0,.08)}
.pc-sub{margin:0; font-size:.86rem; color:var(--ink-soft); font-weight:600}
.ready-txt{color:var(--honey)}

/* ── Rarität (Edelstein-Punkte) ── */
.gems{display:inline-flex; gap:3px; align-items:center}
.gem{display:inline-block; width:9px; height:9px; border-radius:2px; border:1.5px solid var(--border-d); background:var(--card); transform:rotate(45deg)}
.gem.on{background:var(--ink-faint); border-color:var(--ink-faint)}

/* ── Sammlung-Toolbar ── */
.dex-toolbar{display:flex; margin:14px 0 12px}
.dex-toolbar .seg{display:flex; width:100%}
.dex-toolbar .seg-btn{flex:1}
.sub-controls{display:flex; align-items:center; gap:10px; margin:0 0 14px; flex-wrap:wrap}
.pill-input{flex:1 1 160px; font-family:var(--font-b); font-size:.95rem; color:var(--ink); background:#fff;
  border:2px solid var(--border); border-radius:14px; padding:10px 14px; outline:none; transition:.15s}
.pill-input:focus{border-color:var(--leaf); box-shadow:0 0 0 4px var(--leaf-pale)}
.dex-legend{font-size:.78rem; color:var(--ink-soft); font-weight:700}
.dl-count{background:var(--card); border:2px solid var(--border); border-radius:999px; padding:6px 12px; white-space:nowrap}

/* ── Sammlung-Grid (Dex / Critterpedia) ── */
.dex-grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(104px,1fr)); gap:12px}
.dex-card{position:relative; display:flex; flex-direction:column; gap:6px; padding:8px; font:inherit; color:inherit;
  background:var(--card); border:2px solid var(--border); border-bottom-width:5px; border-radius:18px; cursor:pointer;
  box-shadow:0 4px 10px var(--shadow); transition:transform .1s, box-shadow .15s; overflow:hidden; text-align:center;
  animation:pop .4s cubic-bezier(.2,.9,.3,1.2) both}
.dex-card.have:active{transform:translateY(2px); border-bottom-width:3px}
.dc-thumb{position:relative; aspect-ratio:1/1; border-radius:12px; overflow:hidden; background:var(--leaf-pale); display:grid; place-items:center}
.dc-thumb img{width:100%; height:100%; object-fit:cover; display:block}
.dc-em{position:absolute; bottom:3px; right:3px; width:23px; height:23px; border-radius:50%; background:rgba(255,253,246,.92);
  display:grid; place-items:center; font-size:.95rem; box-shadow:0 2px 5px rgba(0,0,0,.2)}
.dc-name{font-family:var(--font-d); font-weight:600; font-size:.84rem; color:var(--ink); line-height:1.05;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.dc-meta{display:flex; align-items:center; justify-content:center; gap:6px; min-height:14px}
.dc-count{font-family:var(--font-d); font-weight:600; font-size:.78rem; color:var(--leaf-d)}
.dc-new{position:absolute; top:6px; left:6px; z-index:2; background:var(--poppy); color:#fff; font-family:var(--font-d);
  font-weight:700; font-size:.58rem; letter-spacing:.5px; padding:2px 6px; border-radius:7px; transform:rotate(-8deg);
  box-shadow:0 2px 5px rgba(0,0,0,.28)}
.dc-ready{position:absolute; top:6px; right:6px; z-index:2; width:25px; height:25px; border-radius:50%; background:var(--butter);
  display:grid; place-items:center; font-size:.95rem; box-shadow:0 2px 5px rgba(0,0,0,.22); animation:bob 2.4s ease-in-out infinite}
.dex-card.lock{border-style:dashed; border-bottom-width:2px; box-shadow:none; cursor:default; opacity:.9}
.dex-card.lock .dc-thumb{background:var(--paper-2)}
.dc-q{font-size:1.9rem; opacity:.4; filter:grayscale(1)}
.dex-card.lock .dc-name{color:var(--ink-faint)}

/* ── Erkennungs-Vorschlag (Sheet) ── */
.fld-head{display:flex; align-items:center; justify-content:space-between; gap:8px; margin:4px 0 8px}
.fld-head .fld-label{margin:0}
.suggest{display:flex; align-items:center; gap:10px; margin:0 0 12px; padding:10px 13px; border-radius:14px;
  border:2px solid var(--border); font-size:.9rem; animation:fade .25s}
.suggest.loading{background:var(--card-2); color:var(--ink-soft)}
.suggest.miss{background:#fdeee9; border-color:#f4c4b8; color:var(--poppy); font-weight:600}
.suggest.ok{background:var(--leaf-pale); border-color:#cfe3ac}
.sg-em{font-size:1.7rem; line-height:1}
.sg-txt{display:flex; flex-direction:column; line-height:1.25}
.sg-txt b{font-family:var(--font-d); font-weight:600; font-size:1.02rem; color:var(--leaf-d)}
.sg-conf{font-style:normal; background:var(--leaf); color:#fff; font-size:.72rem; font-weight:700;
  padding:1px 8px; border-radius:999px; margin-left:5px; vertical-align:1px}
.sg-txt small{color:var(--ink-soft); font-size:.74rem; margin-top:1px}
.spinner.dark{border:3px solid rgba(120,96,46,.22); border-top-color:var(--leaf-d)}

/* ── Steckbrief (Art-Detail) ── */
.sp-hero{position:relative; height:190px; display:grid; place-items:center; overflow:hidden;
  background:var(--leaf-pale);
  background:radial-gradient(circle at 50% 35%, color-mix(in srgb, var(--c) 38%, #fff), var(--leaf-pale))}
.sp-hero img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.sp-hero .veil{position:absolute; inset:auto 0 0 0; height:74px; background:linear-gradient(transparent, var(--paper)); z-index:1}
.sp-emblem{position:relative; z-index:2; font-size:4.4rem; filter:drop-shadow(0 5px 10px rgba(0,0,0,.3))}
.sp-hero.has-img .sp-emblem{position:absolute; top:10px; left:12px; font-size:1.7rem; width:44px; height:44px;
  border-radius:50%; background:rgba(255,253,246,.92); display:grid; place-items:center; box-shadow:0 3px 8px var(--shadow)}

.sp-titlerow{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.sp-rare{display:flex; flex-direction:column; align-items:flex-end; gap:4px; flex:0 0 auto; padding-top:6px}
.rare-lbl{font-family:var(--font-d); font-weight:600; font-size:.74rem; white-space:nowrap}

.steck{margin:14px 0 6px; background:var(--card); border:2px solid var(--border); border-radius:18px; padding:15px 16px}
.st-row{display:flex; align-items:center; justify-content:space-between; gap:10px; min-height:30px}
.st-row.ready{margin:0 -8px; padding:4px 8px; background:linear-gradient(#fbe6b0,#f7d98e); border-radius:12px}
.st-k{display:inline-flex; align-items:center; gap:7px; font-family:var(--font-d); font-weight:600; font-size:.9rem; color:var(--ink-soft)}
.st-ic{font-style:normal; font-size:1.05rem; line-height:1}
.st-v{font-family:var(--font-d); font-weight:600; color:var(--ink); text-align:right}
.st-sep{height:0; border-top:2px dashed var(--border); margin:12px 2px}

.timeline{display:grid; grid-template-columns:repeat(12,1fr); gap:3px; margin:13px 0 2px}
.ym{display:flex; flex-direction:column; align-items:center; gap:4px}
.ym b{display:block; width:100%; height:24px; border-radius:5px; background:var(--paper-2); border:1px solid var(--border)}
.ym.seed b{background-image:repeating-linear-gradient(45deg, transparent 0 3px, rgba(176,120,40,.5) 3px 5px)}
.ym.now b{box-shadow:0 0 0 2px var(--leaf-d)}
.ym span{font-size:.6rem; font-weight:700; color:var(--ink-faint)}
.ym.now span{color:var(--leaf-d); font-weight:800}
.tl-legend{display:flex; gap:14px; flex-wrap:wrap; margin-top:9px; font-size:.72rem; color:var(--ink-soft); font-weight:700}
.tl-legend i.d{display:inline-block; width:11px; height:11px; border-radius:3px; vertical-align:-1px; margin-right:3px; border:1px solid var(--border-d)}
.tl-legend i.d.seed{background-color:var(--paper-2); background-image:repeating-linear-gradient(45deg, transparent 0 2px, rgba(176,120,40,.55) 2px 4px)}
.tl-legend i.d.now{background:var(--leaf-d); border-color:var(--leaf-d)}

.seed-now{font-style:normal; background:var(--honey); color:#5a3c12; font-family:var(--font-d); font-weight:700;
  font-size:.72rem; padding:2px 9px; border-radius:999px; margin-left:7px; white-space:nowrap}
.st-row.ready .seed-now{background:#fff; box-shadow:0 1px 3px rgba(120,96,46,.25)}
.seed-soft{font-style:normal; color:var(--ink-soft); font-size:.74rem; font-weight:700; margin-left:7px}

.hab-row{display:flex; align-items:center; gap:8px; margin-top:0; flex-wrap:wrap}
.habs{display:flex; flex-wrap:wrap; gap:6px}
.hab{background:var(--leaf-pale); border:2px solid #cfe3ac; color:var(--leaf-d); font-family:var(--font-d);
  font-weight:500; font-size:.78rem; padding:4px 11px; border-radius:999px}

.sp-finds-head{display:flex; align-items:center; justify-content:space-between; margin:18px 0 4px}
.sp-finds-head h3{font-family:var(--font-d); font-weight:600; font-size:1.1rem; margin:0; color:var(--ink)}
.sp-finds-head .cnt{background:var(--leaf-pale); color:var(--leaf-d); border:2px solid #cfe3ac; border-radius:999px;
  padding:3px 11px; font-family:var(--font-d); font-weight:600; font-size:.8rem}
.sp-thumbs{display:flex; gap:9px; overflow-x:auto; padding-bottom:4px; margin-top:10px; scroll-snap-type:x mandatory}
.sp-thumbs::-webkit-scrollbar{height:0}
.spt{flex:0 0 auto; width:84px; position:relative; padding:0; border:none; background:none; font:inherit; cursor:pointer; scroll-snap-align:start}
.spt img{width:84px; height:84px; object-fit:cover; border-radius:13px; border:2px solid var(--border); box-shadow:0 3px 7px var(--shadow); display:block}
.spt span{display:block; font-size:.66rem; color:var(--ink-soft); font-weight:700; margin-top:3px; text-align:center}
.spt-done{position:absolute; top:5px; right:5px; width:19px; height:19px; border-radius:50%; background:var(--leaf-d);
  color:#fff; font-style:normal; font-size:.7rem; display:grid; place-items:center; border:2px solid #fff}

@media (min-width:560px){ .grid{grid-template-columns:repeat(3,1fr)} .hero-actions{flex-direction:row} .hero-actions .btn{flex:1}
  .dex-grid{grid-template-columns:repeat(auto-fill, minmax(120px,1fr))} }

/* ════════════════════════════════════════════════════════════════
   Auth · Account · Kategorien · Verbreitung
   ════════════════════════════════════════════════════════════════ */
.auth-wrap{position:fixed; inset:0; z-index:100; display:grid; place-items:center; padding:24px;
  background:radial-gradient(120% 80% at 50% -10%, #fefaef 0%, var(--paper) 45%, var(--paper-2) 100%)}
.auth-card{width:100%; max-width:380px; background:var(--card); border:2px solid var(--border); border-bottom-width:6px;
  border-radius:var(--r-lg); padding:30px 24px 22px; box-shadow:0 16px 38px var(--shadow); text-align:center;
  animation:pop .5s cubic-bezier(.2,.9,.3,1.2) both}
.auth-logo{display:grid; place-items:center; width:88px; height:88px; margin:0 auto 6px; border-radius:50%;
  background:radial-gradient(circle at 38% 32%, #fff, var(--leaf-pale)); box-shadow:0 6px 0 var(--border-d), 0 12px 20px var(--shadow)}
.auth-logo svg{animation:bob 4s ease-in-out infinite}
.auth-title{font-family:var(--font-d); font-weight:700; font-size:2rem; color:var(--leaf-d); margin:8px 0 0; letter-spacing:.3px; text-shadow:0 2px 0 #fff}
.auth-sub{color:var(--ink-soft); font-weight:600; margin:3px 0 18px}
.auth-seg{display:flex; width:100%; margin-bottom:16px}
.auth-seg .seg-btn{flex:1; padding:9px}
#auth-form{display:flex; flex-direction:column; gap:11px; text-align:left}
.auth-field{display:flex; flex-direction:column; gap:5px}
.auth-field span{font-family:var(--font-d); font-weight:600; font-size:.82rem; color:var(--ink-soft); padding-left:4px}
.auth-field input{font-family:var(--font-b); font-size:1rem; color:var(--ink); background:#fff; border:2px solid var(--border); border-radius:14px; padding:12px 14px; outline:none; transition:.15s}
.auth-field input:focus{border-color:var(--leaf); box-shadow:0 0 0 4px var(--leaf-pale)}
.auth-err{margin:0; padding:9px 12px; background:#fdeee9; border:2px solid #f4c4b8; border-radius:12px; color:var(--poppy); font-weight:600; font-size:.85rem}
#auth-submit{width:100%; margin-top:6px}
.auth-hint{color:var(--ink-faint); font-size:.82rem; margin:14px 0 0}

.topbar-right{display:flex; align-items:center; gap:10px}
.acct{position:relative}
.acct-btn{width:42px; height:42px; border-radius:50%; border:2px solid var(--border-d); border-bottom-width:4px;
  background:linear-gradient(#fff,#f4eede); font-family:var(--font-d); font-weight:700; font-size:1.1rem; color:var(--leaf-d);
  cursor:pointer; box-shadow:0 3px 8px var(--shadow); display:grid; place-items:center}
.acct-btn:active{transform:translateY(2px); border-bottom-width:2px}
.acct-menu{position:absolute; right:0; top:50px; z-index:40; background:var(--card); border:2px solid var(--border); border-radius:16px;
  box-shadow:0 10px 24px var(--shadow-d); padding:12px; min-width:172px; display:flex; flex-direction:column; gap:9px; animation:fade .2s}
.acct-name{font-family:var(--font-d); font-weight:600; color:var(--ink); font-size:.9rem; text-align:center; word-break:break-word}

.cat-seg{display:flex; width:100%; margin:14px 0 10px}
.cat-seg .seg-btn{flex:1}
.cat-pick{display:flex; width:100%; margin:4px 0 14px}
.cat-pick .seg-btn{flex:1}

.cat-pill{display:inline-flex; align-items:center; gap:5px; background:var(--leaf-pale); border:2px solid #cfe3ac; color:var(--leaf-d);
  font-family:var(--font-d); font-weight:600; font-size:.78rem; padding:4px 11px; border-radius:999px; white-space:nowrap}
#gbif-map{height:180px}
.gbif-note{font-size:.72rem; color:var(--ink-faint); margin:6px 2px 0; text-align:right}
.map-empty{height:100%; display:grid; place-items:center; color:var(--ink-faint); font-size:.85rem; font-weight:600; background:var(--paper-2)}

/* ── Desktop-Ansicht: Sidebar-Rail links + breiter Inhalt ── */
@media (min-width:900px){
  body{padding-left:240px; padding-bottom:30px}

  /* Tab-Leiste → vertikale, cozy Sidebar */
  .tabbar{flex-direction:column; align-items:stretch; top:0; bottom:0; left:0; right:auto;
    width:240px; height:100dvh; padding:24px 16px calc(env(safe-area-inset-bottom) + 16px);
    border-top:none; border-right:2px solid var(--border); box-shadow:6px 0 22px var(--shadow);
    justify-content:flex-start; gap:6px}
  .tabbar::before{content:"🌼"; font-size:1.9rem; text-align:center; margin:2px 0 18px;
    filter:drop-shadow(0 3px 5px var(--shadow))}
  .tab{flex:0 0 auto; flex-direction:row; justify-content:flex-start; gap:14px;
    padding:14px 16px; border-radius:16px; font-size:1.02rem; transition:background .15s, transform .08s}
  .tab .ti{font-size:1.5rem}
  .tab:hover{background:var(--card-2)}
  .tab.active{background:var(--leaf-pale)}
  .tab.active::before{display:none}
  .tab.active .ti{transform:none}

  .topbar{max-width:1120px; margin:0 auto; padding-top:26px}
  main{max-width:1120px; padding:0 24px 36px}
  .hero-actions{flex-direction:row}
  .dex-grid{grid-template-columns:repeat(auto-fill, minmax(146px,1fr)); gap:16px}
  .grid{grid-template-columns:repeat(auto-fill, minmax(196px,1fr))}

  .modal{max-width:620px}
  .sp-hero{height:230px}
  .detail-hero img{max-height:300px}
}
@media (min-width:1280px){ .topbar, main{max-width:1280px} }

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

/* ── Naturschutz-Hinweise ─────────────────────────────────────── */
.naturschutz-warn{
  display:flex; align-items:center; gap:.6em; flex-wrap:wrap;
  margin:10px 0 14px; padding:12px 14px;
  background:#fdecec; color:#9a1d1d;
  border-left:4px solid #d24a4a; border-radius:12px;
  font-size:.92rem; line-height:1.35;
}
.naturschutz-warn a{color:#7a1212; font-weight:700; text-decoration:underline}
.naturschutz-warn strong{font-weight:700}
.st-disclaimer{
  margin:8px 0 0; padding:9px 12px;
  background:#fff6db; color:#6a4c10;
  border-radius:10px; font-size:.86rem; line-height:1.4;
}
.st-disclaimer a{color:#6a4c10; font-weight:700; text-decoration:underline}
