:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--frame: #111820;--frame-2: #19232c;--ink: #1e201c;--muted: #6e675b;--paper: #f5ecd9;--paper-2: #fff8e9;--paper-3: #eadcc2;--line: rgba(50, 42, 31, .28);--green: #3f7650;--green-2: #81ad67;--blue: #2f6780;--red: #b34837;--orange: #c46b35;--gold: #d7aa49;--shadow: 0 18px 42px rgba(0, 0, 0, .34);--soft-shadow: 0 8px 18px rgba(35, 25, 15, .18);--radius: 8px}*{box-sizing:border-box}html,body,#root{min-width:320px;height:100vh;margin:0;overflow:hidden}body{background:radial-gradient(circle at top left,rgba(215,170,73,.18),transparent 30%),linear-gradient(135deg,#101720,#1c2831 55%,#111820);color:var(--ink)}button,input{font:inherit}button{border:0;cursor:pointer}button:focus-visible,input:focus-visible{outline:3px solid var(--gold);outline-offset:2px}h1,h2,h3,p{margin-top:0}.dashboard-shell{height:100vh;display:grid;grid-template-rows:92px minmax(0,1fr) 118px 40px;gap:8px;padding:8px;overflow:hidden;background:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:18px 18px}.app-header,.workspace-grid,.bottom-deck,.status-bar{width:min(1800px,100%);margin:0 auto}.app-header{display:grid;grid-template-columns:minmax(390px,1.1fr) minmax(430px,.95fr) minmax(340px,.82fr);gap:8px;align-items:stretch;min-height:0}.brand-block,.stat-board,.headline-card,.dashboard-card,.city-panel,.recent-strip,.sim-controls{background:linear-gradient(135deg,rgba(255,255,255,.42),transparent 34%),var(--paper);border:1px solid rgba(255,255,255,.52);box-shadow:var(--soft-shadow),inset 0 0 0 1px var(--line);border-radius:var(--radius)}.brand-block{display:grid;grid-template-columns:74px minmax(0,1fr);min-height:0;overflow:hidden}.town-crest{display:grid;place-items:center;position:relative;background:var(--frame);border-right:1px solid rgba(255,255,255,.16);color:var(--gold)}.town-crest img{position:absolute;bottom:7px;width:38px;image-rendering:pixelated}.brand-copy{align-self:center;display:grid;align-content:center;gap:1px;min-height:0;padding:5px 14px 6px;min-width:0}.kicker,.brand-copy p,.metric-card span,.headline-card span,.panel-title span,.section-heading h2,.side-rail span,.next-year-card span,.paper-preview-card span{margin:0;font-size:.75rem;line-height:1.1;letter-spacing:0;text-transform:uppercase;font-weight:850}.brand-copy .kicker{color:var(--ink);line-height:1}.brand-copy h1{margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(1.45rem,2vw,2.35rem);line-height:1.05;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;padding:0 0 3px}.brand-copy p:not(.kicker),.brand-meta span{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-meta{min-width:0;display:flex;align-items:center;gap:8px;overflow:hidden}.brand-meta span{min-width:0;font-size:.68rem;line-height:1.1;font-weight:850;text-transform:uppercase}.brand-meta span:first-child{flex:0 1 auto}.brand-meta span+span{flex:1 1 auto;color:var(--green)}.brand-meta span+span:before{content:"· ";color:var(--muted)}.stat-board{display:grid;grid-template-columns:repeat(5,1fr);align-items:center;padding:6px;gap:0}.metric-card{position:relative;display:grid;align-content:center;justify-items:center;min-height:74px;padding:6px;border-right:1px solid var(--line);text-align:center}.metric-card:last-child{border-right:0}.metric-card strong{margin-top:5px;font-size:1.35rem;line-height:1}.metric-card i{display:grid;place-items:center;margin-top:3px;width:22px;height:22px;color:var(--green)}.headline-card{display:grid;grid-template-columns:42px minmax(0,1fr) 24px;align-items:center;gap:9px;min-height:0;padding:8px 10px;color:var(--ink);text-align:left}.headline-card:before{content:"";width:36px;height:36px;image-rendering:pixelated;background:linear-gradient(#f7d98a 0 18%,transparent 18%),linear-gradient(90deg,transparent 0 30%,#222 30% 70%,transparent 70%),linear-gradient(#d85d35 0 100%);clip-path:polygon(43% 0,57% 0,67% 72%,90% 72%,90% 100%,10% 100%,10% 72%,33% 72%)}.headline-card span{grid-column:2;color:var(--red);align-self:end}.headline-card strong{grid-column:2;align-self:start;display:-webkit-box;overflow:hidden;font-size:.94rem;line-height:1.25;-webkit-line-clamp:2;-webkit-box-orient:vertical}.headline-card svg{grid-column:3;grid-row:1 / 3;color:var(--muted);justify-self:end}.workspace-grid{min-height:0;height:100%;display:grid;grid-template-columns:92px minmax(560px,1.55fr) minmax(430px,.9fr);gap:8px}.side-rail{display:grid;grid-template-rows:repeat(7,minmax(0,1fr)) 46px;min-height:0;gap:6px;padding:4px;background:#080e13c2;border:1px solid rgba(255,255,255,.1);border-radius:10px;box-shadow:var(--shadow)}.side-rail button,.next-year-card{display:grid;place-items:center;gap:5px;min-height:0;padding:5px 4px;border-radius:7px;color:#f5ecd9;background:linear-gradient(180deg,#1c2831,#121b22);box-shadow:inset 0 0 0 1px #ffffff14}.side-rail button.active{color:#1e201c;background:linear-gradient(180deg,#f4d878,#d6a73d);box-shadow:inset 0 0 0 2px #ffe99c,0 0 0 1px #a97d25}.side-rail svg{color:currentColor}.next-year-card{margin-top:0;min-height:0;color:#d6e2d2}.next-year-card strong{color:var(--gold);font-size:1.1rem}.city-column{min-width:0;min-height:0}.city-panel{height:100%;min-height:0;overflow:hidden;background:#101820;color:var(--paper);box-shadow:var(--shadow)}.panel-title,.section-heading{display:flex;align-items:center;gap:8px;min-height:34px;padding:7px 10px;color:var(--ink);border-bottom:1px solid var(--line)}.panel-title.dark{justify-content:space-between;color:var(--paper);background:linear-gradient(180deg,#1b2730,#141e26);border-bottom-color:#ffffff1f}.panel-title.dark>div:first-child{min-width:0}.panel-title h2,.section-heading h2{margin:0;font-size:.86rem}.panel-title.dark span{color:var(--paper)}.panel-title.dark strong{display:block;margin-top:2px;color:#a8b5ad;font-size:.78rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.panel-title.dark b{display:flex;align-items:center;gap:7px;font-size:.78rem;text-transform:uppercase}.panel-title.dark b i{width:7px;height:7px;border-radius:50%;background:#ff6b4b;box-shadow:0 0 12px #ff6b4b}.camera-header-controls{display:flex;align-items:center;justify-content:end;gap:10px;min-width:0;margin-left:12px}.camera-zone-tabs{display:flex;align-items:center;gap:4px;max-width:min(500px,40vw);overflow:hidden}.camera-zone-tabs button{min-width:0;height:24px;padding:0 8px;border-radius:5px;color:#d5ded7;background:#ffffff0f;box-shadow:inset 0 0 0 1px #ffffff1a;font-size:.68rem;font-weight:850;text-transform:uppercase;white-space:nowrap}.camera-zone-tabs button.active{color:#15170f;background:var(--gold)}.pixel-city-map{position:relative;height:calc(100% - 34px);min-height:0;overflow:hidden;image-rendering:pixelated;background:radial-gradient(circle at 55% 52%,rgba(159,204,122,.36) 0 11%,transparent 12%),#6fa766}.pixel-city-map.map-school-street{background:radial-gradient(circle at 15% 24%,rgba(192,217,128,.34) 0 13%,transparent 14%),linear-gradient(90deg,rgba(255,255,255,.06) 0 50%,transparent 50%),#70a766}.pixel-city-map.map-market-corner{background:radial-gradient(circle at 49% 54%,rgba(227,199,116,.26) 0 11%,transparent 12%),radial-gradient(circle at 83% 26%,rgba(126,189,103,.5) 0 9%,transparent 10%),#75aa63}.pixel-city-map.map-industrial-road{background:radial-gradient(circle at 13% 36%,rgba(174,160,113,.2) 0 12%,transparent 13%),radial-gradient(circle at 74% 70%,rgba(86,106,94,.28) 0 15%,transparent 16%),#6b8f63}.map-scene{position:absolute;inset:0;transform:scale(var(--map-scale, 1));transform-origin:50% 54%;transition:transform .16s ease;isolation:isolate}.pixel-city-map:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:32px 32px;opacity:.26;pointer-events:none}.road{position:absolute;z-index:1;background:#48515a;box-shadow:inset 0 0 0 3px #303840}.road-v{top:0;bottom:0;width:7%}.road-v-left{left:31%}.road-v-right{left:63%}.road-h{left:0;right:0;height:12%}.road-h-top{top:34%}.road-h-mid{top:58%}.road-h-bottom{top:82%}.road:after{content:"";position:absolute;inset:50% 0 auto;height:3px;background:repeating-linear-gradient(90deg,transparent 0 24px,#d7d5be 24px 38px,transparent 38px 62px)}.road-v:after{inset:0 auto 0 50%;width:3px;height:auto;background:repeating-linear-gradient(180deg,transparent 0 24px,#d7d5be 24px 38px,transparent 38px 62px)}.crosswalk{position:absolute;z-index:2;width:clamp(48px,5vw,68px);height:clamp(18px,1.8vw,26px);background:repeating-linear-gradient(90deg,#f4f0d8 0 8px,transparent 8px 16px)}.cw-1{left:31.4%;top:39%}.cw-2{left:63.4%;top:63%}.cw-3{left:31.4%;top:87%}.park-block{position:absolute;z-index:3;display:grid;place-items:center;border:4px solid rgba(63,104,58,.8);background:#7ebd67;box-shadow:inset 0 0 0 4px #ffffff29,0 8px #0000002e}.park-block span{position:absolute;bottom:6px;padding:3px 6px;background:#f5ecd9e6;color:var(--ink);font-size:.68rem;font-weight:900;text-transform:uppercase}.fountain img{width:86px}.kenney-tree{position:absolute;z-index:4;width:58px;transform:translate(-50%,-50%);filter:drop-shadow(0 6px 0 rgba(0,0,0,.18))}.map-building{position:absolute;z-index:5;width:clamp(108px,8.9vw,148px);height:clamp(78px,6.5vw,104px);transform:translate(-50%,-50%);display:grid;place-items:end center;padding-bottom:14px;border:4px solid #202624;border-bottom-width:9px;background:#d8b178;border-radius:2px 2px 5px 5px;box-shadow:0 0 0 8px #4a564c3d,inset 8px 0 #ffffff2e,inset -8px 0 #0000001f,0 11px #00000042;image-rendering:pixelated}.map-building:after{content:"";position:absolute;left:-10px;right:-10px;bottom:-14px;height:14px;z-index:-1;background:repeating-linear-gradient(90deg,#6f7a72 0 18px,#626d66 18px 36px);border:2px solid rgba(32,38,36,.45);box-shadow:0 5px #00000029}.map-building .roof{position:absolute;top:-22px;left:-4px;right:-4px;height:34px;background:linear-gradient(#454a50 0 44%,#272d31 45% 100%);border:4px solid #202624;border-bottom:0;clip-path:polygon(0 100%,50% 0,100% 100%);box-shadow:inset 0 -8px #0000001f}.map-building.gable{clip-path:polygon(0 15%,14% 15%,50% 0,86% 15%,100% 15%,100% 100%,0 100%)}.map-building.gable .roof{top:-16px;left:-10px;right:-10px;height:48px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 7px,transparent 7px 14px),linear-gradient(#41464b 0 42%,#22292e 43% 100%)}.map-building.civic .roof{top:-19px;left:-10px;right:-10px;height:25px;clip-path:polygon(0 100%,50% 0,100% 100%);background:linear-gradient(#eff0dd 0 50%,#b7baaa 51% 100%);border:4px solid #202624}.map-building.civic{clip-path:none}.map-building.civic .roof:after{content:"";position:absolute;left:50%;top:5px;width:10px;height:10px;transform:translate(-50%);border-radius:50%;background:#46535c;box-shadow:inset 0 0 0 3px #f7e7bd}.map-building .facade-trim{position:absolute;pointer-events:none;inset:auto 12px 18px;height:8px;background:#20262442;box-shadow:0 -36px #ffffff2e}.map-building .facade-trim:before,.map-building .facade-trim:after{content:"";position:absolute;top:-23px;width:15px;height:16px;background:#ffe09d;border:2px solid rgba(32,38,36,.5)}.map-building .facade-trim:before{left:8px}.map-building .facade-trim:after{right:8px}.map-building.awning .roof,.map-building.storefront .roof{top:-9px;left:-7px;right:-7px;height:24px;clip-path:none;background:repeating-linear-gradient(90deg,#f7e7bd 0 13px,#b34837 13px 26px);border:4px solid #202624;box-shadow:0 7px #0000002e}.map-building.awning,.map-building.storefront,.map-building.station{clip-path:polygon(0 8%,100% 8%,100% 100%,0 100%)}.map-building.station .roof{top:-13px;left:-8px;right:-8px;height:27px;clip-path:none;background:linear-gradient(#375f73,#203d4d);border:4px solid #202624}.map-building .windows{position:absolute;top:25px;left:18px;width:13px;height:14px;background:#ffe09d;border:1px solid rgba(32,38,36,.36);box-shadow:32px 0 #ffe09d,64px 0 #ffe09d,0 25px #ffe09d,64px 25px #ffe09d}.map-building .door{position:absolute;bottom:9px;left:50%;width:19px;height:30px;transform:translate(-50%);background:#4b3123;border:3px solid #202624;box-shadow:inset 5px 0 #ffffff1a}.map-building .door:after{content:"";position:absolute;right:3px;top:12px;width:3px;height:3px;background:#f7e7bd}.map-building strong{position:relative;z-index:6;max-width:calc(100% - 18px);padding:4px 5px;background:#f7e7bd;color:#1c211f;border:2px solid #252525;font-size:.66rem;line-height:1;text-transform:uppercase;text-align:center;white-space:nowrap;transform:translateY(4px)}.map-building.stone{background:#c9c8b7}.map-building.brick{background:#a7694d}.map-building.warm{background:#c08345}.map-building.green{background:#799c61}.map-building.blue{background:#5d8ca2}.map-building.red{background:#b56545}.map-building.aqua{background:#6aa0a6}.map-building.brown{background:#8f6a42}.map-building.town-hall{width:clamp(126px,10vw,168px);height:clamp(84px,7vw,112px);background:linear-gradient(90deg,#b9baab 0 16%,#e6dfc8 17% 83%,#b9baab 84% 100%)}.map-building.town-hall .facade-trim{left:17px;right:17px;bottom:18px;height:44px;background:repeating-linear-gradient(90deg,#f4ecd4 0 8px,transparent 8px 20px);box-shadow:0 -48px #d9d2bd}.map-building.town-hall .facade-trim:before,.map-building.town-hall .facade-trim:after{top:-20px;width:12px;height:38px;background:#f7efd8;border:0;box-shadow:25px 0 #f7efd8,50px 0 #f7efd8}.map-building.town-hall .windows{top:28px;left:27px;width:14px;height:15px;box-shadow:35px 0 #ffe09d,70px 0 #ffe09d}.map-building.library .roof,.map-building.school .roof{top:-25px;height:39px}.map-building.library .facade-trim,.map-building.school .facade-trim{inset:11px 15px auto;height:10px;background:#2d201b52;box-shadow:0 44px #ffffff29}.map-building.library{background:linear-gradient(90deg,transparent 0 16%,rgba(255,255,255,.08) 16% 20%,transparent 20% 80%,rgba(0,0,0,.1) 80% 84%,transparent 84%),#a7694d}.map-building.school{background:linear-gradient(90deg,transparent 0 12%,rgba(255,255,255,.12) 12% 18%,transparent 18% 82%,rgba(0,0,0,.12) 82% 88%,transparent 88%),#b56545}.map-building.cafe,.map-building.supermarket,.map-building.hardware{height:clamp(78px,6vw,96px)}.map-building.cafe .facade-trim,.map-building.supermarket .facade-trim,.map-building.hardware .facade-trim,.map-building.laundromat .facade-trim{left:13px;right:13px;bottom:21px;height:24px;background:linear-gradient(90deg,#3f5b5eb8 0 43%,#ffe09ddb 44% 56%,#3f5b5eb8 57% 100%);border:2px solid rgba(32,38,36,.55);box-shadow:none}.map-building.cafe .windows,.map-building.supermarket .windows,.map-building.hardware .windows,.map-building.laundromat .windows{top:34px;left:17px;width:24px;height:22px;background:#b8ded7;box-shadow:32px 0 #b8ded7,64px 0 #b8ded7}.map-building.cafe strong,.map-building.supermarket strong,.map-building.hardware strong,.map-building.laundromat strong{transform:translateY(-1px)}.map-building.bus-station{width:clamp(120px,9.4vw,158px);height:clamp(70px,5.7vw,90px)}.map-building.bus-station .windows{top:25px;left:22px;width:18px;height:22px;background:#b6e1d5;box-shadow:26px 0 #b6e1d5,52px 0 #b6e1d5,78px 0 #b6e1d5}.map-building.bus-station .door{display:none}.map-building.laundromat{width:clamp(112px,8.7vw,144px);background:#79a9ad}.map-building.sprite-building,.map-building.sprite-building.gable,.map-building.sprite-building.awning,.map-building.sprite-building.storefront,.map-building.sprite-building.station{width:clamp(108px,8.6vw,150px);height:clamp(82px,6.8vw,118px);padding:0;border:0;border-radius:0;background:transparent;box-shadow:none;clip-path:none;display:block;overflow:visible}.map-building.sprite-building:after{left:8%;right:8%;bottom:-9px;height:16px;z-index:-1;border:0;border-radius:50%;background:#18211f47;box-shadow:none}.map-building.sprite-building .building-sprite{position:absolute;left:50%;bottom:8px;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;transform:translate(-50%);image-rendering:auto;filter:drop-shadow(0 8px 0 rgba(0,0,0,.24))}.map-building.sprite-building strong{position:absolute;left:50%;bottom:10px;transform:translate(-50%);max-width:86%;z-index:4}.map-building.sprite-building.town-hall{width:clamp(126px,9.8vw,172px);height:clamp(92px,7.2vw,128px)}.map-building.sprite-building.bus-station{width:clamp(78px,6.2vw,108px);height:clamp(62px,5vw,88px)}.map-building.sprite-building.school,.map-building.sprite-building.library{width:clamp(100px,8vw,138px)}.map-building.sprite-building.market,.map-building.sprite-building.cafe{width:clamp(106px,8.4vw,146px)}.map-building.sprite-building.laundromat,.map-building.sprite-building.hardware{width:clamp(92px,7.2vw,124px);height:clamp(74px,5.8vw,102px)}.vehicle,.town-person,.street-prop{position:absolute;z-index:8;image-rendering:pixelated;filter:drop-shadow(0 4px 0 rgba(0,0,0,.25))}.vehicle{width:clamp(42px,4vw,58px)}.vehicle.bus{left:67%;top:38%}.vehicle.taxi{left:18%;top:60%}.vehicle.red-car{left:84%;top:83%}.vehicle.blue-car{left:51%;top:63%}.street-prop{width:27px}.prop-light-one{left:56%;top:32%}.prop-light-two{left:79%;top:64%}.prop-sign{left:28%;top:41%}.town-person{z-index:14;width:clamp(21px,1.55vw,29px);aspect-ratio:1;background:transparent;box-shadow:none;transform:translate(-50%,-50%);animation:citizen-walk 8.5s ease-in-out infinite}.town-person img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;image-rendering:pixelated;opacity:0;filter:hue-rotate(var(--citizen-hue, 0deg)) saturate(var(--citizen-sat, 1.05)) brightness(var(--citizen-brightness, 1)) drop-shadow(0 3px 0 rgba(0,0,0,.45));animation:citizen-facing 8.5s step-end infinite;animation-delay:inherit}.town-person.phase-a-north .dir-north,.town-person.phase-a-south .dir-south,.town-person.phase-a-east .dir-east,.town-person.phase-a-west .dir-west{--face-a: 1}.town-person.phase-b-north .dir-north,.town-person.phase-b-south .dir-south,.town-person.phase-b-east .dir-east,.town-person.phase-b-west .dir-west{--face-b: 1}.town-person.phase-c-north .dir-north,.town-person.phase-c-south .dir-south,.town-person.phase-c-east .dir-east,.town-person.phase-c-west .dir-west{--face-c: 1}@keyframes citizen-walk{0%,to{translate:calc(var(--walk-x, 12px) * -.45) 0}45%{translate:var(--walk-x, 12px) var(--walk-y, -4px)}70%{translate:calc(var(--walk-x, 12px) * .35) calc(var(--walk-y, -4px) * -.5)}}@keyframes citizen-facing{0%,44%{opacity:var(--face-a, 0)}45%,69%{opacity:var(--face-b, 0)}70%,to{opacity:var(--face-c, 0)}}.speech-bubble{position:absolute;right:21%;top:42%;z-index:12;width:min(230px,32%);padding:12px;border:3px solid #1c211f;border-radius:8px;background:#fff8e9;color:#1c211f;font-size:.86rem;font-weight:750;line-height:1.25;box-shadow:0 8px #00000047}.speech-bubble:after{content:"";position:absolute;left:22px;bottom:-13px;border-width:13px 10px 0;border-style:solid;border-color:#1c211f transparent transparent}.city-date-strip,.map-tools{position:absolute;z-index:20;bottom:14px;display:flex;align-items:center;gap:8px}.city-date-strip{left:14px;padding:8px 12px;border-radius:6px;background:#111820eb;box-shadow:inset 0 0 0 1px #ffffff29;color:#d7e6d2;font-size:.76rem;text-transform:uppercase;font-weight:850}.city-date-strip strong{color:var(--gold)}.map-tools{right:12px;padding:4px;border-radius:8px;background:#0b12189e;box-shadow:inset 0 0 0 1px #ffffff14;backdrop-filter:blur(2px)}.map-tools button{display:grid;place-items:center;width:30px;height:30px;border-radius:5px;color:var(--paper);background:#111820e0;box-shadow:inset 0 0 0 1px #ffffff29}.map-tools button:hover{color:var(--gold)}.info-column{min-width:0;min-height:0;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:8px}.dashboard-card{min-width:0;min-height:0;overflow:hidden;display:flex;flex-direction:column}.list-stack{flex:1 1 auto;min-height:0;overflow:hidden;scrollbar-width:thin;padding:5px 10px 4px}.chatter-row,.story-row,.citizen-row{display:grid;gap:10px;align-items:center;min-width:0;padding:7px 0;border-bottom:1px solid var(--line)}.chatter-row{grid-template-columns:32px minmax(0,1fr) max-content}.chatter-row img,.citizen-row img{width:32px;image-rendering:pixelated;filter:hue-rotate(var(--citizen-hue, 0deg)) saturate(var(--citizen-sat, 1)) brightness(var(--citizen-brightness, 1))}.chatter-row p,.story-row p,.citizen-row p,.paper-preview-card p{margin:0;color:#292b26;font-size:.88rem;line-height:1.25;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow-wrap:anywhere}.chatter-row span,.story-row span,.citizen-row span{color:var(--muted);font-size:.68rem;font-weight:800;text-transform:uppercase}.tone-ominous p,.story-row span{color:var(--red)}.story-row{grid-template-columns:minmax(0,1fr) 18px;align-items:center;width:100%;text-align:left;background:transparent;border-top:0;border-right:0;border-left:0;border-radius:0;box-shadow:none;cursor:pointer}.story-row:hover{background:#dcb1401f}.story-row strong,.citizen-row b,.paper-preview-card strong{display:block;min-width:0;margin-bottom:4px;color:var(--ink);font-size:.88rem;line-height:1.2;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow-wrap:anywhere}.story-row>div,.citizen-row>div{min-width:0}.citizen-row{grid-template-columns:48px 1fr}.citizen-row img{width:44px;padding:5px;border-radius:6px;background:#cfb284;box-shadow:inset 0 0 0 2px #241c152e}.text-link{align-self:flex-start;margin:auto 10px 8px;padding:4px 0;background:transparent;color:var(--ink);font-size:.82rem;font-weight:850}.text-link:after{content:" ->"}.empty{margin:12px 0;color:var(--muted);font-size:.9rem}.paper-preview-card{margin:10px;padding:0;text-align:left;background:transparent}.paper-preview-card span,.paper-preview-card strong{color:var(--ink)}.mini-newspaper{margin-top:7px;min-height:78px;padding:8px;border:1px solid rgba(43,36,26,.24);border-radius:6px;background:linear-gradient(90deg,rgba(54,42,22,.05) 1px,transparent 1px),linear-gradient(rgba(54,42,22,.05) 1px,transparent 1px),#f8efd9;background-size:12px 12px;box-shadow:inset 0 0 0 3px #ffffff52;font-family:Georgia,Times New Roman,serif}.mini-newspaper b{display:block;margin-bottom:8px;padding-bottom:5px;border-bottom:3px double rgba(43,36,26,.42);color:#3b2f1f;font-size:.95rem}.bottom-deck{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:8px;min-height:0}.recent-strip,.sim-controls{min-width:0}.recent-cards{display:grid;grid-template-columns:repeat(6,minmax(135px,1fr));gap:7px;padding:7px 10px 8px}.happening-card{min-width:0;height:76px;display:grid;grid-template-columns:28px minmax(0,1fr);grid-template-rows:minmax(0,1fr) auto;gap:6px 8px;align-content:stretch;padding:7px;border-radius:6px;background:#fff8e9c2;box-shadow:inset 0 0 0 1px var(--line)}.happening-card img{width:24px;image-rendering:pixelated;align-self:start;filter:hue-rotate(var(--citizen-hue, 0deg)) saturate(var(--citizen-sat, 1)) brightness(var(--citizen-brightness, 1))}.happening-card p{margin:0;min-width:0;font-size:.76rem;line-height:1.2;display:-webkit-box;overflow:hidden;-webkit-line-clamp:3;-webkit-box-orient:vertical}.happening-card span{grid-column:2;align-self:end;color:var(--muted);font-size:.74rem;font-weight:850;line-height:1}.control-grid{display:grid;grid-template-columns:1.4fr repeat(3,.7fr);gap:7px;padding:7px 10px 8px}.control-grid button,.footer-actions button,.file-button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:6px 9px;border-radius:6px;background:#efe2c7;color:var(--ink);font-weight:900;box-shadow:inset 0 0 0 1px #30271b47,0 3px #30271b3d}.control-grid button:nth-child(n+5){background:#456f4b;color:#fff6df}.control-grid .primary-control{background:#2f679c;color:#fff}.control-grid .selected{background:var(--gold)}.status-bar{min-height:0;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;padding:5px 10px;color:#d7e0dd;background:#080e13c7;border:1px solid rgba(255,255,255,.1);border-radius:10px}.footer-actions{display:flex;gap:8px}.footer-actions button,.file-button{min-height:28px;background:#ffffff0f;color:#f5ecd9;box-shadow:inset 0 0 0 1px #ffffff1f}.file-button input{display:none}.save-status{display:flex;align-items:center;gap:9px}.status-dot{width:9px;height:9px;border-radius:50%;background:#67c66c;box-shadow:0 0 10px #67c66c}.version-line{display:flex;flex-wrap:wrap;justify-content:end;gap:10px;color:#aab4b0}.version-line span+span:before{content:"|";margin-right:10px;color:#ffffff40}.modal-backdrop{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:24px;background:#05090cb8}.newspaper{position:relative;width:min(1080px,96vw);max-height:92vh;overflow:auto;padding:26px;color:#17140f;border-radius:4px;background:radial-gradient(circle at 20% 20%,rgba(92,61,25,.08),transparent 22%),radial-gradient(circle at 70% 35%,rgba(92,61,25,.06),transparent 26%),linear-gradient(90deg,rgba(39,28,15,.04) 1px,transparent 1px),#f7ecd2;background-size:auto,auto,18px 18px,auto;box-shadow:0 26px 70px #0000008a,inset 0 0 0 1px #2b211440;font-family:Georgia,Times New Roman,serif}.paper-actions{position:sticky;top:0;z-index:5;float:right;display:flex;gap:8px}.paper-actions button{display:grid;place-items:center;width:40px;height:40px;border-radius:4px;background:#f7ecd2;color:#17140f;box-shadow:inset 0 0 0 2px #211a12b8}.paper-masthead{text-align:center;padding:6px 72px 18px;border-bottom:5px double rgba(33,26,18,.75)}.paper-masthead p{margin-bottom:5px;font-size:1.15rem;font-weight:900;text-transform:uppercase}.paper-masthead span{display:block;margin-bottom:14px;color:#69543a;font-size:.9rem;text-transform:uppercase}.paper-masthead h1{max-width:860px;margin:0 auto 12px;font-size:clamp(2.5rem,7vw,5.8rem);line-height:.9}.paper-masthead h2{max-width:760px;margin:0 auto;color:#4d3f2d;font-size:1.1rem;font-weight:500}.paper-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.75fr);gap:22px;padding:18px 0;border-bottom:3px solid rgba(33,26,18,.64)}.paper-lead{column-count:2;column-gap:22px;font-size:1.02rem;line-height:1.5}.paper-lead p:first-child:first-letter{float:left;margin:6px 8px 0 0;font-size:4.4rem;line-height:.72;font-weight:900}.paper-sidebar{display:grid;gap:12px}.paper-sidebar section,.paper-feature-row article{padding:12px;background:#fff8e980;box-shadow:inset 0 0 0 1px #2b211433}.newspaper h3{margin:0 0 8px;padding-bottom:5px;border-bottom:2px solid rgba(33,26,18,.65);font-size:.95rem;text-transform:uppercase}.newspaper p{margin-bottom:10px;line-height:1.45}.unresolved-box{border-left:5px solid var(--red)}.paper-feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding-top:16px}.local-ad{border:2px dashed rgba(33,26,18,.46)}.compact-modal{padding:18px}.detail-modal{width:min(980px,94vw);max-height:86vh;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;border-radius:10px;background:var(--paper);color:var(--ink);box-shadow:0 24px 70px #0000008c,inset 0 0 0 1px var(--line)}.detail-modal>header{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:70px;padding:12px 16px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#fff8e9,#efe0c4)}.detail-modal>header span{color:var(--muted);font-size:.72rem;font-weight:900;text-transform:uppercase}.detail-modal>header h2{margin:2px 0 0;font-family:Georgia,Times New Roman,serif;font-size:2rem;line-height:1}.detail-modal>header button,.settings-actions button,.settings-actions .file-button{min-height:36px;padding:7px 12px;border-radius:6px;background:var(--frame);color:var(--paper);font-weight:900}.detail-modal-body{min-height:0;overflow:auto;padding:14px}.modal-list{display:grid;gap:10px}.modal-list-row,.modal-story-card,.modal-citizen-card,.modal-place-card{min-width:0;display:grid;gap:10px;padding:12px;border-radius:8px;background:#fff8e9b8;box-shadow:inset 0 0 0 1px var(--line);color:var(--ink);text-align:left}.modal-list-row{grid-template-columns:1fr auto;align-items:center}.modal-list-row strong,.modal-story-card strong,.modal-citizen-card strong,.modal-place-card strong{display:block;margin-bottom:3px}.modal-list-row span,.modal-story-card span,.modal-citizen-card span,.modal-place-card span{color:var(--muted);font-size:.76rem;font-weight:850;text-transform:uppercase}.modal-list-row p,.modal-story-card p,.modal-citizen-card p,.modal-place-card p,.settings-stack p{margin:4px 0 0;color:#3b372e;line-height:1.35}.modal-grid-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}.modal-section{display:grid;gap:8px}.modal-section h3{margin:8px 0 0;color:var(--ink);font-size:.9rem;text-transform:uppercase}.archive-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.archive-summary-grid article{min-width:0;padding:10px;border-radius:8px;background:#fff8e9bf;box-shadow:inset 0 0 0 1px var(--line)}.archive-summary-grid span{color:var(--muted);font-size:.7rem;font-weight:850;text-transform:uppercase}.archive-summary-grid strong{display:block;margin:4px 0}.archive-summary-grid p{margin:0;color:#3b372e;line-height:1.3}.modal-citizen-card,.modal-place-card{grid-template-columns:44px 1fr;align-items:center}.modal-citizen-card img{width:38px;image-rendering:pixelated;padding:5px;border-radius:6px;background:#cfb284;filter:hue-rotate(var(--citizen-hue, 0deg)) saturate(var(--citizen-sat, 1)) brightness(var(--citizen-brightness, 1))}.modal-place-card svg{color:var(--green)}.stats-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(140px,1fr));gap:10px}.stats-detail-grid .metric-card{min-height:112px;border:0;border-radius:8px;background:#fff8e9b8;box-shadow:inset 0 0 0 1px var(--line)}.settings-stack{display:grid;gap:12px}.settings-actions{display:flex;flex-wrap:wrap;gap:8px}.setup-screen{height:100vh;display:grid;grid-template-columns:minmax(620px,1.15fr) minmax(420px,.85fr);gap:14px;padding:14px;overflow:hidden;background:radial-gradient(circle at 18% 12%,rgba(215,170,73,.16),transparent 28%),linear-gradient(135deg,#101720,#1a2630)}.setup-city,.setup-form{border-radius:var(--radius);background:var(--paper);box-shadow:var(--shadow),inset 0 0 0 1px #ffffff61;overflow:hidden}.setup-city{position:relative;min-height:0;background:linear-gradient(90deg,transparent 0 47%,#3f4a52 47% 55%,transparent 55%),linear-gradient(transparent 0 36%,#3f4a52 36% 44%,transparent 44% 67%,#3f4a52 67% 75%,transparent 75%),#75a86a;border:1px solid rgba(255,255,255,.12)}.setup-city:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:34px 34px;opacity:.22;pointer-events:none}.setup-preview-header{position:absolute;top:14px;left:14px;z-index:20;display:grid;gap:4px;padding:10px 12px;border-radius:8px;background:#111820e6;color:var(--paper);box-shadow:inset 0 0 0 1px #ffffff1f}.setup-preview-header span{display:flex;align-items:center;gap:7px;color:#d7e0dd;font-size:.72rem;font-weight:900;text-transform:uppercase}.setup-preview-header i{width:7px;height:7px;border-radius:50%;background:#ff6b4b;box-shadow:0 0 12px #ff6b4b}.setup-preview-header strong{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:Georgia,Times New Roman,serif;font-size:clamp(1.8rem,3vw,3rem);line-height:1}.setup-road{position:absolute;z-index:1;background:#3f4a52;box-shadow:inset 0 0 0 3px #27313a}.setup-road:after{content:"";position:absolute;inset:50% 0 auto;height:3px;background:repeating-linear-gradient(90deg,transparent 0 24px,#e6dfc7 24px 38px,transparent 38px 62px)}.setup-road.road-a{left:0;right:0;top:37%;height:70px}.setup-road.road-b{left:0;right:0;top:69%;height:70px}.setup-road.road-c{top:0;bottom:0;left:50%;width:76px}.setup-road.road-c:after{inset:0 auto 0 50%;width:3px;height:auto;background:repeating-linear-gradient(180deg,transparent 0 24px,#e6dfc7 24px 38px,transparent 38px 62px)}.setup-plaza{position:absolute;left:44%;top:48%;z-index:6;width:18%;min-width:150px;height:19%;display:grid;place-items:center;border:4px solid rgba(63,104,58,.8);background:#83bd6f;box-shadow:inset 0 0 0 4px #ffffff29,0 8px #0000002e;transform:translate(-50%,-50%)}.setup-plaza img{width:78px;image-rendering:pixelated}.setup-plaza span{position:absolute;bottom:7px;padding:3px 7px;border-radius:4px;background:#fff8e9e6;font-size:.7rem;font-weight:900;text-transform:uppercase}.setup-building{position:absolute;z-index:8;width:clamp(112px,10vw,154px);height:clamp(84px,7vw,112px);transform:translate(-50%,-50%);display:grid;place-items:end center;padding-bottom:13px;border:4px solid #202522;border-bottom-width:8px;background:#c98654;border-radius:2px 2px 5px 5px;box-shadow:0 0 0 8px #4a564c38,inset 8px 0 #ffffff2e,inset -8px 0 #0000001f,0 10px #0000003d;clip-path:polygon(0 12%,14% 12%,50% 0,86% 12%,100% 12%,100% 100%,0 100%)}.setup-building-roof{position:absolute;top:-14px;left:-8px;right:-8px;height:42px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 7px,transparent 7px 14px),linear-gradient(#41464b 0 42%,#22292e 43% 100%);border:4px solid #202522;border-bottom:0;clip-path:polygon(0 100%,50% 0,100% 100%)}.setup-building-detail{position:absolute;top:30px;left:18px;width:14px;height:14px;background:#ffe09d;box-shadow:34px 0 #ffe09d,68px 0 #ffe09d,0 24px #ffe09d,68px 24px #ffe09d}.setup-building-detail:before{content:"";position:absolute;left:34px;top:28px;width:20px;height:28px;background:#4b3123;border:3px solid #202522}.setup-building span{position:relative;z-index:3;padding:4px 6px;border:2px solid #252525;background:#f7e7bd;font-size:.7rem;font-weight:900;text-transform:uppercase;white-space:nowrap}.setup-building.stone{clip-path:none;background:linear-gradient(90deg,#b9baab 0 16%,#e6dfc8 17% 83%,#b9baab 84% 100%)}.setup-building.stone .setup-building-roof{top:-18px;height:28px;background:linear-gradient(#eff0dd 0 50%,#b7baaa 51% 100%)}.setup-building.brick{background:#a7694d}.setup-building.warm,.setup-building.green,.setup-building.blue{clip-path:polygon(0 8%,100% 8%,100% 100%,0 100%)}.setup-building.warm{background:#c08345}.setup-building.green{background:#799c61}.setup-building.blue{background:#5d8ca2}.setup-building.warm .setup-building-roof,.setup-building.green .setup-building-roof{top:-8px;height:24px;clip-path:none;background:repeating-linear-gradient(90deg,#f7e7bd 0 13px,#b34837 13px 26px)}.setup-building.blue .setup-building-roof{top:-11px;height:27px;clip-path:none;background:linear-gradient(#375f73,#203d4d)}.setup-building:has(.setup-building-sprite){width:clamp(112px,9.4vw,154px);height:clamp(88px,7.2vw,124px);padding:0;border:0;background:transparent;box-shadow:none;clip-path:none;display:block}.setup-building:has(.setup-building-sprite):before,.setup-building:has(.setup-building-sprite):after{content:none}.setup-building-sprite{position:absolute;left:50%;bottom:8px;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;transform:translate(-50%);image-rendering:auto;filter:drop-shadow(0 9px 0 rgba(0,0,0,.24))}.setup-building:has(.setup-building-sprite) span{position:absolute;left:50%;bottom:12px;transform:translate(-50%);z-index:4}.setup-tree,.setup-vehicle,.preview-citizen{position:absolute;z-index:10;image-rendering:pixelated;filter:drop-shadow(0 5px 0 rgba(0,0,0,.22))}.setup-tree{width:clamp(44px,4.5vw,66px);transform:translate(-50%,-50%)}.setup-vehicle{width:clamp(48px,4.4vw,70px)}.setup-bus{left:56%;top:39%}.setup-car{left:28%;top:71%}.preview-citizen{width:27px;background:transparent;box-shadow:none;filter:hue-rotate(var(--citizen-hue, 0deg)) saturate(var(--citizen-sat, 1.05)) drop-shadow(0 3px 0 rgba(0,0,0,.45));animation:previewCitizenWalk 8s ease-in-out infinite}@keyframes previewCitizenWalk{0%,to{translate:-7px 0}50%{translate:9px -5px}}.preview-feed{position:absolute;left:18px;right:18px;bottom:16px;display:flex;gap:8px;z-index:20}.preview-feed span{flex:1;min-width:0;padding:9px 10px;border-radius:6px;background:var(--paper-2);color:var(--ink);font-size:.86rem;font-weight:850;box-shadow:inset 0 0 0 1px var(--line)}.setup-form{align-self:center;display:grid;gap:12px;padding:22px;max-width:560px;justify-self:center;width:100%}.setup-form-header{display:grid;gap:5px;margin-bottom:2px}.setup-form-header span,.tone-label{display:flex;align-items:center;gap:7px;color:var(--green);font-size:.78rem;font-weight:900;text-transform:uppercase}.setup-form h1{margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(2.3rem,4vw,4rem);line-height:.92}.setup-form-header p{margin:0;color:var(--muted);font-weight:750}.randomize-town{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:6px;background:#1a2630;color:var(--paper);font-weight:900;box-shadow:inset 0 0 0 1px #ffffff1a}.setup-form label{display:grid;gap:5px;font-weight:850}.setup-form label span{font-size:.82rem;text-transform:uppercase;color:var(--ink)}.setup-form input{width:100%;min-height:42px;border:0;border-radius:6px;background:#fff8e9;color:var(--ink);padding:10px 12px;box-shadow:inset 0 0 0 1px var(--line)}.segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.segmented button,.setup-form .primary{min-height:50px;border-radius:6px;background:#efe2c7;color:var(--ink);font-weight:900;box-shadow:inset 0 0 0 1px var(--line),0 4px #231c1238}.segmented button{display:grid;gap:4px;align-content:center;padding:8px;text-align:center}.segmented button span{color:var(--muted);font-size:.68rem;line-height:1.15}.setup-form .primary{display:inline-flex;align-items:center;justify-content:center;gap:8px}.segmented button.active,.setup-form .primary{background:var(--gold)}@media(max-width:1180px){.app-header,.workspace-grid,.bottom-deck{grid-template-columns:1fr}.workspace-grid{grid-template-columns:96px minmax(0,1fr)}.info-column{grid-column:1 / -1;grid-template-columns:repeat(4,minmax(240px,1fr))}}@media(max-width:920px){.dashboard-shell{padding:8px;height:auto;min-height:100vh;grid-template-rows:auto auto auto auto;overflow-y:auto}.app-header,.workspace-grid,.bottom-deck,.setup-screen,.info-column,.paper-layout,.paper-feature-row{grid-template-columns:1fr}.side-rail{grid-template-columns:repeat(4,1fr);grid-auto-flow:row}.side-rail button,.next-year-card{min-height:62px}.info-column{grid-template-rows:auto}.dashboard-card{min-height:220px}.list-stack{overflow:visible}.stat-board{grid-template-columns:repeat(2,1fr)}.metric-card{border-right:0;border-bottom:1px solid var(--line)}.city-panel{min-height:560px}.pixel-city-map{min-height:518px}.map-building{width:106px;height:88px}.speech-bubble{right:12px;width:220px}.recent-cards{grid-template-columns:repeat(2,1fr)}.status-bar{grid-template-columns:1fr}.version-line{justify-content:start}.paper-lead{column-count:1}}@media(max-width:560px){.brand-block{grid-template-columns:70px 1fr}.town-crest{min-height:96px}.brand-copy h1{white-space:normal;font-size:2.5rem}.side-rail{grid-template-columns:repeat(2,1fr)}.recent-cards,.control-grid,.segmented{grid-template-columns:1fr}.map-building{transform:translate(-50%,-50%) scale(.78)}.kenney-tree{width:42px}.paper-masthead{padding-inline:8px}}
