/* ============ Mander, s'isch Zeit! – Tyrolean Defense 1809 ============ */
@import url('https://fonts.googleapis.com/css2?family=IM+Fell+English:ital@0;1&family=Cinzel:wght@500;700;900&display=swap');

:root{
  --ink:#2c1d0e;
  --ink-soft:#4a3520;
  --paper:#e8d9b8;
  --paper-dark:#d4c096;
  --red:#9b1c1c;
  --red-bright:#c22727;
  --green:#3e5a2e;
  --gold:#c9a227;
  --blue:#2e4a6b;
  --shadow:rgba(20,10,0,.55);
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{width:100%;height:100%;overflow:hidden;background:#120c06}
body{font-family:'IM Fell English',Georgia,serif;color:var(--ink);user-select:none}

#app{position:fixed;inset:0}
.screen{position:absolute;inset:0;display:none;overflow:hidden}
.screen.active{display:block}
.hidden{display:none !important}

/* ---------- Buttons ---------- */
.btn{
  font-family:'IM Fell English',serif;font-size:20px;color:var(--paper);
  background:linear-gradient(180deg,#6b4a26,#4a3115);
  border:2px solid #2c1d0e;border-radius:6px;padding:10px 26px;cursor:pointer;
  box-shadow:0 3px 0 #1d1206,inset 0 1px 0 rgba(255,235,190,.25);
  transition:transform .07s,filter .15s;letter-spacing:.5px;
}
.btn:hover{filter:brightness(1.18)}
.btn:active{transform:translateY(2px);box-shadow:0 1px 0 #1d1206}
.btn:disabled{opacity:.45;cursor:default;filter:grayscale(.6)}
.btn-big{font-size:26px;padding:14px 44px}
.btn-small{font-size:16px;padding:6px 14px}
.btn-primary{background:linear-gradient(180deg,#a82424,#7c1414);border-color:#3d0808}

/* ---------- Loading ---------- */
#screen-loading{background:radial-gradient(ellipse at 50% 35%,#3a2812,#120c06 75%);display:flex}
#screen-loading.active{display:flex;align-items:center;justify-content:center}
.load-box{text-align:center;width:min(560px,86vw)}
.load-title{font-family:'Cinzel',serif;font-size:42px;color:var(--paper);text-shadow:0 3px 12px #000}
.load-sub{color:#b89d6e;margin:10px 0 26px;font-size:19px}
.load-bar{height:18px;border:2px solid #6b4a26;border-radius:9px;background:#1d1206;overflow:hidden}
#load-fill{height:100%;width:0%;background:linear-gradient(90deg,#9b1c1c,#c9a227);transition:width .2s}
.load-info{margin-top:12px;color:#8a734f;font-size:15px;font-style:italic}

/* ---------- Title ---------- */
#screen-title{background:#000}
#title-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:slowzoom 38s ease-in-out infinite alternate}
@keyframes slowzoom{from{transform:scale(1)}to{transform:scale(1.07)}}
.title-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 42%,transparent 38%,rgba(8,4,0,.82) 100%)}
.title-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow-y:auto}
.title-flag{color:var(--gold);font-size:22px;letter-spacing:8px;text-shadow:0 2px 8px #000}
.game-title{
  font-family:'Cinzel',serif;font-weight:900;font-size:clamp(38px,6.5vw,84px);
  color:#f3e6c4;text-shadow:0 4px 0 #5e1010,0 8px 28px rgba(0,0,0,.9);margin:6px 0 2px;
}
.game-subtitle{color:#d8c294;font-size:clamp(15px,1.8vw,23px);font-style:italic;text-shadow:0 2px 8px #000;margin-bottom:40px}
.title-menu{display:flex;flex-direction:column;gap:13px;min-width:280px}
.title-footer{position:absolute;bottom:22px;width:100%;color:#a08a60;font-size:14px;font-style:italic;text-shadow:0 1px 4px #000}

/* Präsentiert-von-Badge (rechts unten) */
.kiwoche-badge{
  position:absolute;right:26px;bottom:20px;z-index:6;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  text-decoration:none;cursor:pointer;
  padding:10px 16px 8px;border-radius:10px;
  background:rgba(10,8,16,.55);border:1px solid rgba(120,140,200,.25);
  transition:transform .15s, background .15s, box-shadow .15s;
}
.kiwoche-badge:hover{transform:scale(1.05);background:rgba(14,12,24,.8);box-shadow:0 6px 24px rgba(60,120,255,.25)}
.kiwoche-badge .kw-label{color:#b8c4e0;font-size:12px;font-style:italic;letter-spacing:1px}
.kiwoche-badge img{width:150px;height:auto;display:block;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}
.kiwoche-badge .kw-url{color:#7fd4e8;font-size:12.5px;letter-spacing:1px}
.kiwoche-badge:hover .kw-url{text-decoration:underline}

/* Impressum (links unten) */
.title-impressum{
  position:absolute;left:26px;bottom:24px;z-index:6;
  color:#a08a60;font-size:14px;font-style:italic;text-decoration:none;
  text-shadow:0 1px 4px #000;border-bottom:1px dotted rgba(160,138,96,.6);
}
.title-impressum:hover{color:#e8d9b8;border-bottom-color:#e8d9b8}

/* ---------- Parchment panels ---------- */
.parchment{
  background:var(--paper-img,linear-gradient(160deg,#ecddbd,#dcc89e));
  background-size:cover;border:3px solid #5e4520;border-radius:10px;
  box-shadow:0 20px 60px rgba(0,0,0,.75),inset 0 0 80px rgba(120,85,30,.25);
}

/* ---------- Campaign map ---------- */
#screen-map{background:#1a1208}
#map-bg{position:absolute;inset:0;background-size:contain;background-repeat:no-repeat;background-position:center;background-color:#15100a;filter:saturate(.95)}
.map-topbar{
  position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;background:linear-gradient(180deg,rgba(20,12,4,.88),rgba(20,12,4,0));z-index:5;
}
.map-topbtns{display:flex;gap:10px}
.res-display{display:flex;gap:18px;font-size:20px;color:var(--paper)}
.res b{color:#ffe9ad}
#map-nodes{position:absolute;z-index:3}
.map-node{
  position:absolute;width:54px;height:54px;margin:-27px 0 0 -27px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#c84b4b,#7c1414);border:3px solid #f3e6c4;
  color:#fff;font-size:20px;font-weight:bold;display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.7);transition:transform .12s;font-family:'Cinzel',serif;
}
.map-node:hover{transform:scale(1.16)}
.map-node.locked{background:radial-gradient(circle at 35% 30%,#6b6b6b,#3a3a3a);border-color:#9a8c6c;cursor:default;filter:saturate(.4)}
.map-node.done{background:radial-gradient(circle at 35% 30%,#4f7a36,#2e4a1e)}
.map-node.bonus{border-radius:14px;background:radial-gradient(circle at 35% 30%,#b08a1e,#7a5c10)}
.map-node .node-stars{position:absolute;bottom:-20px;font-size:13px;white-space:nowrap;text-shadow:0 1px 3px #000;color:#ffd75e}
.map-tooltip{
  position:absolute;z-index:9;background:rgba(24,15,5,.94);color:var(--paper);border:2px solid #6b4a26;
  border-radius:8px;padding:10px 14px;max-width:300px;pointer-events:none;font-size:15px;
}
.map-tooltip b{color:#ffe9ad;font-size:17px}
.map-tooltip .tt-sub{color:#b89d6e;font-style:italic;font-size:13px}

/* ---------- Level intro ---------- */
#screen-intro{display:none;background:rgba(10,6,2,.92)}
#screen-intro.active{display:flex;align-items:center;justify-content:center}
.intro-wrap{width:min(1060px,94vw);max-height:92vh;overflow:auto;padding:30px 38px;color:var(--ink)}
.intro-head{text-align:center;border-bottom:2px solid rgba(90,60,20,.4);padding-bottom:12px;margin-bottom:18px}
.intro-akt{color:var(--red);font-size:15px;letter-spacing:3px;text-transform:uppercase}
#intro-title{font-family:'Cinzel',serif;font-size:34px;margin:4px 0}
.intro-date{font-style:italic;color:var(--ink-soft)}
.intro-cols{display:grid;grid-template-columns:1.25fr 1fr;gap:28px}
.intro-section-label{font-family:'Cinzel',serif;font-size:14px;letter-spacing:2px;color:var(--red);margin:14px 0 6px;text-transform:uppercase}
.intro-left p{font-size:17px;line-height:1.5}
.intro-tip{margin-top:16px;padding:10px 14px;border-left:4px solid var(--gold);background:rgba(201,162,39,.13);font-style:italic;font-size:15px}
#hero-select{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hero-card{
  border:2px solid #6b4a26;border-radius:8px;padding:8px;cursor:pointer;text-align:center;
  background:rgba(255,248,225,.35);transition:all .15s;position:relative;
}
.hero-card:hover{background:rgba(255,248,225,.7)}
.hero-card.selected{border-color:var(--red);box-shadow:0 0 0 2px var(--red);background:rgba(255,235,200,.85)}
.hero-card.locked{opacity:.45;cursor:default;filter:grayscale(.9)}
.hero-card img{width:74px;height:74px;border-radius:50%;object-fit:cover;border:2px solid #5e4520}
.hero-card .hname{font-weight:bold;font-size:15px;margin-top:4px}
.hero-card .hdesc{font-size:12px;color:var(--ink-soft);line-height:1.25;margin-top:3px}
.star-cond{font-size:15px;margin:4px 0}
.intro-actions{display:flex;justify-content:space-between;margin-top:24px}

/* ---------- Game ---------- */
#screen-game{background:#000}
#game-canvas{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);box-shadow:0 0 80px rgba(0,0,0,.9)}

#hud{position:absolute;inset:0;pointer-events:none;z-index:10}
.hud-top{
  position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;
  padding:10px 16px;background:linear-gradient(180deg,rgba(18,10,3,.82),rgba(18,10,3,0));
}
.hud-group{display:flex;gap:14px;align-items:center;pointer-events:auto}
.hud-center{font-family:'Cinzel',serif;color:#e8d9b8;font-size:19px;text-shadow:0 2px 6px #000}
.hud-item{color:#f3e6c4;font-size:21px;text-shadow:0 2px 5px #000}
.hud-item b{color:#ffe9ad}
.hud-btn{
  font-family:inherit;font-size:17px;color:var(--paper);background:rgba(40,26,10,.85);
  border:2px solid #6b4a26;border-radius:6px;padding:6px 12px;cursor:pointer;
}
.hud-btn:hover{background:rgba(70,46,18,.95)}

.hud-bottom{position:absolute;bottom:14px;left:16px;right:16px;display:flex;align-items:flex-end;gap:14px;pointer-events:none}
.ability-btn{
  width:78px;height:78px;border-radius:12px;border:3px solid #c9a227;background:#241608;cursor:pointer;
  position:relative;pointer-events:auto;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.7);
  display:flex;align-items:center;justify-content:center;font-size:34px;
}
.ability-btn img{width:100%;height:100%;object-fit:cover}
.ability-btn.locked{filter:grayscale(1);opacity:.5;cursor:default}
.ability-btn .cd-overlay{
  position:absolute;left:0;right:0;bottom:0;height:0%;background:rgba(0,0,0,.72);transition:height .1s linear;
}
.ability-btn .ability-key{
  position:absolute;top:2px;left:5px;font-size:12px;color:#ffe9ad;background:rgba(0,0,0,.55);
  border-radius:4px;padding:0 5px;font-family:'Cinzel',serif;
}
.ability-btn .uses-badge{
  position:absolute;bottom:2px;right:4px;background:var(--red);color:#fff;border-radius:9px;
  font-size:13px;padding:0 7px;border:1px solid #f3e6c4;
}
.ability-btn.ready{animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 6px 1px rgba(201,162,39,.5)}50%{box-shadow:0 0 18px 5px rgba(201,162,39,.9)}}

.wave-call{margin-left:auto;text-align:right;pointer-events:auto}
.wave-preview{
  margin-top:8px;background:rgba(24,15,5,.9);border:2px solid #6b4a26;border-radius:8px;
  padding:8px 12px;color:var(--paper);font-size:15px;max-width:430px;text-align:left;
}
.wave-preview .wp-title{color:#ffe9ad;font-family:'Cinzel',serif;font-size:13px;letter-spacing:1px}
.wave-preview .wp-units{display:flex;gap:12px;flex-wrap:wrap;margin-top:5px}
.wave-preview .wp-unit{display:flex;align-items:center;gap:5px}
.wave-preview .wp-unit img{width:30px;height:30px;object-fit:contain}

/* Build menu (radial-ish popup) */
.build-menu{
  position:absolute;z-index:20;background:rgba(26,16,6,.96);border:2px solid #8a6a32;border-radius:12px;
  padding:10px;display:grid;grid-template-columns:repeat(3,86px);gap:8px;box-shadow:0 10px 40px rgba(0,0,0,.8);
}
.build-opt{
  border:2px solid #6b4a26;border-radius:9px;background:#33210d;cursor:pointer;padding:5px 4px 4px;
  text-align:center;color:var(--paper);transition:all .12s;position:relative;
}
.build-opt:hover{border-color:var(--gold);background:#4a3115}
.build-opt.cantafford{opacity:.45;cursor:default}
.build-opt img{width:44px;height:44px;object-fit:contain;filter:drop-shadow(0 2px 3px rgba(0,0,0,.6))}
.build-opt .b-name{font-size:11.5px;line-height:1.05;margin-top:2px}
.build-opt .b-cost{font-size:13px;color:#ffd75e}
.build-menu .bm-close{grid-column:1/-1;font-size:13px;color:#b89d6e;text-align:center;cursor:pointer;padding-top:2px}

/* Tower panel */
.tower-panel{
  position:absolute;z-index:20;width:300px;background:rgba(26,16,6,.97);border:2px solid #8a6a32;
  border-radius:12px;padding:12px 14px;color:var(--paper);box-shadow:0 10px 40px rgba(0,0,0,.8);
}
.tower-panel h3{font-family:'Cinzel',serif;font-size:18px;color:#ffe9ad;margin-bottom:2px}
.tower-panel .tp-stats{font-size:14px;color:#cdb88e;margin-bottom:8px;line-height:1.45}
.tp-upgrade{
  border:2px solid #6b4a26;border-radius:8px;padding:7px 9px;margin:7px 0;cursor:pointer;transition:all .12s;
}
.tp-upgrade:hover{border-color:var(--gold);background:rgba(201,162,39,.12)}
.tp-upgrade.cantafford{opacity:.5;cursor:default}
.tp-upgrade .u-name{font-weight:bold;color:#ffe9ad;font-size:15px}
.tp-upgrade .u-desc{font-size:13px;color:#cdb88e;line-height:1.3}
.tp-upgrade .u-cost{float:right;color:#ffd75e}
.tp-owned{border-color:var(--gold);background:rgba(201,162,39,.15);cursor:default}
.tp-row{display:flex;gap:8px;margin-top:10px}
.tp-row .btn{flex:1;font-size:15px;padding:7px 6px}

/* Toast & quotes */
.game-toast{
  position:absolute;top:88px;left:50%;transform:translateX(-50%);z-index:30;background:rgba(24,15,5,.92);
  border:2px solid var(--gold);color:#ffe9ad;border-radius:10px;padding:10px 22px;font-size:18px;
  box-shadow:0 8px 30px rgba(0,0,0,.7);text-align:center;pointer-events:none;max-width:72%;
}
.quote-banner{
  position:absolute;bottom:120px;left:50%;transform:translateX(-50%);z-index:30;max-width:760px;width:86%;
  background:rgba(18,10,3,.93);border:2px solid #8a6a32;border-radius:12px;padding:16px 26px;text-align:center;
  color:#e8d9b8;font-size:19px;font-style:italic;box-shadow:0 10px 40px rgba(0,0,0,.8);pointer-events:none;
}
.quote-banner .q-author{font-size:14px;color:#b89d6e;margin-top:8px;font-style:normal;letter-spacing:1px}

/* Overlays */
.overlay{position:absolute;inset:0;background:rgba(8,4,0,.78);z-index:40;display:flex;align-items:center;justify-content:center}
.overlay-box{padding:36px 48px;text-align:center;display:flex;flex-direction:column;gap:13px;min-width:380px}
.overlay-box h2{font-family:'Cinzel',serif;font-size:32px;margin-bottom:8px}
.result-box{max-width:640px}
.result-stars{font-size:46px;letter-spacing:8px;margin:4px 0;text-shadow:0 3px 8px rgba(120,80,0,.5)}
.result-stars .dim{opacity:.25;filter:grayscale(1)}
#result-text{font-size:17px;line-height:1.5}
.result-rewards{display:flex;gap:26px;justify-content:center;font-size:21px;margin:6px 0}
.result-unlocks{font-size:15px;color:var(--red);font-style:italic}
.result-actions{display:flex;gap:12px;justify-content:center;margin-top:8px}

/* ---------- Meta / Enzyklopädie / Settings ---------- */
#screen-meta,#screen-enzy,#screen-settings{background:radial-gradient(ellipse at 50% 30%,#33210d,#120c06 80%)}
#screen-meta.active,#screen-enzy.active,#screen-settings.active{display:flex;align-items:center;justify-content:center}
.meta-wrap,.enzy-wrap,.settings-wrap{width:min(1080px,94vw);max-height:92vh;overflow:auto;padding:26px 34px}
.meta-head{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid rgba(90,60,20,.4);padding-bottom:10px;margin-bottom:16px}
.meta-head h2{font-family:'Cinzel',serif;font-size:28px}
.meta-cols{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.meta-col h3{font-family:'Cinzel',serif;font-size:19px;margin-bottom:10px}
.meta-cur{font-size:13px;color:var(--ink-soft);font-family:'IM Fell English',serif}
.meta-item{
  border:2px solid #6b4a26;border-radius:9px;padding:10px 13px;margin-bottom:10px;background:rgba(255,248,225,.35);
}
.meta-item .m-title{font-weight:bold;font-size:16.5px}
.meta-item .m-desc{font-size:13.5px;color:var(--ink-soft);margin:2px 0 7px;line-height:1.3}
.meta-item .m-row{display:flex;align-items:center;justify-content:space-between}
.meta-item .m-pips{letter-spacing:3px;font-size:15px}
.meta-item .pip{color:#b3a075}
.meta-item .pip.on{color:var(--red)}
.meta-item button{font-size:14.5px;padding:5px 14px}
.meta-item.maxed{border-color:var(--gold);background:rgba(201,162,39,.18)}

.enzy-tabs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.enzy-tab{
  font-size:15px;padding:6px 16px;border:2px solid #6b4a26;border-radius:20px;cursor:pointer;background:rgba(255,248,225,.3);
}
.enzy-tab.active{background:var(--red);color:#fff;border-color:#5e1010}
.enzy-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}
.enzy-item{
  border:2px solid #6b4a26;border-radius:9px;padding:10px 13px;cursor:pointer;background:rgba(255,248,225,.4);transition:all .12s;
}
.enzy-item:hover{background:rgba(255,248,225,.75)}
.enzy-item.locked{opacity:.5;cursor:default;font-style:italic}
.enzy-item .e-title{font-weight:bold;font-size:15.5px}
.enzy-item .e-cat{font-size:12px;color:var(--red);letter-spacing:1px;text-transform:uppercase}
.enzy-detail{margin-top:14px;border-top:2px solid rgba(90,60,20,.4);padding-top:14px}
.enzy-detail h3{font-family:'Cinzel',serif;font-size:22px;margin-bottom:6px}
.enzy-detail p{font-size:16px;line-height:1.55}
.enzy-count{font-size:15px;color:var(--ink-soft)}

.setting-row{display:flex;align-items:center;justify-content:space-between;padding:13px 4px;border-bottom:1px solid rgba(90,60,20,.3);font-size:18px}
.setting-row input[type=range]{width:260px;accent-color:var(--red)}
.setting-row select{font-family:inherit;font-size:16px;padding:4px 8px;background:var(--paper);border:2px solid #6b4a26;border-radius:6px;color:var(--ink)}
.setting-row.danger label{color:var(--red)}

/* Damage flash */
.flash-red{animation:flashred .45s}
@keyframes flashred{0%{box-shadow:inset 0 0 120px 40px rgba(155,28,28,.85)}100%{box-shadow:none}}

@media (max-width:760px){
  .intro-cols,.meta-cols{grid-template-columns:1fr}
  .build-menu{grid-template-columns:repeat(3,76px)}
}

/* ============ 3D-Zusätze ============ */
#game-3d{position:absolute;inset:0}
#game-3d canvas{display:block}
#overlay3d{position:absolute;inset:0;pointer-events:none;z-index:5;overflow:hidden}
.f3d{
  position:absolute;left:0;top:0;font-family:'IM Fell English',serif;font-weight:bold;
  text-shadow:0 1px 3px rgba(20,12,4,.9), 0 0 2px rgba(20,12,4,.9);
  white-space:nowrap;transform:translate(-50%,-50%);will-change:transform,opacity;
}
.hb3d{
  position:absolute;left:0;top:0;width:44px;height:5px;background:rgba(0,0,0,.55);
  border:1px solid rgba(20,12,4,.8);transform:translate(-50%,-50%);will-change:transform;
}
.hb3d>i{display:block;height:100%;background:#7cb551}
.hb3d.mid>i{background:#d8b13c}
.hb3d.low>i{background:#c0392b}
.hb3d .st{position:absolute;left:50%;top:-15px;transform:translateX(-50%);font-size:11px;line-height:1}
.zoom-hint{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);color:#cdb88e;font-size:13px;
  text-shadow:0 1px 4px #000;pointer-events:none;opacity:.8;font-style:italic;
}


/* ============ Mobile-Optimierung ============ */
/* Querformat-Hinweis: nur auf kleinen Geräten im Hochformat */
#rotate-overlay{
  display:none;position:fixed;inset:0;z-index:9999;
  background:radial-gradient(ellipse at 50% 40%,#3a2812,#120c06 75%);
  align-items:center;justify-content:center;text-align:center;
}
#rotate-overlay .ro-box{color:var(--paper);padding:30px}
#rotate-overlay .ro-icon{font-size:64px;animation:ro-rotate 1.8s ease-in-out infinite}
#rotate-overlay .ro-text{font-size:21px;margin-top:18px;font-style:italic}
@keyframes ro-rotate{0%,20%{transform:rotate(0)}60%,100%{transform:rotate(90deg)}}
@media (orientation: portrait) and (max-width: 920px){
  #rotate-overlay{display:flex}
}

/* Safari-/Browser-Hinweis am Titel */
.browser-hint{
  margin-top:14px;max-width:520px;font-size:14px;line-height:1.4;
  color:#ffd0a0;background:rgba(120,30,20,.75);border:1px solid rgba(255,160,90,.45);
  border-radius:8px;padding:8px 16px;text-shadow:none;
}

/* Kompaktes HUD auf flachen (mobilen Quer-)Screens */
@media (max-height: 540px){
  .hud-item{font-size:17px}
  .hud-center{font-size:15px}
  .hud-btn{font-size:14px;padding:4px 9px}
  .hud-top{padding:6px 10px}
  .ability-btn{width:62px;height:62px;font-size:26px}
  .ability-btn .ability-key{font-size:10px}
  .hud-bottom{bottom:8px;left:10px;right:10px}
  .wave-preview{font-size:13px;max-width:330px;padding:6px 9px}
  .wave-preview .wp-unit img{width:24px;height:24px}
  .btn-big{font-size:21px;padding:10px 30px}
  .overlay-box{padding:22px 26px;min-width:300px;gap:9px}
  .overlay-box h2{font-size:24px}
  .result-stars{font-size:34px}
  .intro-wrap{padding:18px 22px}
  #intro-title{font-size:25px}
  .intro-left p{font-size:14px}
  .hero-card img{width:54px;height:54px}
  .game-title{margin-top:-10px}
  .title-menu{gap:8px}
  .btn{font-size:17px;padding:8px 20px}
  .tower-panel{width:264px;font-size:14px}
  .build-menu{grid-template-columns:repeat(3,72px);gap:6px}
  .build-opt img{width:36px;height:36px}
  .quote-banner{font-size:15px;padding:10px 16px;bottom:90px}
}
/* Touch-Geräte: größere Klickflächen, kein Hover-Zoom nötig */
@media (pointer: coarse){
  #game-canvas,#game-3d{touch-action:none}
  .tp-upgrade{padding:10px 11px}
  .map-node{width:60px;height:60px;margin:-30px 0 0 -30px}
}


/* ============ Install-Banner & kompakter Titelscreen (mobil) ============ */
.install-banner{
  display:none;margin:2px 0 14px;max-width:480px;text-align:center;
  font-family:'IM Fell English',serif;font-size:16px;line-height:1.35;color:#1d1206;
  background:linear-gradient(180deg,#ffd75e,#c9a227);border:1px solid #8a6a1e;border-radius:8px;
  padding:9px 18px;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.5);
}
.install-banner.show{display:block}
.install-banner.ios{cursor:default}
.install-banner:not(.ios):hover{filter:brightness(1.08)}

@media (max-height: 720px){
  .title-content{justify-content:flex-start;padding:10px 12px 64px;overflow-y:auto}
  .game-title{font-size:clamp(24px,6vh + 12px,44px)}
  .game-subtitle{margin-bottom:12px;font-size:13px}
  .title-flag{font-size:13px;letter-spacing:5px}
  .title-menu{
    display:grid;grid-template-columns:repeat(2,minmax(150px,210px));
    gap:8px;min-width:0;
  }
  .title-menu .btn{font-size:15px;padding:8px 8px}
  .title-menu .btn-big{grid-column:1 / -1;font-size:18px;padding:9px 12px}
  .title-footer{display:none}
  .browser-hint{margin-top:8px;font-size:12px;padding:6px 10px;max-width:440px}
  .install-banner{font-size:14px;padding:7px 12px;margin:0 0 10px}
  .kiwoche-badge{right:8px;bottom:6px;padding:5px 9px 4px;gap:1px}
  .kiwoche-badge img{width:88px}
  .kiwoche-badge .kw-label{font-size:8.5px}
  .kiwoche-badge .kw-url{font-size:9px}
  .title-impressum{left:10px;bottom:8px;font-size:11.5px}
}


/* ============ Sprachwahl im Spiel (Titelscreen) ============ */
.game-langbar{position:absolute;top:12px;right:14px;z-index:7;display:flex;gap:7px}
.game-langbar button{
  width:32px;height:22px;padding:0;border:2px solid rgba(200,165,90,.4);border-radius:4px;
  overflow:hidden;background:#000;cursor:pointer;opacity:.55;transition:all .2s;line-height:0;
}
.game-langbar button svg{width:100%;height:100%;display:block}
.game-langbar button:hover{opacity:.9}
.game-langbar button.active{opacity:1;border-color:#c9a227;box-shadow:0 0 10px rgba(201,162,39,.6)}
@media (max-width:700px){ .game-langbar{top:8px;right:8px;gap:5px} .game-langbar button{width:28px;height:19px} }

/* Hochformat-Politur: Footer nicht unter dem Badge */
@media (orientation: portrait) and (max-width:700px){
  .title-footer{font-size:11.5px;padding:0 96px 0 76px;bottom:10px}
}


/* ============ Versions-Wechsel-Link (über dem Impressum) ============ */
.title-switch{
  position:absolute;left:26px;bottom:54px;z-index:6;
  color:#ffd75e;font-size:16px;text-decoration:none;font-style:italic;
  text-shadow:0 1px 4px #000;border-bottom:1px dotted rgba(255,215,94,.6);
}
.title-switch:hover{color:#ffe9ad;border-bottom-color:#ffe9ad}
@media (max-height: 720px){
  .title-switch{left:10px;bottom:32px;font-size:13px}
}


/* ============ Kompakte Intro-Navigation (Pfeile) ============ */
.intro-nav{
  position:absolute;top:14px;z-index:25;width:54px;height:54px;border-radius:50%;
  font-family:'Cinzel',serif;font-size:32px;line-height:1;color:var(--paper);
  background:linear-gradient(180deg,#6b4a26,#4a3115);border:2px solid #2c1d0e;cursor:pointer;
  box-shadow:0 3px 0 #1d1206, 0 4px 14px rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center;padding:0 0 4px;
  transition:transform .1s,filter .15s;
}
.intro-nav:hover{filter:brightness(1.18)}
.intro-nav:active{transform:translateY(2px)}
.intro-nav-back{left:14px}
.intro-nav-go{right:14px;background:linear-gradient(180deg,#a82424,#7c1414);border-color:#3d0808}
@media (max-height:720px){
  .intro-nav{width:46px;height:46px;font-size:27px;top:10px}
  .intro-nav-back{left:10px}
  .intro-nav-go{right:10px}
}


/* ============ Tastatur-Hinweis (erster Start) ============ */
.keys-hint{
  position:absolute;top:70px;left:50%;transform:translateX(-50%);z-index:35;
  background:rgba(20,12,4,.92);border:2px solid #8a6a32;border-radius:12px;
  padding:14px 22px;display:flex;flex-direction:column;gap:10px;align-items:center;
  pointer-events:none;opacity:1;transition:opacity 1.2s ease;
  box-shadow:0 10px 40px rgba(0,0,0,.7);
}
.keys-hint.fade{opacity:0}
.kh-row{display:flex;align-items:center;gap:6px;color:#e8d9b8;font-size:15px}
.kh-label{margin:0 8px 0 6px}
.kh-sep{color:#8a734f;margin:0 4px}
.key{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:26px;height:26px;padding:0 6px;border-radius:5px;
  background:linear-gradient(180deg,#4a3115,#33210d);border:1px solid #8a6a32;
  border-bottom-width:3px;color:#ffe9ad;font-family:'Cinzel',serif;font-size:13px;
}
.key-wide{padding:0 10px}
@media (max-height:720px){ .keys-hint{top:54px;padding:10px 16px;gap:7px} .kh-row{font-size:13px} .key{min-width:22px;height:22px;font-size:11px} }


/* Freischalt-Button auf der Kampagnenkarte */
.map-unlock{position:absolute;left:16px;bottom:16px;z-index:6}
.map-unlock:disabled{opacity:.55}
@media (max-height:720px){ .map-unlock{left:10px;bottom:10px;font-size:13px;padding:5px 10px} }
