:root{color-scheme:light;--bg: #e8ecdb;--ink: #1d2a24;--muted: #66746b;--panel: #fbf8ef;--panel-strong: #f0dec0;--line: #c8b891;--green: #4f9368;--green-dark: #2f684d;--road: #756f63;--accent: #b85b38;--shadow: 0 24px 70px rgba(55, 45, 31, .18);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-width:320px;background:linear-gradient(135deg,rgba(98,132,76,.16),transparent 42%),radial-gradient(circle at 78% 12%,rgba(184,91,56,.1),transparent 34%),var(--bg);color:var(--ink)}button{border:0;font:inherit}.app-shell{min-height:100vh;padding:24px}.game-surface{width:min(1180px,100%);margin:0 auto}.topbar{display:flex;justify-content:space-between;gap:20px;align-items:end;padding:10px 0 22px}.topbar h1{margin:0;font-size:clamp(2rem,4vw,4.4rem);line-height:.95;letter-spacing:0}.topbar p{margin:10px 0 0;color:var(--muted);font-size:.98rem}.topbar-controls{display:grid;gap:10px;justify-items:end}.language-select{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:.78rem;font-weight:800;text-transform:uppercase}.language-select select{min-height:34px;padding:0 30px 0 10px;border:1px solid var(--line);border-radius:8px;background:#fffaf0e6;color:var(--ink);font:inherit;text-transform:none}.score-strip{display:grid;grid-template-columns:repeat(3,minmax(92px,1fr));gap:8px;min-width:330px}.score-strip div{background:#fffaf0db;border:1px solid var(--line);border-radius:8px;padding:10px 12px}.score-strip span,.progress-copy{display:block;color:var(--muted);font-size:.76rem;font-weight:700;text-transform:uppercase}.score-strip strong{display:block;margin-top:4px;font-size:1.35rem}.play-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:20px;align-items:stretch}.side-panel{background:#fffaf0e6;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:18px;display:flex;flex-direction:column;gap:20px}.panel-section h2,.panel-section h3{margin:0 0 8px}.panel-section h2{font-size:1.35rem}.panel-section h3{font-size:.9rem;text-transform:uppercase}.panel-section p{margin:0 0 14px;color:var(--muted);line-height:1.45}.progress-meter{height:10px;background:#eadcc4;border-radius:999px;overflow:hidden}.progress-meter div{height:100%;background:linear-gradient(90deg,var(--green),#9ebf5d);transition:width .18s ease}.tray{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.tray-tile{aspect-ratio:1;padding:6px;cursor:pointer;border-radius:8px;background:#d8e4be;border:1px solid #d9c39e;transition:transform .14s ease,border-color .14s ease,background .14s ease}.tray-tile:hover,.tray-tile.selected{transform:translateY(-2px);border-color:var(--green-dark);background:#dce9ce}.tray-tile img,.tray-tile svg{width:100%;height:100%}.tray-tile .road-glyph{position:static;inset:auto;display:block;filter:none}.panel-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:auto}.panel-actions.centered{grid-template-columns:1fr 1fr;margin-top:18px}.panel-actions button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;background:var(--ink);color:#fff;cursor:pointer;font-weight:800;font-size:.88rem}.board-wrap{position:relative;min-height:620px;background:radial-gradient(circle at 20% 18%,rgba(255,255,255,.28),transparent 19%),radial-gradient(circle at 82% 78%,rgba(70,112,58,.16),transparent 24%),linear-gradient(135deg,#b7cf91,#9fbe78 46%,#8fb16d);border:1px solid #789957;border-radius:8px;box-shadow:var(--shadow);padding:22px;overflow:hidden}.board-stage{position:relative;height:100%;min-height:580px;overflow:hidden;border-radius:8px}.board{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(6,1fr);gap:0;height:100%;min-height:580px;position:relative;background:linear-gradient(90deg,rgba(47,104,77,.18) 1px,transparent 1px),linear-gradient(rgba(47,104,77,.18) 1px,transparent 1px);background-size:calc(100% / 6) calc(100% / 6);border:2px solid rgba(47,104,77,.35);border-radius:8px;overflow:hidden;transition:opacity .72s ease,filter .72s ease,transform .72s ease}.board-stage.completed .board{opacity:.22;filter:blur(5px) saturate(.85);transform:scale(1.025)}.completion-wash{position:absolute;inset:0;z-index:4;pointer-events:none;opacity:0;background:radial-gradient(circle at 35% 50%,rgba(249,232,142,.55),transparent 30%),linear-gradient(110deg,transparent 0%,rgba(255,255,255,.74) 48%,transparent 58%);transform:translate(-30%)}.board-stage.completed .completion-wash{animation:completeWash 1.2s ease forwards}@keyframes completeWash{0%{opacity:0;transform:translate(-38%)}32%{opacity:1}to{opacity:0;transform:translate(38%)}}.village-stage{position:absolute;inset:14px;z-index:7;display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:12px;opacity:0;transform:translateY(18px) scale(.985);animation:villageReveal .9s ease .48s forwards}@keyframes villageReveal{to{opacity:1;transform:translateY(0) scale(1)}}.stage-copy{display:flex;align-items:center;gap:12px;width:min(580px,100%);justify-self:center;padding:12px 16px;border:1px solid rgba(47,104,77,.24);border-radius:8px;background:#fbf8efeb;box-shadow:0 14px 34px #372d1f29}.stage-copy h2{margin:0;font-size:1.18rem}.stage-copy p{margin:3px 0 0;color:var(--muted);font-size:.9rem}.inline-complete{grid-template-columns:1fr 1fr;width:min(580px,100%);justify-self:center;margin-top:0}.cell{position:relative;min-width:0;min-height:0;border-radius:0;background:radial-gradient(circle at 70% 28%,rgba(255,255,255,.12),transparent 26%),#d8edb429;border:0;cursor:pointer;overflow:hidden;transition:background .15s ease,border-color .15s ease,transform .15s ease}.cell:hover{background:#ebf9d05c;transform:none}.cell.blocked{cursor:default;background:linear-gradient(135deg,#536f4326,#2a423014),#87a3631f}.cell.blocked:hover{background:linear-gradient(135deg,#536f4326,#2a423014),#87a3631f}.cell.buildable{background:radial-gradient(circle at 70% 28%,rgba(255,255,255,.14),transparent 26%),#d8edb447;box-shadow:inset 0 0 0 1px #2f684d24}.cell.connected{background:#ebf9d085}.cell.facility{cursor:default;background:radial-gradient(circle at center,rgba(255,250,240,.76),rgba(255,250,240,.22) 58%,transparent 68%),#648a491f;box-shadow:inset 0 0 0 1px #2f684d66}.road-glyph,.facility-img{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.road-glyph{filter:drop-shadow(0 6px 7px rgba(43,50,35,.24))}.facility-img{inset:4px;width:calc(100% - 8px);height:calc(100% - 22px);object-fit:contain;filter:drop-shadow(0 9px 6px rgba(35,39,27,.24))}.cell span{position:absolute;left:6px;right:6px;bottom:7px;z-index:2;padding:4px 5px;border-radius:6px;background:#fbf8efeb;color:var(--ink);font-size:.68rem;font-weight:900;text-align:center}.rotate-hint{left:auto!important;right:6px!important;bottom:6px!important;width:24px;height:24px;padding:0!important;display:inline-flex;align-items:center;justify-content:center;background:#1d2a24d1!important;color:#fff!important}.overlay{position:absolute;inset:0;display:grid;place-items:center;background:#1d2a2447;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:20}.result-card{position:relative;z-index:21;width:min(720px,calc(100% - 32px));background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:24px;text-align:center;box-shadow:var(--shadow)}.result-card h2{margin:10px 0 6px}.result-card p{color:var(--muted);margin:0}.village-3d{height:100%;min-height:0;margin-top:0;overflow:hidden;border-radius:8px;border:1px solid rgba(47,104,77,.28);background:#dbe5cf;box-shadow:inset 0 0 0 1px #ffffff73}.village-3d canvas{display:block;width:100%;height:100%}@media(max-width:880px){.app-shell{padding:14px}.topbar,.play-layout{grid-template-columns:1fr;display:grid}.topbar-controls{justify-items:stretch}.language-select{justify-content:space-between}.score-strip{min-width:0;width:100%}.play-layout{gap:14px}.side-panel{order:2}.board-wrap{min-height:auto;padding:10px}.board{min-height:auto;aspect-ratio:1;gap:5px}.board-stage{min-height:auto;aspect-ratio:1}.cell span{font-size:.58rem}.result-card{padding:18px}.village-stage{inset:8px;gap:8px}.stage-copy{padding:9px 10px}.stage-copy h2{font-size:.95rem}.stage-copy p{display:none}.village-3d{height:auto;min-height:0}.inline-complete{grid-template-columns:1fr 1fr}}
