:root{
  --bg:#070911;
  --panel:#111827dd;
  --panel-strong:#151f32;
  --text:#f8fafc;
  --muted:#a8b3c7;
  --line:#27344d;
  --accent:#e63b4a;
  --accent-2:#36d1dc;
  --gold:#ffd166;
  --good:#5eead4;
  --shadow:0 26px 80px rgba(0,0,0,.48);
  --radius:26px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box}
html{min-height:100%;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
body{margin:0;min-height:100%;background:
  radial-gradient(circle at top left,rgba(54,209,220,.18),transparent 32rem),
  radial-gradient(circle at 82% 18%,rgba(230,59,74,.20),transparent 28rem),
  linear-gradient(160deg,#070911 0%,#0a1020 58%,#070911 100%);}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;border:0}
input,textarea,select{width:100%;border:1px solid var(--line);background:#0b1220;color:var(--text);border-radius:18px;padding:13px 14px;outline:none;transition:border .2s,box-shadow .2s,transform .2s}
textarea{resize:vertical;line-height:1.55}
input:focus,textarea:focus,select:focus{border-color:var(--accent-2);box-shadow:0 0 0 4px rgba(54,209,220,.12)}
label{display:grid;gap:8px;color:var(--muted);font-size:.88rem}
code{background:#0d1322;border:1px solid var(--line);padding:.15rem .35rem;border-radius:7px;color:#b4f5ff}
.hidden{display:none!important}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:#8ef4ff;margin:0 0 8px;font-weight:800}
.login-view{min-height:100dvh;display:grid;place-items:center;padding:24px;background:linear-gradient(rgba(7,9,17,.55),rgba(7,9,17,.9)),url('icons/london-pattern.svg') center/cover no-repeat}
.login-card{width:min(440px,100%);background:linear-gradient(180deg,rgba(20,30,48,.90),rgba(9,14,25,.94));border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow);border-radius:32px;padding:34px;backdrop-filter:blur(18px)}
.login-card h1{font-size:clamp(2.2rem,9vw,4rem);line-height:.92;margin:8px 0 14px;letter-spacing:-.07em}
.login-card p{color:var(--muted);line-height:1.6}
.brand-mark{width:96px;height:96px;border-radius:28px;display:grid;place-items:center;background:#0c1321;border:1px solid var(--line);box-shadow:0 16px 38px rgba(0,0,0,.35)}
.brand-mark img,.mini-logo{width:100%;height:100%}
.login-form{display:grid;gap:14px;margin-top:26px}.form-error{min-height:1.2rem;color:#ff8b98;margin:0!important}
.app-shell{min-height:100dvh;padding-bottom:calc(68px + var(--safe-bottom))}
.hero{position:relative;overflow:hidden;padding:18px clamp(16px,4vw,38px) 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,14,25,.18),rgba(7,9,17,.98)),url('icons/london-skyline.svg') right bottom/auto 88% no-repeat;opacity:.9;pointer-events:none}
.topbar,.quick-panel{position:relative;z-index:2}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.identity{display:flex;gap:14px;align-items:center}.mini-logo{width:58px;height:58px;border-radius:18px;box-shadow:0 10px 24px rgba(0,0,0,.34)}
.identity h1{font-size:clamp(2.1rem,7vw,4.8rem);letter-spacing:-.08em;line-height:.9;margin:0}.identity span{color:var(--muted)}
.quick-panel{margin-top:22px;display:grid;gap:14px;grid-template-columns:1fr auto;align-items:end}.trip-row{display:grid;grid-template-columns:auto minmax(160px,360px) auto;align-items:end;gap:10px}.trip-row label{padding-bottom:12px}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:46px;border-radius:999px;padding:0 18px;font-weight:800;letter-spacing:-.01em;transition:transform .18s,filter .18s,border .18s}.btn:hover,.icon-btn:hover,.media-btn:hover,.export-card:hover{transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,var(--accent),#ff7a59);color:#fff;box-shadow:0 16px 30px rgba(230,59,74,.24)}.btn.ghost{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#ecfeff}.btn.small{min-height:40px;padding:0 14px;font-size:.88rem}.icon-btn{width:42px;height:42px;border-radius:15px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:inline-grid;place-items:center;color:#fff}.icon{width:20px;height:20px;flex:0 0 auto;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.icon.fill{fill:currentColor;stroke:none}
.content{width:min(1220px,100%);margin:0 auto;padding:22px clamp(14px,3vw,28px)}.tabbar{position:fixed;z-index:30;left:50%;bottom:calc(10px + var(--safe-bottom));transform:translateX(-50%);width:min(720px,calc(100% - 18px));display:grid;grid-template-columns:repeat(5,1fr);gap:6px;padding:8px;background:rgba(9,14,25,.78);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.11);border-radius:24px;box-shadow:var(--shadow)}
.tab{min-height:50px;border-radius:18px;background:transparent;color:var(--muted);display:grid;place-items:center;gap:1px;font-size:.7rem;font-weight:800}.tab.active{background:linear-gradient(135deg,rgba(230,59,74,.24),rgba(54,209,220,.18));color:#fff}.tab .icon{width:19px;height:19px}.tab-panel{display:none;animation:fade .22s ease}.tab-panel.active{display:block}@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.panel{background:linear-gradient(180deg,rgba(17,24,39,.78),rgba(11,18,32,.88));border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);box-shadow:0 20px 70px rgba(0,0,0,.25);padding:20px;backdrop-filter:blur(18px)}.panel+.panel{margin-top:18px}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.panel-head h2{margin:0;font-size:1.35rem;letter-spacing:-.04em}.stackable{align-items:flex-start}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.stat-card{position:relative;overflow:hidden;padding:20px;border-radius:24px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.11)}.stat-card strong{display:block;font-size:2rem;letter-spacing:-.07em}.stat-card span{color:var(--muted);font-weight:700}.stat-card .icon{position:absolute;right:18px;bottom:16px;width:38px;height:38px;color:rgba(255,255,255,.17)}
.split-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:18px}.calendar-controls{display:flex;align-items:center;gap:8px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.calendar-day,.calendar-name{min-height:58px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:8px;position:relative}.calendar-name{min-height:auto;text-align:center;font-weight:900;color:var(--muted);background:transparent;border:0}.calendar-day{cursor:pointer;text-align:left;color:#fff}.calendar-day.other{opacity:.38}.calendar-day.today{border-color:var(--accent-2);box-shadow:0 0 0 3px rgba(54,209,220,.12)}.calendar-day.has-entry:after{content:"";position:absolute;right:9px;bottom:9px;width:9px;height:9px;border-radius:50%;background:var(--accent)}.calendar-day small{display:block;color:var(--muted);font-size:.7rem;margin-top:6px}.idea-list{display:grid;gap:14px;padding-left:18px;color:var(--muted);line-height:1.65}.idea-list strong{color:#fff}
.editor-panel{margin-bottom:18px}.entry-form{display:grid;gap:16px}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.wide{grid-column:1/-1}.check-row{display:flex;align-items:center;gap:10px;align-self:end;padding:13px 0}.check-row input{width:auto}.rating-box{display:grid;gap:8px;color:var(--muted);font-size:.88rem}.mood-buttons,.rating-buttons{display:flex;flex-wrap:wrap;gap:8px}.pill-choice{min-height:42px;border-radius:999px;padding:0 13px;background:#0b1220;border:1px solid var(--line);color:#dce7f8}.pill-choice.active{border-color:var(--accent-2);background:rgba(54,209,220,.14);color:#fff}.location-tools,.form-actions,.media-actions,.search-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.coord-label{color:var(--muted);font-size:.88rem}.media-actions{padding:12px;border:1px dashed rgba(255,255,255,.18);border-radius:22px;background:rgba(255,255,255,.035)}.media-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;border-radius:18px;padding:0 14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);font-weight:800;color:#fff}.media-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}.button-like{border:1px solid rgba(255,255,255,.12)}.button-like.recording{background:rgba(230,59,74,.22);border-color:rgba(230,59,74,.6)}.recorder-status{min-height:22px;color:#8ef4ff;font-weight:700}.search-row{margin:8px 0 18px}.search-row input{flex:1 1 260px}.entries-list{display:grid;gap:16px}.entry-card{overflow:hidden;border-radius:26px;background:linear-gradient(180deg,rgba(17,24,39,.84),rgba(10,15,27,.92));border:1px solid rgba(255,255,255,.1);box-shadow:0 18px 50px rgba(0,0,0,.22)}.entry-card-body{padding:18px}.entry-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:.84rem;font-weight:800}.entry-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.entry-title h3{font-size:1.3rem;letter-spacing:-.04em;margin:8px 0}.entry-card p{line-height:1.65;color:#dbe7f6;white-space:pre-wrap}.tag-row{display:flex;gap:7px;flex-wrap:wrap}.tag{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);color:#cce9ff;border-radius:999px;padding:5px 9px;font-size:.76rem;font-weight:800}.entry-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.media-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-top:12px}.media-item{position:relative;overflow:hidden;border-radius:18px;background:#080d17;border:1px solid rgba(255,255,255,.08);min-height:120px}.media-item img,.media-item video{display:block;width:100%;height:170px;object-fit:cover}.media-item audio{width:100%;margin:42px 0 22px;padding:0 10px}.media-actions-mini{position:absolute;right:8px;top:8px;display:flex;gap:6px}.media-actions-mini .icon-btn{width:34px;height:34px;border-radius:12px;background:rgba(3,7,18,.68);backdrop-filter:blur(9px)}
.map-panel{min-height:70vh}.map-canvas{width:100%;height:430px;border-radius:24px;background:linear-gradient(145deg,#0b1220,#16233a);border:1px solid rgba(255,255,255,.1);overflow:hidden}.map-fallback{margin-top:12px;padding:16px;border-radius:20px;border:1px solid rgba(54,209,220,.22);background:rgba(54,209,220,.08);line-height:1.6;color:#d8f7ff}.place-list{display:grid;gap:10px;margin-top:14px}.place-card{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px;border-radius:18px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09)}.place-card strong{display:block}.place-card span{display:block;color:var(--muted);font-size:.85rem;margin-top:3px}.place-card a{color:#8ef4ff;text-decoration:none;font-weight:900}.leaflet-container{font-family:inherit}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#101827;color:#f8fafc}.leaflet-popup-content{line-height:1.45}.logbook-pin span{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#36d1dc,#ffb347);box-shadow:0 10px 24px rgba(0,0,0,.38);font-size:20px;transform:translateY(-2px)}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}.empty{padding:22px;border:1px dashed rgba(255,255,255,.16);border-radius:22px;color:var(--muted);line-height:1.6;text-align:center}.export-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.export-card{text-align:left;min-height:150px;padding:18px;border-radius:24px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.11);color:#fff;display:grid;align-content:space-between}.export-card strong{font-size:1.12rem}.export-card span{color:var(--muted);line-height:1.45}.export-card .icon{width:34px;height:34px;color:#8ef4ff}.hint{color:var(--muted);line-height:1.6}.footer{text-align:center;color:#8d98ab;font-size:.82rem;padding:34px 16px 26px}.dialog{border:0;background:transparent;padding:18px}.dialog::backdrop{background:rgba(0,0,0,.72);backdrop-filter:blur(8px)}.dialog-card{width:min(520px,calc(100vw - 30px));display:grid;gap:14px;background:linear-gradient(180deg,#151f32,#0b1220);border:1px solid rgba(255,255,255,.12);border-radius:28px;padding:24px;box-shadow:var(--shadow)}.dialog-card h2{margin:0}.dialog-actions{display:flex;justify-content:flex-end;gap:10px}.toast{position:fixed;z-index:60;left:50%;bottom:calc(86px + var(--safe-bottom));transform:translateX(-50%) translateY(20px);max-width:calc(100% - 30px);padding:13px 16px;border-radius:999px;background:#f8fafc;color:#08101d;font-weight:900;opacity:0;pointer-events:none;transition:.22s;box-shadow:var(--shadow)}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media (max-width:860px){.quick-panel{grid-template-columns:1fr}.hero-actions{justify-content:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr)}.split-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.export-grid{grid-template-columns:1fr}.tab{font-size:.62rem}.tabbar{border-radius:22px}.map-canvas{height:360px}.identity h1{font-size:clamp(2rem,10vw,3.4rem)}}
@media (max-width:540px){.hero{padding-top:14px}.topbar{align-items:center}.identity{align-items:center}.mini-logo{width:48px;height:48px}.identity span{display:none}.trip-row{grid-template-columns:1fr;gap:8px}.trip-row label{padding:0}.stats-grid{grid-template-columns:1fr 1fr}.stat-card{padding:15px}.stat-card strong{font-size:1.6rem}.calendar-grid{gap:5px}.calendar-day{min-height:48px;padding:6px;border-radius:13px}.calendar-day small{display:none}.panel{padding:16px;border-radius:22px}.tabbar{gap:4px;padding:6px}.tab{min-height:48px;border-radius:17px}.content{padding-left:12px;padding-right:12px}.media-item img,.media-item video{height:140px}}
@media print{body{background:#fff;color:#111}.hero,.tabbar,.footer,.entry-actions,.media-actions-mini,.search-row{display:none!important}.app-shell{padding:0}.content{width:100%;padding:0}.tab-panel{display:block!important}.panel,.entry-card{box-shadow:none;border:1px solid #ddd;background:#fff;color:#111}.entry-card p,.hint,.tag,.entry-meta{color:#333}.tab-panel:not(#diaryTab){display:none!important}}

/* Kai Light Theme – freundlich, klar, mobil lesbar */
:root{
  --bg:#f6f1e8;
  --panel:#ffffffee;
  --panel-strong:#fffaf1;
  --text:#182033;
  --muted:#687184;
  --line:#e2d9cb;
  --accent:#d83b4a;
  --accent-2:#147f98;
  --gold:#c9961a;
  --good:#0f8f78;
  --shadow:0 24px 70px rgba(41,32,20,.13);
}
html{background:var(--bg);color:var(--text)}
body{background:
  radial-gradient(circle at top left,rgba(20,127,152,.13),transparent 34rem),
  radial-gradient(circle at 86% 12%,rgba(216,59,74,.12),transparent 30rem),
  linear-gradient(160deg,#fff8ed 0%,#f7efe2 48%,#edf7f8 100%);}
input,textarea,select{background:#fffdf8;color:var(--text);border-color:var(--line);box-shadow:0 1px 0 rgba(255,255,255,.7) inset}
input::placeholder,textarea::placeholder{color:#98a0ad}
input:focus,textarea:focus,select:focus{border-color:var(--accent-2);box-shadow:0 0 0 4px rgba(20,127,152,.13)}
label,.hint,.footer,.tab,.entry-meta,.coord-label,.place-card span,.export-card span,.idea-list,.calendar-name,.entry-card p{color:var(--muted)}
code{background:#fff6e8;border-color:#eadcc9;color:#8a4d00}
.eyebrow{color:#147f98}
.login-view{background:linear-gradient(rgba(255,248,237,.62),rgba(246,241,232,.94)),url('icons/london-pattern.svg') center/cover no-repeat}
.login-card{background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(255,249,239,.96));border:1px solid rgba(130,95,50,.18);box-shadow:var(--shadow)}
.login-card p{color:var(--muted)}
.brand-mark{background:#fff;border-color:#eadfce;box-shadow:0 16px 34px rgba(54,42,26,.12)}
.form-error{color:#bd2336!important}
.hero{border-bottom:1px solid rgba(91,70,43,.13);background:rgba(255,255,255,.35)}
.hero-bg{background:linear-gradient(180deg,rgba(255,251,244,.35),rgba(246,241,232,.88)),url('icons/london-skyline.svg') right bottom/auto 88% no-repeat;opacity:.55}
.identity span{color:#687184}
.mini-logo{box-shadow:0 12px 24px rgba(44,35,22,.14)}
.btn.primary{background:linear-gradient(135deg,#d83b4a,#f08b57);color:#fff;box-shadow:0 15px 28px rgba(216,59,74,.22)}
.btn.ghost,.icon-btn,.media-btn{background:rgba(255,255,255,.74);border:1px solid rgba(126,95,57,.18);color:#243047;box-shadow:0 10px 24px rgba(42,33,20,.07)}
.btn.ghost:hover,.icon-btn:hover,.media-btn:hover{border-color:rgba(20,127,152,.36)}
.tabbar{background:rgba(255,255,255,.84);border:1px solid rgba(126,95,57,.18);box-shadow:0 18px 48px rgba(49,38,24,.18)}
.tab{color:#717b8d}
.tab.active{background:linear-gradient(135deg,rgba(216,59,74,.14),rgba(20,127,152,.15));color:#172033}
.panel{background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,250,241,.90));border:1px solid rgba(126,95,57,.16);box-shadow:var(--shadow)}
.stat-card,.export-card{background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(255,246,231,.82));border:1px solid rgba(126,95,57,.16);color:#182033}
.stat-card .icon{color:rgba(20,127,152,.22)}
.calendar-day,.calendar-name{background:rgba(255,255,255,.7);border-color:rgba(126,95,57,.15)}
.calendar-name{background:transparent}.calendar-day{color:#182033}.calendar-day.today{border-color:#147f98;box-shadow:0 0 0 3px rgba(20,127,152,.14)}.calendar-day.has-entry:after{background:#d83b4a}.idea-list strong{color:#182033}
.pill-choice{background:#fffdf8;border-color:#e2d9cb;color:#303a4f}.pill-choice.active{border-color:#147f98;background:rgba(20,127,152,.13);color:#182033}.media-actions{border-color:rgba(126,95,57,.20);background:rgba(255,255,255,.52)}.button-like.recording{background:rgba(216,59,74,.13);border-color:rgba(216,59,74,.45)}.recorder-status{color:#147f98}
.entry-card{background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(255,250,241,.93));border:1px solid rgba(126,95,57,.16);box-shadow:0 16px 44px rgba(45,36,24,.11)}
.entry-card p{color:#424b5e}.tag{border-color:rgba(126,95,57,.16);background:rgba(20,127,152,.09);color:#236070}.media-item{background:#fffaf2;border-color:rgba(126,95,57,.16)}.media-actions-mini .icon-btn{background:rgba(255,255,255,.82);backdrop-filter:blur(9px)}
.map-canvas{background:linear-gradient(145deg,#fffaf1,#e9f5f6);border-color:rgba(126,95,57,.16)}.map-fallback{border-color:rgba(20,127,152,.25);background:rgba(20,127,152,.08);color:#314153}.place-card{background:rgba(255,255,255,.72);border-color:rgba(126,95,57,.16)}.place-card a{color:#147f98}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fffaf2;color:#182033}.logbook-pin span{background:linear-gradient(135deg,#147f98,#f0b357);box-shadow:0 10px 20px rgba(45,36,24,.22)}
.empty{border-color:rgba(126,95,57,.2);color:#687184}.export-card .icon{color:#147f98}.dialog::backdrop{background:rgba(31,25,18,.34);backdrop-filter:blur(8px)}.dialog-card{background:linear-gradient(180deg,#ffffff,#fff7ea);border:1px solid rgba(126,95,57,.18);box-shadow:var(--shadow)}.toast{background:#182033;color:#fffaf1;box-shadow:var(--shadow)}
@media print{body{background:#fff}.panel,.entry-card{background:#fff;color:#111;border-color:#ddd;box-shadow:none}}
