:root{
  --bg:#f3f6fb;
  --bg-soft:#eef3f9;
  --panel:#ffffff;
  --panel-alt:#f9fbfe;
  --line:#d8e1ec;
  --line-strong:#c4d0df;
  --text:#1f2937;
  --muted:#5f6f84;
  --brand:#2f6fed;
  --brand-dark:#1f57c7;
  --accent:#0f8f6a;
  --warn:#f59e0b;
  --bad:#d33d36;
  --good:#15803d;
  --shadow:0 10px 25px rgba(18,37,63,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,Arial,sans-serif;background:linear-gradient(180deg,#f8fbff 0%,#f2f6fb 100%);color:var(--text);line-height:1.5}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:none;color:var(--brand-dark)}
img{max-width:100%;display:block}
.wrap{max-width:1380px;margin:0 auto;padding:0 18px}
.site-topbar{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.top-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 0}
.logo{display:flex;align-items:center;gap:12px;color:var(--text);font-weight:800;font-size:24px}
.logo-mark{width:42px;height:42px;border:2px solid var(--brand);display:flex;align-items:center;justify-content:center;background:#edf3ff;color:var(--brand);font-size:20px;font-weight:900}
.logo small{display:block;font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.top-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--line);background:#f8fbff;color:var(--muted);font-size:13px}
.layout-grid{display:grid;grid-template-columns:280px minmax(0,1fr);gap:22px;padding:24px 0 30px}
.sidebar{align-self:start;position:sticky;top:84px;background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)}
.sidebar-inner{padding:18px}
.sidebar-profile{padding:14px;border:1px solid var(--line);background:var(--bg-soft);margin-bottom:18px}
.sidebar-profile .name{font-weight:800;margin-bottom:6px}
.balance-mini{display:grid;gap:8px;font-size:13px;color:var(--muted)}
.balance-mini b{color:var(--text);font-size:16px}
.sidebar-section{margin-bottom:18px}
.sidebar-title{margin:0 0 10px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#7a8ba3;font-weight:800}
.sidebar-links{display:grid;gap:8px}
.sidebar-link{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:600}
.sidebar-link:hover{background:#f6f9fe}
.sidebar-link.active{border-color:var(--brand);background:#edf3ff;color:var(--brand)}
.sidebar-note{padding:12px;border:1px dashed var(--line-strong);background:#fafcff;color:var(--muted);font-size:13px}
.main-column{min-width:0}
.footer{border-top:1px solid var(--line);background:#fff;color:var(--muted);padding:22px 0;margin-top:8px}
.hero{margin-bottom:18px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:stretch}
.hero-box,.panel,.card{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow)}
.hero-box{padding:26px}
.hero h1,.hero-box h1{margin:0 0 10px;font-size:40px;line-height:1.08}
.hero p{margin:0 0 12px;color:var(--muted)}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.panel{padding:20px}.card{padding:18px}
.card h2,.card h3,.panel h2,.panel h3{margin-top:0}
.card-title-row{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px}
.card-media{height:180px;border:1px solid var(--line);background:#f4f7fb;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:14px}
.card-media img{width:100%;height:100%;object-fit:cover}
.placeholder-media{font-size:54px;color:#95a5bd;font-weight:800}
.feature-card{display:grid;gap:10px}
.feature-icon{width:46px;height:46px;border:1px solid var(--line);background:#eef4ff;color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.kpi{padding:16px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.kpi-label{font-size:13px;color:var(--muted);margin-bottom:8px}
.stat{font-size:30px;font-weight:800;color:var(--text);line-height:1.1}
.muted{color:var(--muted)}
.small{font-size:13px}
.badge{display:inline-block;padding:4px 8px;border:1px solid var(--line);background:#f8fbff;color:#4c5d76;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.badge.good{color:#166534;border-color:#b7dfc6;background:#eefbf1}.badge.warn{color:#9a6700;border-color:#eed39d;background:#fff7e5}.badge.bad{color:#9f1d1d;border-color:#efb0b0;background:#fff1f1}
.btn,.button,button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 15px;border:1px solid var(--brand);background:var(--brand);color:#fff;font-weight:700;cursor:pointer;transition:.18s ease;box-shadow:none;border-radius:0}
.btn:hover,.button:hover,button:hover{background:var(--brand-dark);border-color:var(--brand-dark);color:#fff}
.btn.secondary,button.secondary{background:#fff;border-color:var(--line-strong);color:var(--text)}
.btn.secondary:hover,button.secondary:hover{background:#f5f8fc;border-color:#b9c8da;color:var(--text)}
.btn.good,button.good{background:var(--good);border-color:var(--good)}
.btn.good:hover,button.good:hover{background:#166534;border-color:#166534}
.btn.danger,button.danger{background:var(--bad);border-color:var(--bad)}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap}
.alert{padding:14px 16px;border:1px solid var(--line);margin:0 0 16px}.alert.success{background:#edf9f0;border-color:#badfc3}.alert.error{background:#fff3f3;border-color:#efb7b7}.alert.warn{background:#fff7e7;border-color:#f1d39b}
form{margin:0}.form-row{display:grid;gap:6px;margin-bottom:14px}label{font-size:14px;font-weight:700;color:#334155}.check-row{display:flex;align-items:center;gap:8px}input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line-strong);background:#fff;color:var(--text);border-radius:0;font:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(47,111,237,.12)}textarea{min-height:90px;resize:vertical}
.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;min-width:760px;background:#fff}.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.table th{background:#f7faff;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:#617389}
.surf-card{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center}
.admin-menu{display:grid;gap:8px}.admin-menu a{display:block;padding:10px 12px;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:600}.admin-menu a.active{border-color:var(--brand);background:#edf3ff;color:var(--brand)}
.product-card .card-media{height:160px}.product-card .price-line{font-size:14px;color:var(--muted);display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}.product-card .price-line b{color:var(--text)}
.step-list{display:grid;gap:10px}.step-item{display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:flex-start;padding:14px;border:1px solid var(--line);background:#fff}.step-num{width:48px;height:48px;background:#edf3ff;color:var(--brand);border:1px solid #cfe0ff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px}
.metric-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.metric-strip .metric{padding:16px;border:1px solid var(--line);background:var(--panel-alt)}
.metric-strip .metric b{display:block;font-size:26px;color:var(--text);margin-top:6px}
.info-list{display:grid;gap:10px}.info-list .info-item{padding:14px;border:1px solid var(--line);background:#fff}
.city-building-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.city-building-card{display:grid;gap:12px;padding:16px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
.city-building-card .meta{display:grid;gap:6px;font-size:14px;color:var(--muted)}
.owned-building{display:grid;grid-template-columns:110px 1fr;gap:14px;padding:14px;border:1px solid var(--line);background:#fff}
.owned-building .mini-media{height:96px;border:1px solid var(--line);background:#f4f7fb;display:flex;align-items:center;justify-content:center;overflow:hidden}
.list-clean{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.hr{height:1px;background:var(--line);margin:18px 0}
.top-form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.building-preview{width:96px;height:72px;border:1px solid var(--line);background:#f4f7fb;overflow:hidden;display:flex;align-items:center;justify-content:center}.building-preview img{width:100%;height:100%;object-fit:cover}
.surf-frame{height:100vh;display:grid;grid-template-rows:62px 1fr 70px;background:#f4f7fb}.surf-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:#ffffff;border-bottom:1px solid var(--line)}.surf-bottom{border-top:1px solid var(--line);border-bottom:0}.surf-iframe{width:100%;height:100%;border:0;background:#fff}.surf-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.small-btn{padding:8px 10px;font-size:13px}.surf-banner{width:100%;text-align:center;overflow:hidden;color:var(--muted)}.surf-modal-backdrop{position:fixed;inset:0;background:rgba(20,29,45,.45);z-index:100;display:flex;align-items:center;justify-content:center;padding:18px}.surf-modal-backdrop[hidden]{display:none}.surf-modal{width:min(460px,100%);background:#fff;border:1px solid var(--line);padding:22px;box-shadow:0 18px 50px rgba(20,29,45,.18);text-align:left}.surf-modal h2{margin-top:0}.math-question{font-size:34px;font-weight:900;text-align:center;background:#f7faff;border:1px solid var(--line);padding:18px;margin:14px 0}.modal-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.modal-message{min-height:20px;margin-top:10px}.error-text{color:var(--bad)}.success-text{color:var(--good)}
@media(max-width:1100px){.layout-grid{grid-template-columns:1fr}.sidebar{position:static}.hero-grid,.kpi-grid,.metric-strip,.city-building-grid,.grid.cols-4,.grid.cols-3,.grid.cols-2,.top-form-grid{grid-template-columns:1fr 1fr}.hero h1,.hero-box h1{font-size:32px}}
@media(max-width:760px){.top-inner{align-items:flex-start;flex-direction:column}.top-actions{width:100%}.hero-grid,.kpi-grid,.metric-strip,.city-building-grid,.grid.cols-4,.grid.cols-3,.grid.cols-2,.top-form-grid,.surf-card,.owned-building{grid-template-columns:1fr}.hero h1,.hero-box h1{font-size:28px}.table{min-width:620px}.surf-bar{align-items:flex-start;flex-direction:column}.surf-frame{grid-template-rows:auto 1fr auto}}

/* Layout fixes: cleaner admin forms, readable tables, Russian status badges, no stat overflow. */
.check-row{align-items:flex-start;gap:10px;line-height:1.35}
.check-row input[type="checkbox"],.check-row input[type="radio"]{width:auto;min-width:16px;height:16px;margin-top:2px;padding:0;box-shadow:none}
.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:12px}
.kpi{min-width:0;overflow:hidden}
.stat{font-size:clamp(22px,2vw,30px);word-break:break-word;overflow-wrap:anywhere}
.stat-money{font-size:clamp(20px,1.8vw,28px);white-space:normal}
.badge{text-transform:none;letter-spacing:0;white-space:nowrap}
.admin-section-title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}
.admin-section-title h2{margin:0}.admin-section-title p{margin:4px 0 0}
.admin-edit-list{display:grid;gap:16px}
.admin-edit-card{border:1px solid var(--line);background:#fff;padding:18px;box-shadow:var(--shadow)}
.admin-edit-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.admin-edit-card-header h3{margin:0}.admin-edit-card-header .muted{margin-top:4px}
.admin-edit-grid{display:grid;grid-template-columns:180px minmax(260px,1fr) minmax(320px,1.35fr) 160px;gap:16px;align-items:start}
.admin-image-box{display:grid;gap:10px}.admin-image-preview{height:130px;border:1px solid var(--line);background:#f4f7fb;display:flex;align-items:center;justify-content:center;overflow:hidden}.admin-image-preview img{width:100%;height:100%;object-fit:cover}
.admin-fields-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.admin-fields-grid .wide{grid-column:1/-1}.admin-fields-grid textarea{min-height:120px}
.admin-actions-box{display:grid;gap:12px}.admin-actions-box button{width:100%}
.settings-block-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}.settings-block{padding:16px;border:1px solid var(--line);background:#f8fbff}.settings-block b{display:block;margin-bottom:6px}.settings-block p{margin:0;color:var(--muted);font-size:13px}
.surf-options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px;margin-bottom:14px}.surf-option-card{padding:16px;border:1px solid var(--line);background:#f8fbff;display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start}.surf-option-card input{margin-top:3px}.surf-option-card b{display:block;margin-bottom:4px}.surf-option-card span{color:var(--muted);font-size:13px;line-height:1.45}
.form-block-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;align-items:end}.form-block-grid .wide{grid-column:1/-1}
.admin-card-table{display:grid;gap:12px}.admin-row-card{border:1px solid var(--line);background:#fff;padding:16px;display:grid;grid-template-columns:90px minmax(160px,.8fr) minmax(260px,1.4fr) minmax(260px,1fr);gap:16px;align-items:start;max-width:100%}.admin-row-card>div{min-width:0}.admin-row-card.compact{grid-template-columns:80px minmax(180px,1fr) minmax(160px,.8fr) minmax(160px,.8fr) 170px}.admin-row-card .row-label{font-size:12px;text-transform:uppercase;color:var(--muted);font-weight:800;margin-bottom:5px}.admin-row-card h3{margin:0 0 6px}.admin-row-card a{overflow-wrap:anywhere}.status-select-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:stretch;width:100%;max-width:100%}.status-select-row select{min-width:0;width:100%}.status-select-row button{white-space:nowrap;min-width:0;max-width:100%}.table .cell-actions form{display:flex;gap:8px;flex-wrap:wrap}.table .cell-actions input{max-width:180px}.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
@media(max-width:1180px){.admin-edit-grid,.admin-row-card,.admin-row-card.compact{grid-template-columns:1fr 1fr}.admin-image-preview{height:180px}}
@media(max-width:760px){.admin-edit-grid,.admin-fields-grid,.admin-row-card,.admin-row-card.compact,.form-block-grid,.surf-options-grid,.settings-block-grid{grid-template-columns:1fr}.status-select-row{grid-template-columns:1fr}.status-select-row select,.status-select-row button{width:100%}}
.admin-row-card.compact{grid-template-columns:80px repeat(4,minmax(150px,1fr)) 160px}
@media(max-width:1180px){.admin-row-card.compact{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.admin-row-card.compact{grid-template-columns:1fr}}
.live-production{margin-top:10px;padding:10px 12px;border:1px solid #cfe0ff;background:#f4f8ff;display:grid;gap:4px;max-width:100%}
.live-production span:first-child{color:var(--muted);font-size:13px}
.live-production b{font-size:18px;line-height:1.25;color:var(--brand);overflow-wrap:anywhere}
.live-production-box{margin-top:10px;padding:10px 12px;border:1px solid #cfe0ff;background:#f4f8ff;display:grid;gap:4px}
.live-production-value{font-size:18px;font-weight:800;color:var(--brand);overflow-wrap:anywhere}
.balance-updated-flash{animation:balanceFlash .8s ease}
@keyframes balanceFlash{0%{background:#e8fff2}100%{background:transparent}}

/* Live city counters and instant Ajax balance updates */
.live-production{margin:10px 0;padding:10px 12px;border:1px solid #cfe0ff;background:#f7fbff;display:grid;gap:4px;max-width:100%}
.live-production span:first-child{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.live-production b{font-size:20px;color:var(--brand);line-height:1.15;word-break:break-word}
[data-balance].is-updated{animation:balancePulse .65s ease}
@keyframes balancePulse{0%{background:#dbeafe}100%{background:transparent}}
.owned-building{align-items:start}.owned-building > div:last-child{min-width:0}.owned-building h3,.owned-building p{word-break:break-word}

/* Live counters and AJAX balance refresh. */
.balance-updated{animation:balancePulse .8s ease}
@keyframes balancePulse{0%{background:#fff5c2}100%{background:transparent}}
.live-production{margin:10px 0;padding:10px 12px;border:1px solid #cfe0ff;background:#f4f8ff;display:grid;gap:3px;max-width:360px}
.live-production span{color:#51657f;font-size:13px}
.live-production b{font-size:18px;color:#1d4ed8;overflow-wrap:anywhere}
.live-production small{color:#6b7f98;font-size:12px}
@media(max-width:760px){.live-production{max-width:none}.live-production b{font-size:16px}}

/* Warehouse resource cards with instant calculations */
.storage-grid{display:grid;gap:16px}
.storage-card{border:1px solid var(--line);background:#fff;box-shadow:var(--shadow);padding:18px;display:grid;gap:16px}
.storage-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:12px}
.storage-card-head h3{margin:0 0 4px}
.storage-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.storage-metric{border:1px solid var(--line);background:#f8fbff;padding:12px;min-width:0}
.storage-metric span,.calc-grid span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em;font-weight:800;margin-bottom:4px}
.storage-metric b,.calc-grid b{font-size:16px;overflow-wrap:anywhere}
.storage-actions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.storage-action-box{border:1px solid var(--line);background:#fff;padding:14px;display:grid;gap:10px}
.storage-action-box h4{margin:0 0 4px;font-size:18px}
.calc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.calc-grid>div{border:1px solid var(--line);background:#f7faff;padding:10px;min-width:0}
.storage-action-box button{width:max-content;min-width:130px}
@media(max-width:980px){.storage-metrics,.storage-actions-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.storage-card-head,.storage-metrics,.storage-actions-grid,.calc-grid{grid-template-columns:1fr}.storage-card-head{display:grid}.storage-action-box button{width:100%}}

/* Admin surfing: keep status select and save button inside the card. */
.admin-row-card > div{min-width:0}
.admin-row-card a,.admin-row-card p,.admin-row-card h3{overflow-wrap:anywhere;word-break:break-word}
.status-select-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  width:100%;
  max-width:100%;
}
.status-select-row select{
  min-width:0;
  width:100%;
  max-width:100%;
}
.status-select-row button{
  width:auto;
  max-width:100%;
  min-width:0;
  padding-left:12px;
  padding-right:12px;
  white-space:normal;
}
@media(max-width:900px){
  .status-select-row{grid-template-columns:1fr}
  .status-select-row button{width:100%}
}


.building-buy-form{
  display:grid;
  gap:10px;
}
.building-buy-form .form-row{
  margin-bottom:0;
}
.building-buy-total{
  padding:10px 12px;
  border:1px solid var(--line);
  background:#f7faff;
  font-size:14px;
  color:var(--muted);
}
.building-buy-total b{
  color:var(--text);
}
.live-production-collect{
  margin-top:10px;
}
.live-production-collect .small-btn{
  width:100%;
}
.modal-notice{
  position:fixed;
  inset:0;
  z-index:120;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(18,37,63,.35);
}
.modal-notice-card{
  width:min(560px,100%);
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 20px 60px rgba(18,37,63,.18);
  padding:18px;
}
.modal-notice-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  border-bottom:1px solid var(--line);
  padding-bottom:12px;
  margin-bottom:12px;
}
.modal-notice-head h3{
  margin:0;
}
.modal-notice-body{
  color:var(--text);
  line-height:1.6;
}
@media(max-width:760px){
  .modal-notice-head{
    flex-direction:column;
  }
}

.captcha-box{border:1px solid var(--line);background:#f8fbff;padding:14px;margin:0 0 14px}
.captcha-code{display:inline-block;letter-spacing:.22em;font-weight:900;font-size:24px;background:#fff;border:1px dashed var(--line-strong);padding:10px 14px;margin-bottom:10px;color:var(--brand);user-select:none}
.live-production-collect{margin-top:10px}
button[disabled],.btn[disabled]{opacity:.65;cursor:not-allowed;background:#9fb4d7;border-color:#9fb4d7;color:#fff}
button[disabled]:hover{background:#9fb4d7;border-color:#9fb4d7;color:#fff}

/* Mobile overflow fixes: keep badges, section headers and buttons inside the viewport. */
html,body{
  max-width:100%;
  overflow-x:hidden;
}
.wrap,.main-column,.panel,.card,.hero-box,.sidebar,.grid,.card-title-row{
  min-width:0;
  max-width:100%;
}
.card-title-row > *{
  min-width:0;
}
.badge,.top-badge,.btn,.button,button,.sidebar-link{
  max-width:100%;
}
.badge{
  overflow-wrap:anywhere;
  word-break:normal;
}
@media(max-width:760px){
  .wrap{padding-left:12px;padding-right:12px;width:100%}
  .layout-grid{padding-top:14px;gap:14px}
  .card-title-row{
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
  }
  .card-title-row .badge{
    white-space:normal;
    width:100%;
  }
  .hero-box,.panel,.card{padding:16px}
  .top-actions{display:grid;grid-template-columns:1fr;gap:8px}
  .top-badge{width:100%;justify-content:space-between;white-space:normal;overflow-wrap:anywhere}
  .hero-actions,.inline-actions{width:100%}
  .hero-actions .btn,.hero-actions .button,.inline-actions .btn,.inline-actions button{width:100%}
  .metric-strip,.kpi-grid,.grid.cols-4,.grid.cols-3,.grid.cols-2,.city-building-grid,.top-form-grid{
    grid-template-columns:1fr !important;
  }
  .feature-card,.product-card,.city-building-card,.storage-card,.owned-building{
    max-width:100%;
    overflow:hidden;
  }
  .feature-card p,.card p,.panel p,.muted{
    overflow-wrap:anywhere;
  }
}
@media(max-width:420px){
  .logo{font-size:20px;align-items:flex-start}
  .logo small{font-size:10px;line-height:1.35}
  .hero h1,.hero-box h1{font-size:26px;line-height:1.15}
  .panel h2,.card h2{font-size:23px;line-height:1.2}
  .card h3,.panel h3{font-size:19px;line-height:1.25}
}

/* Desktop width and adaptive menu fixes. */
.wrap{
  max-width:1180px;
}
.mobile-menu-toggle,
.mobile-menu-close,
.menu-overlay{
  display:none;
}
.mobile-menu-toggle,
.mobile-menu-close{
  border:1px solid var(--line-strong);
  background:#fff;
  color:var(--text);
}
.mobile-menu-toggle:hover,
.mobile-menu-close:hover{
  background:#f5f8fc;
  color:var(--text);
  border-color:var(--line-strong);
}
@media(min-width:1101px){
  .sidebar{
    top:max(24px, calc(50vh - 360px));
    max-height:calc(100vh - 48px);
    overflow-y:auto;
    scrollbar-width:thin;
  }
}
@media(max-width:1100px){
  .mobile-menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    white-space:nowrap;
  }
  .mobile-menu-close{
    display:inline-flex;
    width:100%;
    margin-bottom:14px;
  }
  .menu-overlay{
    position:fixed;
    inset:0;
    background:rgba(15,23,42,.38);
    z-index:70;
  }
  body.menu-open{
    overflow:hidden;
  }
  body.menu-open .menu-overlay{
    display:block;
  }
  .sidebar{
    display:block;
    position:fixed !important;
    top:12px !important;
    left:12px;
    bottom:12px;
    width:min(340px, calc(100vw - 24px));
    max-width:calc(100vw - 24px);
    max-height:none;
    overflow-y:auto;
    z-index:80;
    transform:translateX(calc(-100% - 24px));
    transition:transform .18s ease;
    box-shadow:0 18px 60px rgba(15,23,42,.22);
  }
  body.menu-open .sidebar{
    transform:translateX(0);
  }
}
@media(max-width:760px){
  .top-inner{
    gap:10px;
  }
  .mobile-menu-toggle{
    width:100%;
  }
  .captcha-box{
    padding:12px;
  }
  .captcha-code{
    display:block;
    width:100%;
    max-width:100%;
    text-align:center;
    font-size:clamp(18px,7vw,24px);
    letter-spacing:.16em;
    overflow-wrap:anywhere;
  }
  .captcha-box input{
    width:100%;
    font-size:16px;
    text-transform:uppercase;
  }
}

/* Desktop sidebar position and width refinement. */
@media(min-width:1101px){
  .wrap{
    max-width:1280px;
  }
  .layout-grid{
    grid-template-columns:280px minmax(0,1fr);
    align-items:start;
  }
  .sidebar{
    position:sticky;
    top:50vh;
    transform:translateY(-50%);
    max-height:calc(100vh - 32px);
    overflow-y:auto;
    scrollbar-width:thin;
  }
}
@media(min-width:1500px){
  .wrap{
    max-width:1320px;
  }
}

/* Sidebar final fix: remove inner scrollbar and keep the desktop menu as a normal sticky block. */
@media(min-width:1101px){
  .sidebar{
    position:sticky !important;
    top:max(24px, calc(50vh - 390px)) !important;
    transform:none !important;
    max-height:none !important;
    overflow:visible !important;
    scrollbar-width:auto !important;
  }
  .sidebar::-webkit-scrollbar{
    width:0 !important;
    height:0 !important;
  }
  .sidebar-inner{
    overflow:visible !important;
  }
  .layout-grid{
    overflow:visible !important;
  }
}

/* Integer storage and mobile menu scroll fix. */
.storage-bulk-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:0 0 16px;
}
.storage-bulk-actions form{margin:0}
.storage-bulk-actions button{width:auto;min-width:190px}
.storage-action-box .inline-actions{align-items:center}
.storage-action-box .inline-actions button{width:auto;min-width:130px}
@media(max-width:680px){
  .storage-bulk-actions{display:grid;grid-template-columns:1fr}
  .storage-bulk-actions button,.storage-action-box .inline-actions button{width:100%}
}
@media(max-width:1100px){
  body.menu-open{overflow:hidden}
  .sidebar{
    max-height:calc(100dvh - 24px) !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
  }
  .sidebar-inner{
    min-height:auto;
    padding-bottom:max(28px, env(safe-area-inset-bottom));
  }
}

/* Bonus module */
.bonus-grid .bonus-card,
.bonus-admin-card{
  display:grid;
  gap:12px;
}
.bonus-icon{
  width:52px;
  height:52px;
  border:1px solid var(--line);
  background:#eef4ff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
}
.bonus-details{
  display:grid;
  gap:8px;
  padding:12px;
  border:1px solid var(--line);
  background:var(--panel-alt);
}
.bonus-details div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  font-size:14px;
}
.bonus-details span{
  color:var(--muted);
}
.bonus-details b{
  text-align:right;
  overflow-wrap:anywhere;
}
.bonus-card button[disabled]{
  cursor:not-allowed;
  opacity:.72;
}
.bonus-admin-card .form-row{
  margin-bottom:10px;
}
@media(max-width:760px){
  .bonus-details div{
    display:grid;
    gap:4px;
  }
  .bonus-details b{
    text-align:left;
  }
}

/* Surf cards redesign */
.surf-panel-list{
  padding:24px;
}
.surf-modern-list{
  display:grid;
  gap:24px;
  margin-top:18px;
}
.surf-modern-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:22px;
  align-items:center;
  padding:30px 34px;
  border:1px solid #eceff5;
  border-radius:28px;
  background:#fbfbfd;
  box-shadow:none;
}
.surf-modern-main{
  min-width:0;
  display:grid;
  gap:12px;
}
.surf-modern-head h3{
  margin:0;
  font-size:25px;
  line-height:1.2;
  color:#2d3442;
}
.surf-modern-desc{
  margin:0;
  color:#a3acc0;
  font-size:16px;
}
.surf-modern-meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.surf-modern-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border:1px solid #eceff5;
  background:#fff;
  color:#7a8599;
  font-size:13px;
  font-weight:700;
  border-radius:999px;
}
.surf-modern-side{
  display:grid;
  gap:18px;
  align-items:center;
  justify-items:end;
  min-width:270px;
}
.surf-modern-stats{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.surf-modern-stat{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:15px;
  font-weight:700;
  color:#b1b5c7;
}
.surf-modern-stat.reward{
  color:#e14a4a;
}
.surf-modern-icon{
  width:22px;
  height:22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:15px;
  line-height:1;
  border-radius:50%;
  color:currentColor;
  background:transparent;
}
.surf-modern-actions .btn{
  min-width:200px;
}

@media(max-width:980px){
  .surf-modern-card{
    grid-template-columns:1fr;
    align-items:start;
    padding:24px 22px;
    border-radius:22px;
  }
  .surf-modern-side{
    min-width:0;
    width:100%;
    justify-items:start;
  }
  .surf-modern-stats{
    justify-content:flex-start;
  }
}
@media(max-width:640px){
  .surf-panel-list{padding:18px}
  .surf-modern-head h3{font-size:20px}
  .surf-modern-desc{font-size:15px}
  .surf-modern-stats{display:grid;gap:10px}
  .surf-modern-actions,.surf-modern-actions .btn{width:100%}
}

/* Pagination for user operations and admin logs */
.pagination{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}
.pagination a,
.pagination span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:8px 12px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-weight:700;
  font-size:14px;
}
.pagination a:hover{
  border-color:var(--brand);
  background:#edf3ff;
  color:var(--brand);
}
.pagination .active{
  border-color:var(--brand);
  background:var(--brand);
  color:#fff;
}
.pagination .disabled,
.pagination .dots{
  color:var(--muted);
  background:#f7faff;
}
.pagination-info{
  color:var(--muted)!important;
  background:#f8fbff!important;
  font-weight:600!important;
}
@media(max-width:640px){
  .pagination a,
  .pagination span{
    flex:1 1 auto;
    min-width:44px;
  }
  .pagination-info{
    flex-basis:100%;
  }
}

/* Tasks module */
.tasks-hero h1,
.task-detail-head h1{margin:0 0 8px;font-size:34px;line-height:1.15}
.task-tabs{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.task-tabs a{display:inline-flex;padding:10px 14px;border:1px solid var(--line);background:#fff;color:var(--muted);font-weight:700;text-decoration:none}
.task-tabs a.active,.task-tabs a:hover{border-color:var(--brand);color:var(--brand);background:#edf3ff}
.task-category-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.task-category{padding:9px 12px;border:1px solid var(--line);background:#f6f8fc;color:#758098;font-weight:700;font-size:13px;text-decoration:none}
.task-category.active,.task-category:hover{border-color:var(--brand);background:#edf3ff;color:var(--brand)}
.tasks-filter-panel{margin-top:16px}
.task-search-form{display:grid;grid-template-columns:minmax(220px,1fr) auto auto;gap:12px;align-items:end}
.task-list{display:grid;gap:18px;margin-top:18px}
.task-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:center;background:#fff;border:1px solid var(--line);padding:24px 28px;box-shadow:var(--shadow)}
.task-card-main{min-width:0}
.task-card-title-row{display:flex;justify-content:space-between;gap:16px;align-items:start}
.task-card h2{margin:0 0 10px;font-size:24px;line-height:1.2}
.task-card h2 a{color:var(--text);text-decoration:none}
.task-card h2 a:hover{color:var(--brand)}
.task-price{font-size:22px;font-weight:900;color:#e14a4a;white-space:nowrap}
.task-url{color:#98a4bc;font-weight:700;margin-bottom:10px;word-break:break-all}
.task-card-meta{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;color:#7a8599;font-size:14px;font-weight:700}
.task-card-actions{display:grid;gap:10px}
.task-author-card{margin:16px 0;display:flex;align-items:center;gap:16px;padding:26px 32px;background:#17234b;color:#fff;box-shadow:var(--shadow)}
.task-author-card small{display:block;color:#d9e2ff;margin-top:4px}
.avatar-circle{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff;color:#17234b;font-size:28px}
.task-author-spacer{flex:1}
.task-detail-head{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:center}
.task-detail-stats{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}
.task-detail-stats div{min-width:120px;border:1px solid var(--line);padding:14px;background:#f8fbff}
.task-detail-stats span{display:block;color:var(--muted);font-size:13px;font-weight:700}
.task-detail-stats b{display:block;margin-top:6px;font-size:20px}
.task-text-box{border:1px solid var(--line);background:#fbfdff;padding:18px;line-height:1.55;word-break:break-word}
.task-submit-panel form,.task-add-form{display:grid;gap:14px}
.task-add-form label,.task-submit-panel label{font-weight:800}
.task-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.radio-line,.check-line{display:flex;align-items:center;gap:8px;font-weight:700!important}
.task-report-list{display:grid;gap:16px}
.task-report-card{border:1px solid var(--line);background:#fff;padding:20px}
.task-report-head{display:flex;justify-content:space-between;align-items:start;gap:16px;margin-bottom:14px}
.task-report-head h3{margin:0 0 6px}
.task-review-form{display:grid;grid-template-columns:minmax(180px,1fr) auto auto;gap:10px;margin-top:14px;align-items:center}
.btn.bad{background:#e84c5f;color:#fff;border-color:#e84c5f}
.btn.bad:hover{filter:brightness(.95)}
.alert.info{background:#eaf2ff;border-color:#c9ddff;color:#244568}

@media(max-width:900px){
  .task-card,.task-detail-head{grid-template-columns:1fr}
  .task-card-actions,.task-card-actions .btn{width:100%}
  .task-detail-stats{justify-content:flex-start}
  .task-search-form,.task-form-grid,.task-review-form{grid-template-columns:1fr}
}
@media(max-width:640px){
  .tasks-hero h1,.task-detail-head h1{font-size:28px}
  .task-card{padding:20px}
  .task-card-title-row{display:grid;gap:8px}
  .task-price{font-size:20px}
  .task-author-card{padding:20px;align-items:flex-start}
  .task-detail-stats div{width:100%}
}

/* Task add form: boxed choices for report check and screenshot requirement */
.task-option-section{
  border:1px solid var(--line);
  background:#fbfdff;
  padding:20px;
  display:grid;
  gap:16px;
}
.task-option-title h2{
  margin:0 0 6px;
  font-size:22px;
}
.task-option-title p{
  margin:0;
}
.task-choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.task-choice-card{
  position:relative;
  display:grid!important;
  grid-template-columns:auto minmax(0,1fr);
  align-items:start;
  gap:12px;
  padding:18px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
  min-height:100%;
  font-weight:700!important;
}
.task-choice-card:hover{
  border-color:var(--brand);
  background:#f7faff;
}
.task-choice-card:has(input:checked){
  border-color:var(--brand);
  background:#edf3ff;
  box-shadow:0 0 0 2px rgba(46,100,230,.08) inset;
}
.task-choice-card input[type="radio"],
.task-choice-card input[type="checkbox"]{
  width:18px;
  height:18px;
  margin-top:4px;
  flex-shrink:0;
}
.task-choice-content{
  display:grid;
  gap:6px;
  min-width:0;
}
.task-choice-title{
  display:block;
  font-weight:900;
  color:var(--text);
  font-size:16px;
}
.task-choice-text{
  display:block;
  color:var(--muted);
  font-weight:600;
  line-height:1.45;
}
.task-choice-card-wide{
  width:100%;
}
.task-control-card{
  border:1px dashed #c8d5ea;
  background:#fff;
  padding:16px;
  display:grid;
  gap:8px;
}
.task-control-card label{
  font-weight:900!important;
}
.task-control-card small{
  display:block;
}

@media(max-width:900px){
  .task-choice-grid{
    grid-template-columns:1fr;
  }
  .task-option-section{
    padding:16px;
  }
}

/* Tasks management update */
.task-detail-head > div:first-child,
.task-card-main,
.task-report-head > div:first-child{
  min-width:0;
}
.task-detail-head h1,
.task-card h2,
.task-report-head h3{
  overflow-wrap:anywhere;
  word-break:break-word;
}
.task-detail-stats{
  min-width:0;
}
.task-detail-stats div{
  min-width:120px;
  max-width:180px;
}
.task-detail-stats b{
  overflow-wrap:anywhere;
  word-break:break-word;
}
.task-owner-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  min-width:220px;
}
.task-owner-actions form{
  margin:0;
  display:inline-flex;
}
.task-owner-actions .btn{
  min-height:36px;
  padding:8px 12px;
  white-space:nowrap;
}
.task-status-tabs a{
  gap:8px;
  align-items:center;
}
.task-status-tabs span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:24px;
  height:24px;
  padding:0 7px;
  border:1px solid currentColor;
  font-size:12px;
  font-weight:900;
  background:#fff;
}
.task-tabs a.active span,
.task-tabs a:hover span{
  background:#fff;
}
@media(max-width:900px){
  .task-owner-actions{
    min-width:0;
  }
  .task-owner-actions,
  .task-owner-actions form,
  .task-owner-actions .btn{
    width:100%;
  }
  .task-detail-stats div{
    max-width:none;
  }
}

/* Attention flags for user/admin menus */
.admin-menu a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.sidebar-link > span:first-child,
.admin-menu a > span:first-child{
  min-width:0;
}
.attention-flag{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:3px;
  min-width:30px;
  height:24px;
  padding:0 6px;
  border:1px solid #fecaca;
  background:#fff1f2;
  color:#dc2626;
  font-size:12px;
  font-weight:900;
  line-height:1;
  animation:attentionBlink 1.1s ease-in-out infinite;
}
.attention-flag-icon{
  font-size:15px;
  line-height:1;
}
.attention-flag-count{
  font-size:11px;
  line-height:1;
}
@keyframes attentionBlink{
  0%,100%{opacity:1;transform:translateY(0);box-shadow:0 0 0 rgba(220,38,38,0)}
  45%{opacity:.45;transform:translateY(-1px);box-shadow:0 0 0 3px rgba(220,38,38,.12)}
}
@media (prefers-reduced-motion: reduce){
  .attention-flag{animation:none}
}
@media(max-width:760px){
  .attention-flag{height:22px;min-width:28px}
}



/* Production banners and city landing */
.public-ad{
  margin:16px 0;
}
.public-ad-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.public-ad-slot{
  min-height:74px;
  border:1px solid var(--line);
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:8px;
}
.public-ad-slot iframe,
.public-ad-slot img,
.public-ad-slot ins{
  max-width:100%;
}
.public-ad-bottom{
  margin-top:20px;
}
.landing-city-hero{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr);
  gap:22px;
  align-items:stretch;
  margin:18px 0;
}
.landing-city-copy{
  border:1px solid var(--line);
  background:#fff;
  padding:34px;
  box-shadow:var(--shadow);
}
.landing-city-copy h1{
  margin:8px 0 14px;
  font-size:46px;
  line-height:1.08;
  letter-spacing:-.03em;
}
.landing-city-copy p{
  color:var(--muted);
  font-size:17px;
  max-width:760px;
}
.landing-kicker{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border:1px solid var(--line);
  background:#f4f7ff;
  color:#2f6fed;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:12px;
}
.city-map-card{
  position:relative;
  min-height:390px;
  border:1px solid var(--line);
  background:
    linear-gradient(90deg,rgba(47,111,237,.06) 1px,transparent 1px),
    linear-gradient(180deg,rgba(47,111,237,.06) 1px,transparent 1px),
    #fbfdff;
  background-size:42px 42px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.city-road{
  position:absolute;
  left:-20%;
  right:-20%;
  bottom:96px;
  height:76px;
  background:#dfe7f2;
  border-top:8px solid #c9d5e5;
  border-bottom:8px solid #c9d5e5;
  transform:rotate(-5deg);
}
.city-road:after{
  content:"";
  position:absolute;
  left:0;right:0;top:31px;
  border-top:4px dashed #fff;
}
.city-building{
  position:absolute;
  width:138px;
  min-height:112px;
  border:1px solid var(--line-strong);
  background:#fff;
  display:grid;
  place-items:center;
  gap:4px;
  padding:14px 10px;
  text-align:center;
  font-weight:900;
  box-shadow:0 12px 22px rgba(18,37,63,.08);
}
.city-building span{
  font-size:36px;
}
.city-building:before{
  content:"";
  position:absolute;
  left:-1px;right:-1px;top:-18px;
  height:18px;
  background:#2f6fed;
  border:1px solid #1f57c7;
}
.city-building-a{left:34px;bottom:138px}
.city-building-b{right:42px;bottom:150px}
.city-building-c{left:130px;top:76px}
.city-building-d{right:112px;top:48px}
.city-stats-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:16px 0;
}
.city-stat{
  border:1px solid var(--line);
  background:#fff;
  padding:18px;
}
.city-stat span{
  display:block;
  color:var(--muted);
  font-size:14px;
}
.city-stat b{
  display:block;
  margin-top:4px;
  font-size:30px;
  line-height:1;
}
.landing-section{
  margin-top:16px;
}
.building-feature-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.building-feature{
  position:relative;
  border:1px solid var(--line);
  background:#fff;
  padding:54px 18px 20px;
  min-height:220px;
  overflow:hidden;
}
.building-feature .building-roof{
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:32px;
  background:repeating-linear-gradient(90deg,#2f6fed 0 28px,#1f57c7 28px 56px);
}
.building-feature .building-icon{
  width:58px;
  height:58px;
  border:1px solid var(--line);
  background:#f3f6fb;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:30px;
  margin-bottom:12px;
}
.building-feature h3{
  margin:0 0 10px;
}
.building-feature p{
  margin:0;
  color:var(--muted);
}
.city-product-card{
  border:1px solid var(--line);
  background:#fff;
  padding:18px;
}
.city-product-img{
  height:130px;
  border:1px solid var(--line);
  background:#f4f7fb;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:14px;
}
.city-product-img span{
  font-size:48px;
}
.city-product-img img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.city-product-meta{
  display:grid;
  gap:7px;
  color:var(--muted);
  font-size:14px;
}
.production-settings textarea{
  width:100%;
  min-height:110px;
  resize:vertical;
}

@media(max-width:1100px){
  .landing-city-hero{
    grid-template-columns:1fr;
  }
  .city-map-card{
    min-height:320px;
  }
  .building-feature-grid,
  .city-stats-row{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:680px){
  .public-ad-grid,
  .building-feature-grid,
  .city-stats-row{
    grid-template-columns:1fr;
  }
  .landing-city-copy{
    padding:24px 18px;
  }
  .landing-city-copy h1{
    font-size:31px;
  }
  .city-map-card{
    min-height:360px;
  }
  .city-building{
    width:120px;
    min-height:96px;
  }
  .city-building-a{left:18px;bottom:142px}
  .city-building-b{right:18px;bottom:138px}
  .city-building-c{left:34px;top:72px}
  .city-building-d{right:34px;top:58px}
}

/* Sidebar 200x300 banner blocks */
.sidebar-public-ads{
  display:grid;
  gap:14px;
  margin-top:16px;
}
.public-ad-sidebar-slot{
  width:100%;
  min-height:300px;
  max-width:300px;
  margin:0 auto;
  padding:0;
  background:#fff;
}
.public-ad-sidebar-slot iframe,
.public-ad-sidebar-slot img,
.public-ad-sidebar-slot ins{
  max-width:100%;
}
@media(max-width:980px){
  .sidebar-public-ads{
    margin-top:14px;
  }
  .public-ad-sidebar-slot{
    min-height:220px;
    max-width:100%;
  }
}

/* Building images by context */
.building-image-editor{
  border:1px solid var(--line);
  background:#f8fbff;
  padding:16px;
  margin:16px 0;
}
.admin-section-title.compact{margin-bottom:10px}
.admin-section-title.compact h3{margin:0 0 4px;font-size:18px}
.building-image-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.building-image-grid.compact{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.building-image-card{
  display:grid;
  gap:8px;
  padding:12px;
  background:#fff;
  border:1px solid var(--line);
  min-width:0;
}
.building-image-card h4{margin:0;font-size:15px}
.building-image-card label{font-size:12px;font-weight:800;color:var(--ink)}
.building-image-card input[type="file"]{font-size:12px;max-width:100%}
.small-preview{
  height:72px;
  border:1px solid var(--line);
  background:#f3f6fb;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:var(--muted);
  font-size:12px;
}
.small-preview img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.admin-building-images{margin:0}
.building-admin-edit-grid{grid-template-columns:190px minmax(260px,1fr) minmax(360px,1.4fr) 140px}
.city-building .city-building-image{
  width:56px;
  height:56px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:0;
}
.city-building .city-building-image img{
  width:100%;
  height:100%;
  object-fit:contain;
}
@media(max-width:1200px){
  .building-image-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .building-admin-edit-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .building-image-grid,.building-image-grid.compact{grid-template-columns:1fr}
}

/* Withdrawal activation window */
.withdraw-window-panel,
.withdraw-referral-info{
  margin:16px 0;
}
.withdraw-window-panel.good-panel{
  border-color:#b9e6c8;
  background:#f4fff7;
}
.withdraw-window-panel.warn-panel{
  border-color:#f0cf91;
  background:#fff8e8;
}
.withdraw-window-panel.expired{
  border-color:#f2b4b4;
  background:#fff5f5;
}
.withdraw-window-timer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border:1px solid #cbd7ea;
  background:#fff;
  margin:12px 0;
  font-weight:800;
}
.withdraw-window-timer b{
  font-size:28px;
  line-height:1;
}
@media(max-width:640px){
  .withdraw-window-timer{
    display:grid;
    justify-items:start;
  }
  .withdraw-window-timer b{
    font-size:24px;
  }
}

.mini-info-block{
  margin-top:12px;
  padding:12px;
  border:1px solid var(--line);
  background:#f8fbff;
}
button:disabled,
.btn:disabled{
  opacity:.55;
  cursor:not-allowed;
}

/* Energy equipment module */
.energy-owned-card{
  align-items:flex-start;
}
.energy-production-box{
  margin-top:14px;
}
.energy-equipment-admin-card .admin-edit-media img,
.energy-owned-card .owned-media img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.energy-equipment-admin-card{
  grid-template-columns:70px 120px minmax(0,1fr) 150px;
}
@media(max-width:900px){
  .energy-equipment-admin-card{
    grid-template-columns:1fr;
  }
}

/* Energy equipment */
.energy-equipment-card .placeholder-media,
.energy-owned-card .placeholder-media{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:90px;
  font-size:46px;
}
.energy-live-box{
  margin-top:12px;
  border-left:4px solid #2f6fed;
}
.energy-equipment-admin-card{
  align-items:flex-start;
}
.energy-equipment-admin-card .admin-edit-media img{
  width:92px;
  height:92px;
  object-fit:contain;
  background:#f3f6fb;
  border:1px solid #d7e0ef;
}
@media(max-width:720px){
  .energy-equipment-admin-card{
    grid-template-columns:1fr;
  }
}
.admin-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.admin-form-grid .span-2{grid-column:1 / -1}
.admin-form-grid .checkline{align-self:center}
@media(max-width:720px){
  .admin-form-grid{grid-template-columns:1fr}
}

/* Deposit bonus packs */
.gold-set-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;
}
.gold-set-card{
  position:relative;
  overflow:hidden;
  border:1px solid #d8b756;
  background:linear-gradient(180deg,#fffaf0 0%,#ffffff 55%);
  padding:18px;
  box-shadow:0 10px 24px rgba(214,164,44,.12);
}
.gold-set-ribbon{
  position:absolute;
  top:0;
  right:0;
  padding:6px 10px;
  background:#f2c94c;
  color:#111827;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.gold-set-head h3{margin:0 0 8px;font-size:22px;line-height:1.15}
.gold-set-range{font-weight:800;color:#8a6408}
.gold-set-percent{
  margin-top:12px;
  padding:10px 12px;
  background:#fff3bf;
  border:1px solid #e4bd45;
  font-weight:900;
}
.gold-set-items{display:grid;gap:8px;margin-top:14px}
.gold-set-item{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:8px 10px;
  border:1px solid #e6edf7;
  background:#fff;
}
.deposit-pack-admin-list{display:grid;gap:16px}
.deposit-pack-admin-card{
  border:1px solid #ccd7e8;
  background:#fff;
  padding:18px;
}
.deposit-pack-items{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.deposit-pack-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) 110px;
  gap:10px;
  align-items:end;
  padding:12px;
  border:1px solid #dde6f3;
  background:#f8fbff;
}
.compact-card{padding:14px}
@media(max-width:680px){
  .deposit-pack-item{grid-template-columns:1fr}
}

/* Deposit bonus pack admin editor */
.deposit-pack-editor{display:grid;gap:16px}
.admin-subpanel{
  border:1px solid #d6e1f0;
  background:#f9fbff;
  padding:16px;
}
.admin-subpanel-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
  border-bottom:1px solid #e3ebf6;
  padding-bottom:10px;
}
.admin-subpanel-title h3,
.admin-subpanel-title h4{margin:0}
.admin-field-grid{
  display:grid;
  gap:12px;
}
.admin-field-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.admin-field-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.admin-field-card{
  display:grid;
  gap:8px;
  align-content:start;
  border:1px solid #d7e2f2;
  background:#fff;
  padding:12px;
  min-width:0;
}
.admin-field-card.no-pad{
  padding:0;
  border:0;
  background:transparent;
}
.admin-field-card label{
  font-weight:800;
  color:#172033;
}
.admin-field-card input,
.admin-field-card select,
.admin-field-card textarea{width:100%}
.check-card{
  cursor:pointer;
  user-select:none;
}
.check-card input{
  width:auto;
}
.large-check-card{
  grid-template-columns:auto 1fr;
  align-items:center;
}
.large-check-card span{display:grid;gap:4px}
.large-check-card em{
  font-style:normal;
  color:#60708c;
  font-size:13px;
  line-height:1.35;
}
.mini-check-card{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid #d7e2f2;
  background:#fff;
  padding:10px 12px;
}
.deposit-pack-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px solid #e3ebf6;
  padding-bottom:14px;
  margin-bottom:16px;
}
.deposit-pack-card-head h3{margin:0 0 6px}
.deposit-building-table{
  display:grid;
  gap:8px;
}
.deposit-building-head,
.deposit-building-row{
  display:grid;
  grid-template-columns:70px minmax(240px,1fr) 160px;
  gap:10px;
  align-items:end;
}
.deposit-building-head{
  align-items:center;
  padding:10px 12px;
  background:#eef4fc;
  border:1px solid #d7e2f2;
  color:#496284;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}
.deposit-building-row{
  padding:12px;
  border:1px solid #d7e2f2;
  background:#fff;
}
.deposit-building-number{
  align-self:center;
  font-weight:900;
  color:#2f69e8;
}
@media(max-width:1100px){
  .admin-field-grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .admin-field-grid.cols-2,
  .admin-field-grid.cols-4{grid-template-columns:1fr}
  .deposit-pack-card-head{display:grid}
  .deposit-building-head{display:none}
  .deposit-building-row{grid-template-columns:1fr}
  .deposit-building-number{padding-bottom:6px;border-bottom:1px solid #e3ebf6}
}

/* Deposit bonus admin UI improvements */
.deposit-bonus-panel .muted.small,
.deposit-bonus-field-card .muted.small{
  display:block;
  margin-top:6px;
  font-size:12px;
  line-height:1.45;
}
.deposit-bonus-admin-form{display:grid;gap:18px}
.deposit-bonus-settings-grid{
  display:grid;
  grid-template-columns:minmax(260px,1.3fr) minmax(240px,1fr) minmax(240px,1fr);
  gap:14px;
  align-items:stretch;
}
.deposit-bonus-field-card{
  display:grid;
  gap:12px;
  padding:16px;
  border:1px solid #d8e2f0;
  background:#f9fbff;
}
.deposit-bonus-field-card .field-card-title{
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:#35506f;
}
.field-card-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(160px,.8fr);
  gap:12px;
  align-items:end;
}
.admin-check-card{
  min-height:48px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px;
  border:1px solid #cfddec;
  background:#fff;
  font-weight:800;
  cursor:pointer;
}
.admin-check-card input{width:auto;min-width:auto;margin:0}
.admin-check-card.small-check-card{min-height:42px;margin-top:10px}
.deposit-bonus-buildings-box{
  padding:16px;
  border:1px solid #d8e2f0;
  background:#fff;
}
.compact-title{margin-bottom:12px}
.deposit-bonus-building-table{
  display:grid;
  gap:8px;
}
.deposit-bonus-building-head,
.deposit-bonus-building-row{
  display:grid;
  grid-template-columns:60px minmax(240px,1fr) minmax(130px,180px);
  gap:10px;
  align-items:stretch;
}
.deposit-bonus-building-head{
  padding:9px 12px;
  background:#f3f6fb;
  border:1px solid #dbe5f2;
  color:#566b87;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.deposit-bonus-building-row{
  padding:10px;
  border:1px solid #dde6f3;
  background:#f8fbff;
}
.deposit-bonus-building-row .slot-number{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:58px;
  border:1px solid #cfddec;
  background:#fff;
  font-weight:900;
  color:#315173;
}
.field-box{
  display:grid;
  gap:6px;
  padding:10px;
  border:1px solid #cfddec;
  background:#fff;
  min-width:0;
}
.field-box label{
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  color:#516984;
}
.field-box select,
.field-box input{
  width:100%;
  min-width:0;
}
.quantity-box input{text-align:left}
.deposit-pack-admin-card .deposit-bonus-settings-grid{margin-top:10px}
.deposit-pack-admin-card .deposit-bonus-buildings-box{margin-top:14px}
@media(max-width:1100px){
  .deposit-bonus-settings-grid{grid-template-columns:1fr 1fr}
  .wide-field-card{grid-column:1/-1}
}
@media(max-width:760px){
  .deposit-bonus-settings-grid,
  .field-card-row,
  .deposit-bonus-building-head,
  .deposit-bonus-building-row{
    grid-template-columns:1fr;
  }
  .deposit-bonus-building-head{display:none}
  .deposit-bonus-building-row .slot-number{justify-content:flex-start;min-height:36px;padding:0 10px}
}

/* Wider referral levels block on deposit bonuses admin page */
.referral-levels-panel{
  margin-bottom:16px;
}
.admin-field-grid.cols-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.referral-levels-grid{
  align-items:stretch;
}
.referral-level-card{
  gap:10px;
}
.referral-level-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-bottom:8px;
  border-bottom:1px solid #e3ebf6;
}
.referral-level-title b{
  font-size:20px;
  color:#172033;
}
.referral-check-card{
  margin-top:4px;
}
@media(max-width:1100px){
  .admin-field-grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:760px){
  .admin-field-grid.cols-3{grid-template-columns:1fr}
  .referral-level-title{align-items:flex-start;flex-direction:column}
}

/* Referral banners and PayKassa payout UI */
.referral-banner-grid,
.referral-banner-admin-list{
  display:grid;
  gap:16px;
}
.referral-banner-grid{
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.referral-banner-card,
.referral-banner-admin-card{
  border:1px solid var(--border,#d8e2f1);
  background:#fff;
  padding:18px;
  display:grid;
  gap:12px;
}
.referral-banner-preview,
.referral-banner-admin-preview{
  border:1px solid var(--border,#d8e2f1);
  background:#f5f8fc;
  padding:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:auto;
}
.referral-banner-preview img,
.referral-banner-admin-preview img{
  max-width:100%;
  height:auto;
  object-fit:contain;
}
.referral-benefit-card .stat{
  margin:8px 0;
}
.copy-row input,
.referral-banner-card textarea{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:13px;
}
.withdraw-admin-actions{
  display:grid;
  gap:10px;
  min-width:360px;
}
.break-anywhere{
  overflow-wrap:anywhere;
  word-break:break-word;
}
.referral-banner-admin-card form{
  margin:0;
}
@media(max-width:760px){
  .withdraw-admin-actions{min-width:0;width:100%}
  .withdraw-admin-actions .grid.cols-2{grid-template-columns:1fr}
}

/* Support tickets */
.ticket-list{display:grid;gap:14px;margin-top:16px}
.ticket-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;border:1px solid var(--border);background:#fff;padding:18px;box-shadow:var(--shadow)}
.ticket-card.is-unread{border-color:#2f6fed;background:#f8fbff}
.ticket-title-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.ticket-title-row h3{margin:0;font-size:20px;line-height:1.25;word-break:break-word}
.ticket-title-row a{text-decoration:none;color:var(--ink)}
.ticket-preview{margin:8px 0 0;word-break:break-word}
.ticket-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;color:var(--muted);font-size:13px}
.ticket-meta span{border:1px solid var(--border);padding:5px 8px;background:#f8fafc}
.ticket-card-side{display:grid;gap:10px;justify-items:end;min-width:160px}
.ticket-show-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.ticket-show-head h1{margin:16px 0 8px;word-break:break-word}
.ticket-thread{display:grid;gap:14px;margin-top:14px}
.ticket-message{max-width:82%;border:1px solid var(--border);background:#fff;padding:14px;box-shadow:var(--shadow)}
.ticket-message.from-admin{justify-self:start;border-left:4px solid #2f6fed;background:#f8fbff}
.ticket-message.from-user{justify-self:end;border-left:4px solid #10a05f;background:#f7fff9}
.ticket-message-head{display:flex;gap:10px;justify-content:space-between;flex-wrap:wrap;margin-bottom:8px;color:var(--muted);font-size:13px}
.ticket-message-head b{color:var(--ink)}
.ticket-message-body{white-space:normal;word-break:break-word;line-height:1.55}
.ticket-status-form{display:grid;gap:8px;min-width:260px}
.admin-ticket-table td{vertical-align:top}
.table-row-unread{background:#f8fbff}
.toolbar-form{display:grid;grid-template-columns:minmax(220px,1fr) 240px auto auto;gap:10px;align-items:end;margin:14px 0}
@media(max-width:900px){.ticket-card{grid-template-columns:1fr}.ticket-card-side{justify-items:start;min-width:0}.ticket-show-head{display:grid}.ticket-status-form{min-width:0}.toolbar-form{grid-template-columns:1fr}.ticket-message{max-width:100%}}

/* Admin withdraw window controls */
.withdraw-admin-control-panel .alert{margin-bottom:14px}
.settings-check-card{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:14px;
  border:1px solid var(--line-strong);
  background:#fff7ed;
  cursor:pointer;
}
.settings-check-card input{width:auto;margin-top:3px}
.settings-check-card span{display:grid;gap:4px}
.settings-check-card small{font-weight:400;color:var(--muted);line-height:1.45}
.user-withdraw-window-card .stat{font-size:22px}
