
:root{
  --bg:#eef6ff;
  --bg2:#dcecff;
  --panel:rgba(255,255,255,.88);
  --panel-strong:rgba(255,255,255,.96);
  --line:#c9ddf5;
  --text:#17324d;
  --muted:#5f7b99;
  --accent:#4f8cff;
  --accent2:#63d7c6;
  --accent3:#ffd780;
  --warn:#c95b5b;
  --shadow:0 18px 42px rgba(69,110,160,.16);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.7), transparent 32%),
    linear-gradient(180deg,rgba(244,250,255,.92),rgba(226,239,255,.96)),
    url('/assets/img/header.png') center top/cover fixed;
}
a{color:var(--accent);text-decoration:none}
a:hover{opacity:.92}
.site-shell{min-height:100vh}

.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:18px 28px;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(201,221,245,.95);
  box-shadow:0 10px 30px rgba(93,128,173,.10);
  position:sticky;top:0;z-index:10
}
.brand-block{display:flex;flex-direction:column;gap:4px}
.brand-name{font-size:30px;font-weight:800;letter-spacing:.2px;color:#23466d}
.brand-tag{color:var(--muted);font-size:13px}
.top-links{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.top-links a{padding:10px 14px;border-radius:12px;font-weight:700;color:#2a4e78}
.top-links a:hover{background:rgba(79,140,255,.10)}
.version-badge{
  display:inline-flex;align-items:center;margin-left:10px;padding:5px 11px;border-radius:999px;
  background:linear-gradient(90deg,rgba(79,140,255,.16),rgba(99,215,198,.18));
  color:#355a84;font-size:.8rem;vertical-align:middle;border:1px solid rgba(79,140,255,.15)
}
.button-link,.btn{
  border:none;border-radius:14px;padding:12px 18px;display:inline-block;cursor:pointer;font-weight:700;
  box-shadow:0 10px 24px rgba(79,140,255,.20)
}
.btn.primary,.button-link{background:linear-gradient(90deg,var(--accent),#77a7ff);color:#fff}
.btn.secondary{background:linear-gradient(90deg,var(--accent2),#7ac8ff);color:#17324d}
.btn.small{padding:9px 12px;border-radius:10px;background:linear-gradient(90deg,var(--accent),#77a7ff);color:#fff}
.ghost{background:transparent!important;border:1px solid rgba(42,78,120,.18);box-shadow:none!important}
.danger{background:linear-gradient(90deg,#ef8d8d,#d75d5d)!important;color:#fff}

.hero{
  min-height:440px;background-size:cover;background-position:center;
  border-bottom:1px solid rgba(201,221,245,.9)
}
.hero-overlay{
  background:linear-gradient(90deg,rgba(244,250,255,.86),rgba(231,243,255,.66));
  padding:52px 40px;min-height:440px;display:flex;flex-direction:column;justify-content:center
}
.hero h1{font-size:52px;line-height:1.08;max-width:900px;margin:0 0 14px;color:#1f4268}
.hero p{font-size:19px;color:#4f6d8f;max-width:860px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:22px 0}
.hero-badges,.city-banner .hero-badges{display:flex;flex-wrap:wrap;gap:10px}
.hero-badges span,.stat-pill{
  padding:10px 14px;background:rgba(255,255,255,.72);border:1px solid rgba(99,215,198,.30);
  border-radius:999px;color:#355a84;box-shadow:0 8px 20px rgba(103,143,192,.10)
}

.section-grid,.dashboard-grid,.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;padding:22px 24px}
.card,.table-card,.hero-panel{
  margin:22px 24px;padding:22px;background:var(--panel);border:1px solid var(--line);
  border-radius:24px;backdrop-filter:blur(8px);box-shadow:var(--shadow)
}
.hero-panel{display:flex;justify-content:space-between;gap:16px;align-items:center}
.compact-card{padding:16px}
.card h1,.card h2,.table-card h2,.hero-panel h2{margin-top:0;color:#23466d}
.feature-list{margin:0;padding-left:20px;line-height:1.8}

.landingVoteGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.landingVoteCard{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(240,247,255,.92));
  border:1px solid var(--line);border-radius:20px;text-align:center;min-height:150px;
  box-shadow:0 14px 28px rgba(97,134,177,.12)
}
.landingVoteCard strong{color:#24496f}
.landingVoteCard span{color:var(--muted)}
.landingVoteCard img{max-width:100%;height:auto;border-radius:8px;background:#fff;padding:4px}

.app-grid{display:grid;grid-template-columns:240px 1fr 260px;gap:18px;padding:18px;align-items:start}
.sidebar{
  position:sticky;top:92px;background:var(--panel-strong);border:1px solid var(--line);
  border-radius:24px;padding:18px;min-height:420px;box-shadow:var(--shadow)
}
.sidebar h3{margin-top:0;color:#23466d}
.sidebar a{
  display:block;padding:11px 13px;margin-bottom:8px;background:rgba(79,140,255,.08);
  color:#25486e;border-radius:14px;border:1px solid rgba(79,140,255,.08);font-weight:700
}
.sidebar a:hover{background:rgba(79,140,255,.16)}
.content{min-height:70vh;padding-bottom:30px}
.content.full{width:100%}
.footer{text-align:center;padding:28px;color:#5f7b99}

.flash{margin:20px 24px;padding:14px 16px;border-radius:16px;box-shadow:0 10px 22px rgba(93,128,173,.10)}
.flash.success{background:rgba(99,215,198,.18);border:1px solid rgba(99,215,198,.35)}
.flash.error{background:rgba(239,141,141,.16);border:1px solid rgba(215,93,93,.35)}

.progress-wrap,.progress{height:18px;background:#e3efff;border-radius:999px;overflow:hidden;margin:14px 0}
.progress-bar,.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--accent2),var(--accent))}
.quick-link{
  display:block;padding:18px;border-radius:18px;background:linear-gradient(135deg,rgba(79,140,255,.14),rgba(99,215,198,.20));
  border:1px solid var(--line);font-weight:700;color:#24496f;box-shadow:0 12px 24px rgba(97,134,177,.10)
}

label{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;color:#355a84;font-weight:700}
input,select,textarea{
  padding:12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.92);color:#17324d;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65)
}
textarea{min-height:120px;width:100%}
input::placeholder,textarea::placeholder{color:#7f9bbc}
table{width:100%;border-collapse:collapse}
th,td{padding:14px;border-bottom:1px solid rgba(159,184,220,.28);text-align:left}
th{color:#456b94}
.inline-form,.admin-user-form,.inline-two,.admin-user-flags,.admin-user-meta,.admin-user-actions,.admin-ban-form,.admin-search-form{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.form-card{max-width:760px}
.stack-form{display:flex;flex-direction:column;gap:10px}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:18px 0}
.stat-card{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(241,247,255,.96));
  border:1px solid rgba(201,221,245,.95);border-radius:20px;padding:18px;box-shadow:0 12px 26px rgba(97,134,177,.10)
}
.stat-card span{display:block;opacity:.8;font-size:.9rem;color:#5f7b99}
.stat-card strong{display:block;font-size:2rem;margin-top:8px;color:#23466d}
.admin-search-form input[type=text]{min-width:280px;flex:1}
.admin-user-card{display:flex;flex-direction:column;gap:14px}
.admin-user-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}
.muted{opacity:.75;color:#6f88a5}.grid-two{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}

.admin-hero{
  background:linear-gradient(135deg,rgba(79,140,255,.16),rgba(99,215,198,.18),rgba(255,215,128,.18));
  border:1px solid rgba(201,221,245,.95)
}
.admin-hero p,.card p{color:#53718f}

@media (max-width:1100px){
  .app-grid{grid-template-columns:1fr}
  .sidebar{position:relative;top:0;min-height:auto}
  .hero h1{font-size:38px}
}


.hero-subgrid{display:grid;grid-template-columns:1.25fr .95fr;gap:18px;padding:0 24px 12px}
.hero-subcard,.mini-panel,.news-card,.tile-card,.welcome-card{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(243,248,255,.95));
  border:1px solid rgba(201,221,245,.96);border-radius:24px;box-shadow:var(--shadow)
}
.hero-subcard{padding:22px}
.hero-subcard h3,.mini-panel h3,.news-card h3,.tile-card h3,.welcome-card h3{margin-top:0;color:#23466d}
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-top:16px}
.kpi-chip{padding:16px;border-radius:18px;background:linear-gradient(135deg,rgba(79,140,255,.12),rgba(99,215,198,.14));border:1px solid rgba(79,140,255,.10)}
.kpi-chip span{display:block;color:#6381a0;font-size:.88rem}
.kpi-chip strong{display:block;font-size:1.35rem;margin-top:8px;color:#23466d}
.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;padding:0 24px 22px}
.tile-card{padding:20px;position:relative;overflow:hidden}
.tile-card p{margin-bottom:0;color:#567493}
.tile-card::after{content:"";position:absolute;right:-20px;top:-20px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(99,215,198,.20),transparent 70%)}
.card-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(79,140,255,.16),rgba(99,215,198,.22));font-size:26px;margin-bottom:12px}
.info-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.info-strip span{padding:9px 12px;border-radius:999px;background:rgba(79,140,255,.08);border:1px solid rgba(79,140,255,.08);color:#44698f;font-weight:700}
.admin-quick-grid .quick-link,.tile-card .btn{margin-top:10px}
.dashboard-shell{display:grid;grid-template-columns:1.25fr .9fr;gap:18px;padding:0 24px 22px}
.dashboard-shell .table-card,.dashboard-shell .welcome-card{margin:0}
.welcome-card{padding:22px}
.welcome-list{margin:0;padding-left:18px;line-height:1.9;color:#557391}
.stat-highlight{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;padding:0 24px 12px}
.stat-highlight .stat-card{margin:0}
.news-card{padding:22px;margin:0 24px 22px}
.news-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.news-item{padding:16px;border-radius:18px;background:rgba(79,140,255,.07);border:1px solid rgba(79,140,255,.09)}
.news-item strong{display:block;color:#24496f;margin-bottom:8px}
.soft-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(201,221,245,.95),transparent);margin:8px 0 18px}
.badge-soft{display:inline-flex;padding:7px 11px;border-radius:999px;background:rgba(99,215,198,.16);color:#305f73;font-weight:700;font-size:.85rem}
.admin-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin:0 24px 18px}
.admin-toolbar .hero-badges span{background:rgba(255,255,255,.9)}
.sidebar a.active-link{background:linear-gradient(90deg,rgba(79,140,255,.18),rgba(99,215,198,.16));border-color:rgba(79,140,255,.18)}
.footer{background:rgba(255,255,255,.5);margin-top:18px;border-top:1px solid rgba(201,221,245,.7)}
@media (max-width:1100px){
  .hero-subgrid,.dashboard-shell{grid-template-columns:1fr}
}


/* v0.1.3 visual upgrade */
body{
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.94), transparent 34%),
    radial-gradient(circle at 85% 15%, rgba(99,215,198,.18), transparent 24%),
    linear-gradient(180deg,#f6fbff,#edf6ff 38%, #e7f1ff 100%),
    url('/assets/img/header.png') center top/cover fixed;
}
.topbar{
  background:rgba(255,255,255,.9);
  box-shadow:0 14px 36px rgba(93,128,173,.12);
}
.sidebar{
  background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(244,250,255,.92));
}
.sidebar a{
  position:relative;
  overflow:hidden;
}
.sidebar a::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--accent),var(--accent2));
  opacity:0;transition:.2s;
}
.sidebar a.active::before,.sidebar a:hover::before{opacity:1}
.hero{
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:'';
  position:absolute;right:-80px;bottom:-80px;width:320px;height:320px;
  background:radial-gradient(circle, rgba(255,255,255,.5), rgba(255,255,255,0));
  pointer-events:none;
}
.hero-overlay{padding:64px 40px}
.hero h1{font-size:56px}
.badge-soft{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:linear-gradient(90deg,rgba(79,140,255,.14),rgba(99,215,198,.22));
  border:1px solid rgba(79,140,255,.12);
  color:#2d527d;font-weight:700;
}
.hero-subgrid,.tile-grid,.city-showcase,.feature-callouts,.admin-focus-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px;padding:0 24px 22px;
}
.hero-subcard,.tile-card,.showcase-card,.callout-card,.mini-panel{
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(247,251,255,.9));
  border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow);
}
.tile-card,.showcase-card,.callout-card{position:relative;overflow:hidden}
.tile-card::after,.showcase-card::after,.callout-card::after{
  content:'';position:absolute;right:-34px;top:-34px;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle, rgba(99,215,198,.18), rgba(99,215,198,0));
}
.card-icon,.showcase-icon{
  width:58px;height:58px;display:grid;place-items:center;border-radius:18px;
  background:linear-gradient(135deg, rgba(79,140,255,.14), rgba(99,215,198,.25));
  font-size:28px;margin-bottom:10px;border:1px solid rgba(79,140,255,.10)
}
.section-title{padding:0 24px;margin:10px 0 16px}
.section-title h2{margin:0 0 6px;color:#23466d}
.section-title p{margin:0;color:var(--muted)}
.metric-band{
  margin:0 24px 22px;padding:14px;background:rgba(255,255,255,.65);border:1px solid var(--line);
  border-radius:22px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;box-shadow:var(--shadow)
}
.metric-band .metric{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.78)}
.metric-band .metric span{display:block;color:var(--muted);font-size:13px;margin-bottom:4px}
.metric-band .metric strong{font-size:24px;color:#23466d}
.dashboard-banner,.admin-banner{
  margin:22px 24px;padding:24px;border-radius:26px;border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(255,255,255,.95), rgba(234,246,255,.95));
  box-shadow:var(--shadow);display:grid;grid-template-columns:2fr 1fr;gap:18px;align-items:center;
}
.dashboard-banner .mini-stats,.admin-banner .mini-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.mini-stat{
  padding:16px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid rgba(201,221,245,.8)
}
.mini-stat span{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
.mini-stat strong{font-size:22px;color:#23466d}
.news-card{
  margin:22px 24px;padding:24px;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(243,249,255,.92));
  border:1px solid var(--line);box-shadow:var(--shadow)
}
.news-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.news-item{padding:18px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid rgba(201,221,245,.85);line-height:1.55}
.news-item strong{display:block;margin-bottom:6px;color:#23466d}
.quick-link{
  display:flex;align-items:center;justify-content:center;min-height:74px;text-align:center;
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(239,248,255,.95));
}
.welcome-list{padding-left:20px;line-height:1.8;margin:0}
.vibe-card{
  display:flex;gap:16px;align-items:flex-start;padding:18px;border-radius:20px;background:rgba(255,255,255,.8);border:1px solid var(--line)
}
.vibe-card .emoji{font-size:28px}
.table-card table tr:hover td{background:rgba(79,140,255,.04)}
@media (max-width: 900px){
  .dashboard-banner,.admin-banner{grid-template-columns:1fr}
  .hero h1{font-size:42px}
}


/* v0.1.6 building menu */
.build-intro-card{background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(239,248,255,.94));}
.build-requirements-strip{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.req-chip{padding:11px 14px;border-radius:999px;background:rgba(79,140,255,.08);border:1px solid rgba(79,140,255,.12);font-weight:700;color:#355a84}
.req-chip.done{background:rgba(99,215,198,.18);border-color:rgba(99,215,198,.32);color:#255d57}
.req-chip.pending{background:rgba(255,215,128,.2);border-color:rgba(255,215,128,.34);color:#8a6718}
.build-category-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;flex-wrap:wrap;margin-bottom:16px}
.build-category-header p{margin:6px 0 0;color:#587796}
.build-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.building-card{background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(242,248,255,.96));border:1px solid rgba(201,221,245,.96);border-radius:24px;overflow:hidden;box-shadow:0 16px 34px rgba(97,134,177,.10);display:flex;flex-direction:column}
.building-card.locked{opacity:.86}
.building-image-wrap{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,rgba(79,140,255,.08),rgba(99,215,198,.14));display:flex;align-items:center;justify-content:center}
.building-image-wrap img{width:100%;height:100%;object-fit:cover}
.building-badge{position:absolute;top:12px;padding:7px 10px;border-radius:999px;font-size:.78rem;font-weight:700;background:rgba(255,255,255,.92);border:1px solid rgba(201,221,245,.95);color:#315679}
.building-badge.mandatory{left:12px;background:linear-gradient(90deg,rgba(255,215,128,.92),rgba(255,244,204,.98));color:#7d5b10}
.building-badge.category{right:12px}
.building-card-body{padding:18px;display:flex;flex-direction:column;gap:12px;flex:1}
.building-card-body h3{margin:0;color:#23466d}
.building-meta{display:flex;flex-wrap:wrap;gap:8px}
.building-meta span{padding:7px 10px;border-radius:999px;background:rgba(79,140,255,.08);border:1px solid rgba(79,140,255,.08);font-size:.86rem;color:#44698f;font-weight:700}
.build-note{margin:0;color:#5f7b99;min-height:22px}
.build-note.warning{color:#b36a14;font-weight:700}
.build-note.success{color:#256d56;font-weight:700}
.btn[disabled]{opacity:.55;cursor:not-allowed;box-shadow:none}


/* v0.1.6 compact building cards */
.build-economy-strip{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}
.build-card-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.build-category-card{padding:16px 16px 18px}
.building-card{border-radius:20px}
.building-image-wrap{aspect-ratio:16/7;max-height:240px}
.building-image-wrap img{object-fit:contain;padding:16px}
.building-card-body{padding:14px 16px 16px;gap:10px}
.building-card-body h3{font-size:1.05rem}
.building-meta span{font-size:.8rem;padding:6px 9px}
@media (min-width: 1350px){.build-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));}}


/* v0.1.7 admin buildings */
.admin-building-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.admin-building-form-grid label{display:flex;flex-direction:column;gap:8px;font-weight:700;color:#355a84}
.admin-building-form-grid input,.admin-building-form-grid select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:#fff;color:#284a70}
.admin-building-form-grid .checkbox-row{flex-direction:row;align-items:center;gap:10px;padding-top:28px}
.admin-building-actions{display:flex;gap:12px;align-items:center;grid-column:1/-1;flex-wrap:wrap}
.admin-image-library{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.admin-image-card{background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(241,247,255,.95));border:1px solid var(--line);border-radius:20px;padding:14px;display:flex;flex-direction:column;gap:8px;box-shadow:0 14px 24px rgba(97,134,177,.08)}
.admin-image-preview{height:110px;border-radius:16px;background:linear-gradient(135deg,rgba(79,140,255,.08),rgba(99,215,198,.14));display:flex;align-items:center;justify-content:center;padding:10px}
.admin-image-preview img{max-width:100%;max-height:100%;object-fit:contain}
.admin-image-card strong{color:#23466d}
.admin-image-card small{color:#708aa5;word-break:break-all}
@media (max-width: 900px){.admin-building-form-grid{grid-template-columns:1fr}}


.admin-building-form-grid .full{grid-column:1/-1;}
.admin-building-form-grid textarea{width:100%;min-height:110px;border:1px solid #cfe0f4;border-radius:16px;padding:12px 14px;background:#fff;color:#244a73;font:inherit;resize:vertical;}
.building-description{margin:10px 0 12px;color:#5b7594;line-height:1.45;min-height:44px;}
.building-card .building-meta{flex-wrap:wrap;}


/* v0.1.9 buildings */
.building-image-wrap.compact{min-height:170px;max-height:170px;padding:18px}
.dependency-chain{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 6px}
.dependency-chip{padding:7px 10px;border-radius:999px;font-size:.82rem;font-weight:700;background:rgba(79,140,255,.10);border:1px solid rgba(79,140,255,.10);color:#32577f}
.dependency-chip.ok{background:rgba(99,215,198,.18);border-color:rgba(99,215,198,.24);color:#2b665c}
.dependency-chip.missing{background:rgba(255,215,128,.24);border-color:rgba(255,215,128,.34);color:#8a6430}
.owned-building-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:18px}
.owned-building-card{padding:18px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(244,249,255,.95));border:1px solid var(--line);box-shadow:0 14px 28px rgba(97,134,177,.10)}
.owned-building-head{display:flex;gap:14px;align-items:center;margin-bottom:10px}
.owned-building-thumb{width:72px;height:72px;border-radius:18px;background:rgba(79,140,255,.08);display:grid;place-items:center;overflow:hidden;flex:0 0 72px}
.owned-building-thumb img{width:48px;height:48px;object-fit:contain}
.building-meta.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}
.build-progress-wrap{height:14px;background:#e6f1ff;border-radius:999px;overflow:hidden;margin-top:12px}
.build-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent2),var(--accent))}
.building-description.small{font-size:.92rem}
.admin-building-preview-box,.admin-building-dependency-box{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center;padding:16px;border:1px solid var(--line);border-radius:20px;background:rgba(79,140,255,.05)}
.admin-building-preview{width:140px;height:140px;border-radius:18px;background:rgba(255,255,255,.9);display:grid;place-items:center;overflow:hidden;border:1px solid var(--line)}
.admin-building-preview img{max-width:80%;max-height:80%;object-fit:contain}
.dependency-selector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:12px}
.dependency-check{display:flex;flex-direction:row;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.86);border:1px solid var(--line);margin:0}
.dependency-check input{margin:0}
@media (max-width:900px){
  .admin-building-preview-box,.admin-building-dependency-box{grid-template-columns:1fr}
  .building-meta.two-col{grid-template-columns:1fr}
}

.city-map-grid{display:grid;gap:14px;margin-top:18px}.city-map-cell{min-height:150px;border:1px solid #d8e5f4;border-radius:22px;background:linear-gradient(180deg,#f9fcff,#eef6ff);padding:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;box-shadow:0 8px 24px rgba(76,119,168,.08)}.city-map-cell.filled img{width:72px;height:72px;object-fit:contain;margin-bottom:10px}.city-map-cell.empty{background:linear-gradient(180deg,#fcfdff,#f5f9ff)}.city-map-coord{position:absolute;top:10px;left:12px;font-size:12px;color:#6b87a7;background:#ffffffcc;padding:4px 8px;border-radius:999px}.owned-building-actions{display:flex;gap:8px;flex-wrap:wrap}@media (max-width: 1100px){.city-map-grid{grid-template-columns:repeat(3,minmax(0,1fr)) !important}}@media (max-width: 720px){.city-map-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important}.city-map-cell{min-height:120px}}

/* v0.2.1 utilities */
.city-overview-grid{margin-bottom:20px}
.utility-bars{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.utility-bar-card{padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.88)}
.utility-bar-card span{display:block;font-size:.86rem;color:#61758d;margin-bottom:8px}
.progress.utility{height:12px;background:#e8f2ff;border-radius:999px;overflow:hidden;margin-bottom:8px}
.progress.utility span{display:block;height:100%;margin:0;background:linear-gradient(90deg,var(--accent2),var(--accent))}
@media (max-width:900px){.utility-bars{grid-template-columns:1fr}}


/* v0.2.5 townhall expansion */
.townhall-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.townhall-actions{max-width:320px;display:flex;flex-direction:column;gap:12px}
.townhall-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:18px;padding:0 24px 22px}
.department-grid,.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.department-card,.project-card,.townhall-project-active{
  padding:18px;border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(242,248,255,.94));
  border:1px solid rgba(201,221,245,.95);box-shadow:0 12px 24px rgba(97,134,177,.10)
}
.department-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}
.department-card h3,.project-card h3{margin:0 0 10px;color:#23466d}
@media (max-width:1100px){
  .townhall-hero{flex-direction:column}
  .townhall-grid{grid-template-columns:1fr}
}


.bank-hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;}
.bank-stats-grid .stat-card strong{font-size:1.35rem;}
.stack-form{display:grid;gap:12px;margin-top:12px;}
.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.compact-form{margin-top:12px;}
.bank-grid-top,.bank-grid-bottom,.bank-admin-grid{align-items:start;}
.bank-hints{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;font-size:.92rem;color:#54718d;}
.bank-transactions{display:grid;gap:10px;}
.bank-transaction-item{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid #d7e6f5;border-radius:14px;background:#f8fbff;}
.align-right{text-align:right;}
.table-wrap{overflow:auto;}
@media (max-width: 960px){.bank-hero{flex-direction:column;}}


.compact-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;}
.housing-card .building-thumb{height:140px;}
.housing-card .building-thumb img{width:100%;height:100%;object-fit:cover;}
.building-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0;}
.building-stats-grid div{background:#f6fbff;border:1px solid #dceffd;border-radius:14px;padding:10px 12px;}
.building-stats-grid span{display:block;font-size:12px;color:#5d7486;}
.building-stats-grid strong{display:block;margin-top:4px;font-size:15px;}
.action-row{display:flex;gap:8px;flex-wrap:wrap;}
.double-buttons form{flex:1;}
.double-buttons .btn{width:100%;}
.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.admin-form-grid label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#355063;}
.admin-form-grid input,.admin-form-grid textarea{padding:11px 12px;border:1px solid #cfe0ec;border-radius:12px;background:#fff;}
.admin-form-grid .full-span{grid-column:1/-1;}
.btn.danger{background:#f8d7da;color:#842029;border:1px solid #f1aeb5;}
@media (max-width: 900px){.admin-form-grid{grid-template-columns:1fr;}}


.company-card .building-thumb img{object-fit:cover;}
.compact-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));}
.kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px;}
.kv-grid small{display:block;color:#6c7a93;}
.kv-grid strong{display:block;font-size:15px;}
.action-row.wrap{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}
.progress-wrap{height:10px;background:#e8eefc;border-radius:999px;overflow:hidden;margin:10px 0;}
.progress-bar{height:100%;background:linear-gradient(90deg,#72a6ff,#86d2ff);border-radius:999px;}
.grid-form.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.grid-form.two-col label{display:flex;flex-direction:column;gap:6px;}
@media (max-width: 820px){.grid-form.two-col{grid-template-columns:1fr;}}


/* v0.3.3 company cards */
.company-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;}
.company-card{overflow:hidden}
.company-card .building-thumb{
  width:100%;
  height:136px;
  border-radius:20px 20px 0 0;
  background:linear-gradient(180deg,#eef6ff,#dfeefe);
  display:block;
  flex:none;
}
.company-card .building-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.company-card .building-content{padding:16px 18px 18px}
.company-card .building-topline{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.company-card .chip{font-size:12px}
.company-card .kv-grid{margin-top:12px}
.company-card .action-row.wrap form{flex:1 1 auto}
.company-card .action-row.wrap .btn.small{width:100%}
@media (max-width: 900px){
  .company-card .building-thumb{height:122px}
}

/* v0.3.4 company improvements */
.company-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.company-card .building-thumb{
  width:100%;
  height:112px;
  border-radius:20px 20px 0 0;
  background:linear-gradient(180deg,#eef6ff,#dfeefe);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px;
}
.company-card .building-thumb img{
  width:auto;
  height:auto;
  max-width:88%;
  max-height:84px;
  object-fit:contain;
  display:block;
}
.company-metrics{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:12px;
}
.company-metric{
  padding:10px 12px;
  border-radius:16px;
  background:rgba(79,140,255,.06);
  border:1px solid rgba(79,140,255,.12);
}
.company-metric small{display:block;color:#6d7d95}
.company-metric strong{display:block;font-size:15px}
.chain-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
@media (max-width: 700px){
  .company-card .building-thumb{height:96px;padding:12px}
  .company-card .building-thumb img{max-height:72px}
  .company-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
}


/* v0.3.5 market improvements */
.market-hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;flex-wrap:wrap}
.market-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin:18px 0}
.sparkline{width:110px;height:40px;color:#4f8cff;display:block}
.sparkline-cell{min-width:120px}
.text-up{color:#1d8f4d;font-weight:700}
.text-down{color:#c84b5e;font-weight:700}
.stack-form{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.dual-list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.leader-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:14px;background:#f5f9ff;margin-bottom:8px}
.form-grid.three-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
@media (max-width: 980px){.market-grid,.dual-list,.form-grid.three-col{grid-template-columns:1fr}}

/* v0.3.6 market extras */
.news-row{display:flex;justify-content:space-between;gap:14px;padding:14px;border-radius:16px;background:#f8fbff;border:1px solid rgba(79,140,255,.14);margin-bottom:12px;align-items:flex-start}.news-row p{margin:6px 0 0}.news-positive{border-left:4px solid #1d8f4d}.news-negative{border-left:4px solid #c84b5e}.news-neutral{border-left:4px solid #6d7d95}


/* v0.4.2 Jobs & Profile */
.jobs-hero-v042,
.profile-hero-v042{
    display:grid;
    grid-template-columns:1.35fr .95fr;
    gap:18px;
    align-items:stretch;
}
.jobs-grid-v042,
.profile-grid-v042{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
}
.job-card-v042,
.profile-card-v042{
    background:#fff;
    border:1px solid rgba(24,89,163,.10);
    border-radius:18px;
    padding:18px;
    box-shadow:0 8px 24px rgba(35,75,130,.06);
    overflow-wrap:anywhere;
    word-break:break-word;
}
.job-card-v042 h3,
.profile-card-v042 h3,
.job-card-v042 p,
.profile-card-v042 p,
.job-card-v042 small,
.profile-card-v042 small,
.job-card-v042 td,
.profile-card-v042 td,
.table-card td,
.table-card th{
    white-space:normal !important;
    overflow-wrap:anywhere;
    word-break:break-word;
}
.job-card-v042 .job-meta-v042,
.profile-meta-v042{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
    margin-top:10px;
}
.job-pill-v042{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:6px 10px;
    border-radius:999px;
    background:#eef6ff;
    border:1px solid rgba(24,89,163,.12);
    font-size:13px;
    color:#285f9f;
    margin:0 8px 8px 0;
}
.profile-banner-v042{
    background:linear-gradient(135deg,#f7fbff 0%, #eef6ff 100%);
    border:1px solid rgba(24,89,163,.08);
    border-radius:22px;
    padding:22px;
    box-shadow:0 8px 24px rgba(35,75,130,.05);
}
.profile-avatar-v042{
    width:86px;
    height:86px;
    border-radius:24px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg,#7eb8ff 0%, #cde5ff 100%);
    color:#12406f;
    font-size:30px;
    font-weight:700;
    box-shadow:0 8px 22px rgba(44,103,180,.16);
}
.table-card{
    overflow-x:auto;
}
.table-card table{
    width:100%;
    table-layout:auto;
}
.table-card td, .table-card th{
    max-width:none;
}
@media (max-width: 980px){
    .jobs-hero-v042,
    .profile-hero-v042,
    .jobs-grid-v042,
    .profile-grid-v042{
        grid-template-columns:1fr;
    }
}


/* v0.4.4 Arbeitsmarkt */
.jobs-board-v044{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:18px;
    margin-top:18px;
}
.jobs-list-v044{
    display:grid;
    gap:16px;
}
.job-card-v044{
    background:#fff;
    border:1px solid rgba(28,92,160,.10);
    border-radius:20px;
    padding:18px;
    box-shadow:0 8px 24px rgba(35,75,130,.06);
}
.job-card-v044 h3,
.job-card-v044 p,
.job-card-v044 td,
.job-card-v044 th{
    overflow-wrap:anywhere;
    word-break:break-word;
    white-space:normal;
}
.job-badges-v044{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin:10px 0 12px;
}
.job-badge-v044{
    display:inline-flex;
    align-items:center;
    padding:6px 10px;
    border-radius:999px;
    background:#eef6ff;
    color:#285f9f;
    border:1px solid rgba(24,89,163,.12);
    font-size:13px;
}
.career-progress-v044{
    height:10px;
    border-radius:999px;
    background:#e8f1fb;
    overflow:hidden;
    margin:8px 0 10px;
}
.career-progress-v044 span{
    display:block;
    height:100%;
    background:linear-gradient(90deg,#70aef9,#c8e2ff);
}
.jobs-sidepanel-v044{
    display:grid;
    gap:16px;
}
.job-mini-grid-v044{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
}
.application-pill-v044{
    display:inline-block;
    padding:6px 10px;
    border-radius:999px;
    background:#fff7e8;
    border:1px solid rgba(186,132,31,.18);
    color:#9a6b15;
    font-size:13px;
}
@media (max-width:980px){
    .jobs-board-v044{grid-template-columns:1fr;}
}
