*{box-sizing:border-box}body{margin:0;background:#0f172a;color:#f8fafc;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}header{display:flex;justify-content:space-between;gap:1rem;align-items:center;background:#09111f;border-bottom:1px solid #475569;padding:16px 20px}h1{font-size:22px;margin:0 0 6px}h2{font-size:17px;margin:14px 0 8px}h3{font-size:14px;margin:12px 0 6px}p{color:#cbd5e1;line-height:1.4}.small{font-size:12px;color:#cbd5e1}.wrap{display:grid;grid-template-columns:430px minmax(760px,1fr) 420px;gap:14px;padding:14px}@media(max-width:1300px){.wrap{grid-template-columns:1fr}}.card{background:#172033;border:1px solid #475569;border-radius:12px;padding:12px;box-shadow:0 8px 24px rgba(0,0,0,.22)}.login{min-height:100vh;display:grid;place-items:center;padding:24px}.login .card{width:min(520px,100%)}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}label{display:flex;flex-direction:column;gap:4px;color:#cbd5e1;font-size:12px;margin:6px 0}.check{flex-direction:row;align-items:center}input,select,button,.button{font:inherit;color:#f8fafc;background:#0b1220;border:1px solid #475569;border-radius:8px;padding:8px;text-decoration:none}button,.button{cursor:pointer;background:#334155;display:inline-block}.primary{background:#d97706;border-color:#f59e0b;font-weight:700}.danger{background:#7f1d1d}.ok{background:#14532d}.ghost{background:#1e293b}.btnrow{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}.inline{display:inline-block;margin-right:8px}.metrics{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:8px;margin:8px 0}.metric{background:#0b1220;border:1px solid #475569;border-radius:8px;padding:8px}.metric b{display:block;font-size:16px}.metric span{font-size:11px;color:#cbd5e1}.good{color:#bbf7d0!important}.bad{color:#fecaca!important}.toast{margin:12px 14px 0;padding:10px;border-radius:8px}.okbox{background:#11361f;border:1px solid #166534}.err{background:#3b1111;border:1px solid #991b1b;color:#fecaca}.mapwrap{overflow:auto;background:#08111f;border:1px solid #475569;border-radius:10px;padding:10px}.gridmap{display:grid;position:relative;background:#0b1220;outline:2px solid #94a3b8}.cell{border-right:1px solid #1e293b;border-bottom:1px solid #1e293b}.sX{background:#020617}.sU{background:rgba(120,53,15,.55)}.sD{background:rgba(22,101,52,.20)}.sO{background:rgba(37,99,235,.25)}.sectorR{border-right:2px solid #94a3b8}.sectorB{border-bottom:2px solid #94a3b8}.building{z-index:2;border:2px solid rgba(255,255,255,.85);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;font-weight:800;box-shadow:0 2px 8px #0007;line-height:1.05;text-decoration:none;color:white;overflow:hidden}.building span{font-size:9px;opacity:.85}.building.th{background:#facc15;color:#111827}.building.qa{background:#06b6d4;color:#082f49}.building.res{background:#22c55e;color:#052e16}.building.prod{background:#a855f7}.building.mil{background:#ef4444}.building.goods{background:#14b8a6;color:#042f2e}.building.planned{border-style:dashed;outline:3px solid #f97316;outline-offset:-5px}.legend{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:#cbd5e1;margin:8px 0}.sw{width:14px;height:14px;border:1px solid rgba(255,255,255,.35);border-radius:3px;display:inline-block;vertical-align:middle}.sw.x{background:#020617}.sw.u{background:#78350f}.sw.d{background:#166534}.sw.o{background:#2563eb}.sw.planned{background:#f97316}table{width:100%;border-collapse:collapse;font-size:12px;margin:8px 0}th,td{border-bottom:1px solid #475569;padding:6px;text-align:left}th{color:#fde68a}.sectorlist{display:flex;flex-wrap:wrap;gap:6px}.sectorform{display:flex;gap:4px;align-items:center;background:#0b1220;border:1px solid #475569;border-radius:8px;padding:5px}.sectorform span{font-size:12px;color:#cbd5e1}.sectorform button{font-size:12px;padding:4px 6px}.planlist{counter-reset:step;margin:0;padding:0;list-style:none}.planlist li{counter-increment:step;background:#0b1220;border:1px solid #475569;border-radius:8px;margin:6px 0;padding:8px 8px 8px 36px;position:relative;color:#cbd5e1;font-size:13px}.planlist li:before{content:counter(step);position:absolute;left:9px;top:8px;background:#d97706;color:white;border-radius:999px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.planlist b{color:#f8fafc}hr{border:none;border-top:1px solid #475569;margin:12px 0}.header-actions{white-space:nowrap}

.adminwrap{grid-template-columns:420px 1fr}.wide{overflow:auto}.compact{display:inline}.actions{white-space:nowrap}.actions form{margin:2px 0}.bigkey{font-size:18px;color:#fde68a;word-break:break-all}.note{padding:10px;border-radius:8px;background:#312e1a;border:1px solid #854d0e;color:#fde68a;margin:10px 0}.note p{color:#fde68a}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

.mobile-place-box{background:#0b1220;border:1px solid #475569;border-radius:10px;padding:10px;margin:10px 0}.building-palette{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:6px;max-height:360px;overflow:auto}.palette-card{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;min-height:66px;padding:7px;background:#102033;border:1px solid #475569;border-radius:8px}.palette-card b{color:#fde68a}.palette-card span{font-size:11px;line-height:1.15}.palette-card small{font-size:10px;color:#cbd5e1}.palette-card.selected{outline:3px solid #f59e0b;background:#2a1c0a}.compact-note{padding:7px;margin:8px 0}.mapcell{cursor:crosshair}.mapbuilding,.building-select-link{cursor:pointer}.tap-moving{outline:3px solid #f59e0b;outline-offset:2px}.ui-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.mini-btn{font-size:12px;padding:5px 7px}.selected-panel{background:#0b1220;border:1px solid #475569;border-radius:10px;padding:10px}.selected-panel h3{margin-top:0}.selected-panel .detail{font-size:12px;color:#cbd5e1}.selected-panel input{max-width:120px}




/* Sector background numbers.
   Plain numbers are drawn as a transparent overlay across each usable 4×4 sector.
   They sit above buildings but use pointer-events:none, so mobile tapping still works.
   This makes sector IDs visible even when buildings cover the sector. */
.sector-label{
  z-index:7;
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  color:rgba(255,255,255,.24);
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-weight:900;
  font-size:34px;
  line-height:1;
  text-shadow:
    0 2px 6px rgba(0,0,0,.75),
    0 0 12px rgba(0,0,0,.55);
}
.sector-label span{
  display:block;
  background:transparent;
  border:0;
  padding:0;
  min-width:0;
  min-height:0;
  transform:rotate(-12deg);
  user-select:none;
}
.sector-label-U{
  color:rgba(255,255,255,.34);
}
.sector-label-D,.sector-label-O{
  color:rgba(255,255,255,.20);
}
.building{
  opacity:.92;
}
.building:hover{
  opacity:1;
}
.sector-chip{
  display:inline-flex;
  gap:4px;
  align-items:center;
  min-width:58px;
}
.sector-chip b{
  color:#fff;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  letter-spacing:.02em;
}
@media(max-width:700px){
  .sector-label{font-size:26px;color:rgba(255,255,255,.30)}
  .sector-label-U{color:rgba(255,255,255,.40)}
  .sector-chip{min-width:46px}
}


.undo-unlock{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  background:#3b1111;
  border:1px solid #991b1b;
  color:#fecaca;
  border-radius:8px;
  padding:8px;
  margin:8px 0;
}
.undo-unlock span{
  font-size:12px;
}
.undo-unlock b{
  color:#fff;
}
@media(max-width:700px){
  .undo-unlock{
    flex-direction:column;
    align-items:stretch;
  }
}


.undo-unlock small{
  color:#fecaca;
  opacity:.9;
}
.undo-unlock .danger{
  font-weight:700;
}


.townhall-quick{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  background:#2a2108;
  border:1px solid #ca8a04;
  border-radius:10px;
  padding:8px;
  margin:8px 0;
}
.townhall-quick b{
  display:block;
  color:#fde68a;
}
.townhall-quick span{
  display:block;
  color:#cbd5e1;
  font-size:12px;
}
@media(max-width:700px){
  .townhall-quick{
    flex-direction:column;
    align-items:stretch;
  }
}


.option-note{
  margin:4px 0 8px;
  padding:7px;
  background:#0b1220;
  border:1px dashed #475569;
  border-radius:8px;
}


/* Forward-time planner control */
.time-forward-form{
  background:#0b1220;
  border:1px dashed #475569;
  border-radius:10px;
  padding:8px;
  margin:8px 0 12px;
}

/* Drag/drop placement and movement */
.palette-card,
.mapbuilding{
  touch-action:none;
  cursor:grab;
  -webkit-user-drag:none;
  user-select:none;
}
.palette-card:active,
.mapbuilding:active{
  cursor:grabbing;
}
.drag-source{
  opacity:.55!important;
}
.drag-ghost{
  position:fixed;
  left:0;
  top:0;
  z-index:99999;
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
  border:2px dashed rgba(255,255,255,.9);
  border-radius:10px;
  background:rgba(249,115,22,.84);
  color:#fff;
  font-weight:900;
  box-shadow:0 12px 30px rgba(0,0,0,.45);
  transform:translate(-9999px,-9999px);
}
.mapcell.drop-target{
  outline:3px solid #f97316;
  outline-offset:-3px;
  background-color:rgba(249,115,22,.22)!important;
}
body.dragging-building{
  user-select:none;
}
body.dragging-building .gridmap{
  cursor:crosshair;
}
.gridmap{
  touch-action:none;
}


/* Click-to-carry placement mode */
.carry-ghost{
  position:fixed;
  left:0;
  top:0;
  z-index:99999;
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:58px;
  min-height:40px;
  padding:8px 10px;
  border:2px solid rgba(255,255,255,.85);
  border-radius:10px;
  background:rgba(6,182,212,.74);
  color:#fff;
  font-weight:900;
  box-shadow:0 12px 30px rgba(0,0,0,.45);
  transform:translate(-9999px,-9999px);
  text-shadow:0 1px 3px rgba(0,0,0,.7);
}
body.carrying-building{
  cursor:crosshair;
}
.mapcell.carry-target{
  outline:3px solid #06b6d4;
  outline-offset:-3px;
  background-color:rgba(6,182,212,.20)!important;
}
.palette-card.selected{
  outline:3px solid #06b6d4;
  outline-offset:2px;
}


/* FoE Helper import + impediment layer */
.import-box{
  background:#0b1220;
  border:1px solid #334155;
  border-radius:10px;
  padding:10px;
  margin:8px 0 16px;
}
.import-box textarea{
  width:100%;
  min-height:120px;
  resize:vertical;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:12px;
}
.import-box .warn{
  color:#fde68a;
}
.obstacle{
  z-index:6;
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
  background:repeating-linear-gradient(45deg, rgba(239,68,68,.42), rgba(239,68,68,.42) 4px, rgba(127,29,29,.52) 4px, rgba(127,29,29,.52) 8px);
  border:1px solid rgba(248,113,113,.8);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.45);
  color:rgba(255,255,255,.92);
  font-weight:900;
  text-shadow:0 1px 3px rgba(0,0,0,.9);
}
.obstacle span{
  opacity:.85;
}


.manual-sync-box{
  background:#111827;
  border:1px solid #f59e0b;
  border-radius:10px;
  padding:10px;
  margin:10px 0 14px;
  box-shadow:0 0 0 1px rgba(245,158,11,.15) inset;
}
.manual-sync-box h3{
  margin:0 0 6px;
  color:#fde68a;
  font-size:15px;
}
.manual-sync-box p{
  margin:6px 0;
  color:#d1d5db;
  font-size:13px;
  line-height:1.45;
}
.manual-sync-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(135px,1fr));
  gap:6px;
  margin:8px 0;
}
.manual-sync-grid span{
  background:#0b1220;
  border:1px solid #334155;
  border-radius:7px;
  padding:6px 8px;
  color:#e5e7eb;
  font-size:12px;
}


.main-city-import-box{
  background:#0f172a;
  border:1px solid #38bdf8;
  border-radius:10px;
  padding:10px;
  margin:8px 0 16px;
  box-shadow:0 0 0 1px rgba(56,189,248,.12) inset;
}
.main-city-import-box h3{
  margin:0 0 6px;
  color:#bae6fd;
  font-size:15px;
}
.main-city-import-box textarea{
  width:100%;
  min-height:105px;
  resize:vertical;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:12px;
}
.import-summary{
  margin-top:10px;
  border-top:1px solid #334155;
  padding-top:8px;
}


.auto-capacity-note{
  background:#0b1220;
  border:1px solid #334155;
  border-radius:8px;
  padding:8px;
  color:#e5e7eb;
  font-size:12px;
  line-height:1.45;
}
.auto-capacity-note b{
  color:#bae6fd;
}
.auto-capacity-note small{
  color:#94a3b8;
}


.support-options{
  border:1px solid #334155;
  background:#0b1220;
  border-radius:10px;
  padding:10px;
  margin:10px 0;
}
.support-options label{
  margin-bottom:8px;
}


.exact-goods-box{
  grid-column:1/-1;
  background:#0b1220;
  border:1px solid #334155;
  border-radius:10px;
  padding:10px;
  margin:6px 0;
}
.exact-goods-box>b{
  color:#bae6fd;
}
.exact-goods-box p{
  margin:4px 0 8px;
}
.goods-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(110px,1fr));
  gap:8px;
}
.goods-type-select{
  max-width:110px;
  min-width:90px;
  padding:4px;
  border-radius:6px;
}

.building.sell-preview{
  opacity:.45;
  filter:grayscale(.65);
  outline:3px solid #f43f5e;
  outline-offset:-5px;
}

.building.move-preview{
  outline:3px solid #38bdf8;
  outline-offset:-5px;
}
