*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0b08;--surface: #1a1610;--surface-raised: #252017;--surface-hover: #2e2820;--border: #4a3f2a;--border-light: #5c4f35;--gold: #c9a84c;--gold-light: #e0bf6e;--gold-dark: #a07830;--text: #e8d5a3;--text-muted: #8a7a5a;--text-dim: #6a5e42;--green: #6aaa64;--red: #e05c5c;--blue: #5c8ae0;--blue-light: #7aa4f0}body{background-color:var(--bg);color:var(--text);font-family:Palatino Linotype,Book Antiqua,Palatino,Times New Roman,serif;min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 20% 50%,rgba(201,168,76,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(92,138,224,.04) 0%,transparent 50%),var(--bg);padding:1rem}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:0 0 0 1px #c9a84c1a,0 4px 24px #0009,inset 0 1px #c9a84c14;position:relative}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold-dark),var(--gold),var(--gold-dark),transparent);border-radius:4px 4px 0 0}.auth-logo{text-align:center;margin-bottom:.5rem;font-size:2.5rem}.auth-title{text-align:center;font-size:2rem;font-weight:700;color:var(--gold);text-shadow:0 0 20px rgba(201,168,76,.3);letter-spacing:.1em;margin-bottom:.25rem}.auth-subtitle{text-align:center;color:var(--text-muted);font-size:.85rem;margin-bottom:1.75rem;font-style:italic}.auth-tabs{display:flex;gap:0;margin-bottom:1.75rem;border:1px solid var(--border);border-radius:3px;overflow-x:hidden;overflow-y:auto}.auth-tab{flex:1;padding:.65rem 1rem;background:var(--bg);border:none;color:var(--text-muted);font-family:inherit;font-size:.9rem;cursor:pointer;transition:all .2s;letter-spacing:.05em}.auth-tab:hover{background:var(--surface-raised);color:var(--text)}.auth-tab.active{background:var(--surface-raised);color:var(--gold);border-bottom:2px solid var(--gold);font-weight:600}.auth-form{display:flex;flex-direction:column;gap:1.1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{color:var(--text-muted);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;font-family:Palatino Linotype,serif}.form-group input{background:var(--bg);border:1px solid var(--border);border-radius:3px;padding:.65rem .85rem;color:var(--text);font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s;outline:none}.form-group input:focus{border-color:var(--gold-dark);box-shadow:0 0 0 2px #c9a84c26}.form-group input::placeholder{color:var(--text-dim)}.form-help{color:var(--text-dim);font-size:.74rem;line-height:1.35}.btn{padding:.7rem 1.5rem;border:1px solid var(--border);border-radius:3px;font-family:inherit;font-size:.9rem;cursor:pointer;transition:all .2s;letter-spacing:.05em;font-weight:600}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(180deg,#2a2010,#1a1508);color:var(--gold);border-color:var(--gold-dark);box-shadow:0 1px #c9a84c1a}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#352814,#25190a);border-color:var(--gold);color:var(--gold-light);box-shadow:0 0 8px #c9a84c33}.btn-primary:active:not(:disabled){background:linear-gradient(180deg,#1a1508,#2a2010)}.btn-full{width:100%;margin-top:.5rem}.error-msg{color:var(--red);font-size:.85rem;padding:.6rem .85rem;background:#e05c5c1a;border:1px solid rgba(224,92,92,.3);border-radius:3px;text-align:center}.success-msg,.verify-email-state{font-size:.85rem;padding:.6rem .85rem;border-radius:3px;text-align:center}.success-msg,.verify-email-state.success{color:var(--green);background:#6aaa641f;border:1px solid rgba(106,170,100,.28)}.verify-email-state.loading{color:var(--text-muted);background:#ffffff0a;border:1px solid rgba(158,232,255,.12)}.verify-email-state.error{color:var(--red);background:#e05c5c1a;border:1px solid rgba(224,92,92,.3)}.verify-email-actions{margin-top:1rem}.resource-bar{background:linear-gradient(180deg,var(--surface-raised) 0%,var(--surface) 100%);border-bottom:1px solid var(--border);padding:.5rem 1.5rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;box-shadow:0 2px 8px #0006;position:sticky;top:0;z-index:100}.resource-item{display:flex;align-items:center;gap:.4rem;padding:.3rem .75rem;background:#0000004d;border:1px solid var(--border);border-radius:3px;min-width:100px;transition:border-color .2s}.resource-item:hover{border-color:var(--border-light)}.resource-icon{font-size:1rem;line-height:1}.resource-info{display:flex;flex-direction:column;line-height:1.2}.resource-value{font-size:.95rem;font-weight:700;color:var(--gold-light);font-variant-numeric:tabular-nums}.resource-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.game-layout{display:flex;flex-direction:column;min-height:100vh}.game-header{background:linear-gradient(180deg,#1e1a10 0%,var(--surface) 100%);border-bottom:1px solid var(--border);padding:.85rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:0 2px 12px #00000080}.game-header-left{display:flex;align-items:center;gap:1rem}.game-logo{font-size:1.4rem}.game-title{font-size:1.5rem;font-weight:700;color:var(--gold);text-shadow:0 0 15px rgba(201,168,76,.3);letter-spacing:.12em}.village-name{font-size:.85rem;color:var(--text-muted);font-style:italic}.game-header-right{display:flex;align-items:center;gap:1rem}.player-info{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.player-name{font-size:.95rem;color:var(--text);font-weight:600}.player-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.logout-btn{padding:.45rem 1rem;background:#e05c5c1a;border:1px solid rgba(224,92,92,.4);border-radius:3px;color:#c06060;font-family:inherit;font-size:.8rem;cursor:pointer;transition:all .2s;letter-spacing:.04em}.logout-btn:hover{background:#e05c5c33;border-color:var(--red);color:var(--red)}.game-content{flex:1;padding:1.5rem;max-width:1400px;width:100%;margin:0 auto}.section-title{font-size:1.1rem;font-weight:700;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.5rem}.section-title:before{content:"";display:inline-block;width:3px;height:1.1rem;background:var(--gold);border-radius:2px}.queue-section{margin-bottom:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1rem 1.25rem;box-shadow:0 2px 8px #0000004d}.queue-list{display:flex;flex-direction:column;gap:.5rem}.queue-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem;background:#5c8ae012;border:1px solid rgba(92,138,224,.25);border-radius:3px;gap:1rem}.queue-item-left{display:flex;align-items:center;gap:.5rem}.queue-pulse{width:8px;height:8px;background:var(--blue-light);border-radius:50%;animation:pulse 1.5s ease-in-out infinite;flex-shrink:0}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.queue-building{color:var(--text);font-size:.95rem;font-weight:600}.queue-level{color:var(--blue-light);font-size:.85rem}.queue-timer{color:var(--blue-light);font-size:.9rem;font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:.04em;background:#5c8ae01f;padding:.2rem .6rem;border-radius:3px;min-width:72px;text-align:center}.buildings-section{margin-bottom:2rem}.building-sections{display:flex;flex-direction:column;gap:1.1rem}.building-group-section{display:flex;flex-direction:column;gap:.8rem}.building-group-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.building-group-title{color:#f4f7f8;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase}.building-group-count{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.18rem .55rem;border-radius:999px;background:#ffffff0a;border:1px solid rgba(158,232,255,.12);color:var(--text-muted);font-size:.76rem}.village-overview-panel{display:grid;grid-template-columns:minmax(280px,1.1fr) minmax(320px,1.35fr);gap:1rem;margin-bottom:1rem;padding:1rem;border-radius:24px;background:radial-gradient(circle at top right,rgba(242,198,109,.08),transparent 28%),linear-gradient(180deg,#ffffff09,#ffffff04),var(--surface);border:1px solid var(--border);box-shadow:0 18px 45px #0000003d,inset 0 1px #ffffff0a}.village-overview-main{display:flex;flex-direction:column;gap:.75rem;justify-content:center}.village-overview-kicker{color:var(--gold);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}.village-overview-text{color:var(--text-muted);max-width:48ch}.village-overview-highlights{display:flex;flex-wrap:wrap;gap:.6rem}.village-overview-chip{display:flex;flex-direction:column;gap:.1rem;padding:.65rem .8rem;border-radius:16px;background:#ffffff08;border:1px solid rgba(158,232,255,.1)}.village-overview-chip-label,.village-overview-card-label{color:var(--text-dim);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.village-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.village-overview-card{display:flex;flex-direction:column;gap:.35rem;padding:.85rem .9rem;border-radius:18px;background:#ffffff08;border:1px solid rgba(158,232,255,.1)}.village-overview-card.emphasis{background:linear-gradient(135deg,#f2c66d1f,#ffffff08),#ffffff08;border-color:#f2c66d2e}.village-overview-card.wide{grid-column:1 / -1}.village-overview-card strong{color:#f7fafb;font-size:1rem}.village-overview-card-meta{color:var(--text-muted);font-size:.8rem}.village-overview-bar{position:relative;width:100%;height:.45rem;overflow:hidden;border-radius:999px;background:#ffffff0f}.village-overview-bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--gold),#ffd98f)}.village-overview-bar-fill.food{background:linear-gradient(90deg,#7ad28f,#b0ef87)}.buildings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.building-card{background:linear-gradient(160deg,var(--surface-raised) 0%,var(--surface) 100%);border:1px solid var(--border);border-radius:4px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.75rem;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative}.building-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent)}.building-card:hover{border-color:var(--border-light);box-shadow:0 4px 16px #0006;transform:translateY(-1px)}.building-card.maxed{opacity:.86;border-color:#9ee8ff14;background:linear-gradient(180deg,#ffffff05,#ffffff03),#0a1418c7}.building-card.maxed .building-level-inline{color:#bfe1c7d1}.building-card.in-queue{border-color:#5c8ae059;box-shadow:0 0 0 1px #5c8ae01a}.building-card.in-queue:before{background:linear-gradient(90deg,transparent,rgba(92,138,224,.25),transparent)}.building-production{display:flex;align-items:center;gap:.35rem;font-size:.8rem;padding:.25rem .5rem;background:#c9a84c12;border:1px solid rgba(201,168,76,.15);border-radius:3px}.production-icon{font-size:.75rem}.production-value{color:var(--gold-light);font-weight:600;font-variant-numeric:tabular-nums}.production-next{color:var(--text-muted);font-size:.75rem;margin-left:auto}.building-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.building-heading{display:flex;flex-direction:column;gap:.18rem;min-width:0}.building-header-right{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.building-info-icon{width:20px;height:20px;border-radius:50%;background:#f2c66d24;border:1px solid rgba(242,198,109,.38);color:var(--gold-light);font-size:.78rem;font-style:normal;font-weight:800;display:flex;align-items:center;justify-content:center;cursor:default;position:relative;flex-shrink:0;box-shadow:0 0 0 1px #07111673;z-index:3}.building-info-icon:hover{border-color:var(--gold-light);color:#081217;background:linear-gradient(135deg,var(--gold-light),var(--gold))}.building-info-icon:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);right:-8px;width:220px;background:#1e1a0f;border:1px solid var(--gold-dark);border-radius:4px;padding:.6rem .75rem;font-size:.8rem;font-style:normal;font-weight:400;color:#e8d5a3;line-height:1.5;pointer-events:none;opacity:0;transition:opacity .15s;z-index:300;box-shadow:0 6px 20px #000c;white-space:normal}.building-info-icon:hover:after{opacity:1}.building-name{font-size:1rem;font-weight:700;color:var(--text);letter-spacing:.03em}.building-level-inline{display:inline-flex;align-items:center;color:var(--text-dim);font-size:.73rem;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:.03em;white-space:nowrap}.building-upgrade-info{display:flex;flex-direction:column;gap:.5rem}.upgrade-cost{display:flex;flex-wrap:wrap;gap:.35rem}.cost-item{display:flex;align-items:center;gap:.25rem;font-size:.8rem;padding:.2rem .45rem;background:#0000004d;border:1px solid var(--border);border-radius:3px;color:var(--text);transition:border-color .15s}.cost-item.available{border-color:#f2c66d2e;color:var(--text-muted);background:#f2c66d0a}.cost-item.insufficient{border-color:#e05c5c66;color:var(--red);background:#e05c5c12}.cost-icon{font-size:.75rem}.upgrade-time{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}.upgrade-time-icon{font-size:.7rem}.building-card-footer{margin-top:auto}.btn-upgrade{width:100%;padding:.55rem 1rem;background:linear-gradient(180deg,#1e2a14,#131d0c);border:1px solid #3a5228;border-radius:3px;color:#7dbf5a;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.06em;text-transform:uppercase}.btn-upgrade:hover:not(:disabled){background:linear-gradient(180deg,#28381c,#1c2a10);border-color:#4a6e35;color:#8fd468;box-shadow:0 0 8px #6aaa6426}.btn-upgrade:active:not(:disabled){background:linear-gradient(180deg,#131d0c,#1e2a14)}.btn-upgrade:disabled{opacity:.45;cursor:not-allowed;background:linear-gradient(180deg,#181818,#101010);border-color:var(--border);color:var(--text-dim)}.queue-status{width:100%;padding:.5rem 1rem;background:#5c8ae014;border:1px solid rgba(92,138,224,.3);border-radius:3px;color:var(--blue-light);font-size:.85rem;font-style:italic;text-align:center;letter-spacing:.03em;display:flex;align-items:center;justify-content:center;gap:.4rem}.queue-status-dot{width:6px;height:6px;background:var(--blue-light);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background:var(--bg)}.loading-title{font-size:2.5rem;color:var(--gold);letter-spacing:.15em;text-shadow:0 0 20px rgba(201,168,76,.3)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:.9rem;font-style:italic}.error-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.error-card{background:var(--surface);border:1px solid rgba(224,92,92,.4);border-radius:4px;padding:2rem;max-width:400px;text-align:center;display:flex;flex-direction:column;gap:1rem}.error-icon{font-size:2.5rem}.error-title{color:var(--red);font-size:1.1rem;font-weight:700}.error-detail{color:var(--text-muted);font-size:.9rem}.toast{position:fixed;bottom:1.5rem;right:1.5rem;padding:.75rem 1.25rem;border-radius:4px;font-size:.9rem;font-weight:600;z-index:1000;animation:slideIn .3s ease-out;max-width:320px}.toast.error{background:#e05c5c26;border:1px solid rgba(224,92,92,.5);color:var(--red)}.toast.success{background:#6aaa641f;border:1px solid rgba(106,170,100,.4);color:var(--green)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.coord-badge{font-size:.75rem;color:var(--text-dim);background:#0000004d;padding:.15rem .5rem;border-radius:3px;border:1px solid var(--border);font-variant-numeric:tabular-nums}@media (max-width: 640px){.resource-bar{padding:.5rem .75rem;gap:.35rem}.resource-item{min-width:80px;padding:.25rem .5rem}.game-header{padding:.75rem 1rem}.game-content{padding:1rem .75rem}.buildings-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.game-title{font-size:1.2rem}}.map-container{position:relative;width:100%;height:calc(100vh - 180px);min-height:400px;border:1px solid var(--border);border-radius:4px;overflow:hidden;background:#0d0b08}.map-tooltip{background:var(--surface-raised);border:1px solid var(--border-light);border-radius:3px;padding:.4rem .65rem;pointer-events:none;z-index:10;min-width:120px;box-shadow:0 2px 8px #00000080}.tooltip-name{font-size:.85rem;font-weight:700;color:var(--text)}.tooltip-player{font-size:.75rem;color:var(--gold)}.tooltip-coord{font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.map-controls{position:absolute;bottom:1rem;right:1rem;display:flex;gap:.4rem}.map-controls button{background:var(--surface-raised);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:inherit;font-size:.85rem;padding:.4rem .8rem;cursor:pointer;transition:all .2s}.map-controls button:hover{border-color:var(--gold-dark);color:var(--gold)}.game-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:1px solid var(--border)}.game-tab{padding:.6rem 1.5rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;letter-spacing:.06em;text-transform:uppercase;transition:all .2s;margin-bottom:-1px}.game-tab:hover{color:var(--text)}.game-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.troops-panel{padding-bottom:2rem}.troops-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.troop-card{background:linear-gradient(160deg,var(--surface-raised) 0%,var(--surface) 100%);border:1px solid var(--border);border-radius:4px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.75rem;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative}.troop-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent)}.troop-card:hover{border-color:var(--border-light);box-shadow:0 4px 16px #0006;transform:translateY(-1px)}.troop-card.unavailable{opacity:.5}.troop-stats{display:flex;gap:.5rem;flex-wrap:wrap}.stat-item{display:inline-flex;align-items:center;gap:.2rem;font-size:.78rem;padding:.2rem .45rem;background:#0000004d;border:1px solid var(--border);border-radius:3px;color:var(--text-muted);white-space:nowrap}.troop-train-row{display:flex;gap:.5rem;align-items:center}.troop-count-input{width:70px;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text);padding:.4rem .5rem;font-family:inherit;font-size:.9rem;text-align:center;outline:none;transition:border-color .2s;flex-shrink:0}.troop-count-input:focus{border-color:var(--gold-dark);box-shadow:0 0 0 2px #c9a84c26}.troop-count{font-size:1.1rem;font-weight:800;color:var(--gold-light);font-variant-numeric:tabular-nums;flex-shrink:0}.upkeep-bar{margin-bottom:.5rem;padding:.5rem .75rem;background:#0003;border:1px solid var(--border);border-radius:3px;font-size:.85rem;display:inline-flex;align-items:center;gap:.4rem}.research-panel{padding-bottom:2rem}.research-category{margin-bottom:2rem}.research-category-title{font-size:1.05rem}.research-category-title.category-economy{color:var(--gold)}.research-category-title.category-military{color:#e07070}.research-category-title.category-defense{color:var(--blue-light)}.research-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.research-card{background:linear-gradient(160deg,var(--surface-raised) 0%,var(--surface) 100%);border:1px solid var(--border);border-radius:4px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.65rem;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative}.research-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent)}.research-card:hover{border-color:var(--border-light);box-shadow:0 4px 16px #0006;transform:translateY(-1px)}.research-card.in-queue{border-color:#5c8ae059;box-shadow:0 0 0 1px #5c8ae01a}.research-level{font-size:.78rem;font-weight:700;padding:.2rem .55rem;border-radius:12px;background:linear-gradient(135deg,var(--gold-dark),#8a6428);color:var(--bg);letter-spacing:.05em;white-space:nowrap;flex-shrink:0}.research-level.maxed{background:linear-gradient(135deg,#3a6a30,#285020);color:#a0e090}.research-effect{color:var(--gold);font-size:.8rem;font-style:italic}.research-maxed{color:var(--green);text-align:center;font-style:italic;font-size:.85rem;padding:.4rem 0}.research-locked{color:var(--text-muted);text-align:center;font-size:.8rem;padding:.3rem 0;line-height:1.5}.tooltip-npc{font-size:.75rem;color:#c97a2a}.tooltip-plunder{font-size:.72rem;color:var(--gold);font-style:italic}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:500;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1.5rem;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #000c;position:relative}.modal:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--red),transparent)}.modal-title{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.modal-subtitle{font-size:.8rem;color:var(--text-muted);margin-bottom:1.25rem}.troop-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid rgba(74,63,42,.3)}.troop-row-name{font-size:.9rem;font-weight:600;color:var(--text);min-width:120px}.troop-row-available{font-size:.78rem;color:var(--text-muted);flex:1}.troop-row-controls{display:flex;align-items:center;gap:.35rem}.troop-quick-btn{background:var(--surface-raised);border:1px solid var(--border);border-radius:3px;color:var(--text-muted);font-size:.72rem;padding:.2rem .45rem;cursor:pointer}.troop-quick-btn:hover{color:var(--gold);border-color:var(--gold-dark)}.attack-power-preview{margin:1rem 0;padding:.65rem 1rem;background:#e05c5c14;border:1px solid rgba(224,92,92,.25);border-radius:3px;font-size:.85rem;color:var(--text);display:flex;justify-content:space-between}.attack-power-value{color:#e07070;font-weight:700}.modal-actions{display:flex;gap:.75rem;margin-top:1rem}.btn-attack{flex:1;padding:.65rem;background:linear-gradient(180deg,#3a1010,#280a0a);border:1px solid #8B0000;border-radius:3px;color:#e07070;font-family:inherit;font-size:.9rem;font-weight:700;cursor:pointer;letter-spacing:.05em;transition:all .2s}.btn-attack:hover:not(:disabled){background:linear-gradient(180deg,#4a1515,#351010);border-color:#c00;color:#ff8080}.btn-attack:disabled{opacity:.4;cursor:not-allowed}.btn-cancel{padding:.65rem 1.25rem;background:var(--surface-raised);border:1px solid var(--border);border-radius:3px;color:var(--text-muted);font-family:inherit;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-cancel:hover{color:var(--text);border-color:var(--border-light)}.reports-panel{display:flex;flex-direction:column;gap:.75rem}.report-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:.85rem 1rem;cursor:pointer;transition:border-color .2s}.report-card:hover{border-color:var(--border-light)}.report-card.victory{border-left:3px solid var(--green)}.report-card.defeat{border-left:3px solid var(--red)}.report-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.report-result{font-size:.95rem;font-weight:700}.report-result.victory{color:var(--green)}.report-result.defeat{color:var(--red)}.report-villages{font-size:.82rem;color:var(--text-muted);flex:1}.report-date{font-size:.75rem;color:var(--text-dim);white-space:nowrap}.report-loot{display:flex;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.report-loot-item{font-size:.78rem;color:var(--gold-light)}.report-details{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted);display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.report-power{font-size:.78rem;margin-top:.5rem;color:var(--text-muted)}.admin-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.admin-header{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.admin-header-left{display:flex;align-items:center;gap:.75rem}.admin-subtitle{font-size:.75rem;color:var(--red);letter-spacing:.12em;text-transform:uppercase;font-weight:700}.admin-header-right{display:flex;align-items:center;gap:.75rem}.admin-content{flex:1;padding:1.5rem;max-width:1400px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.admin-error{background:#e05c5c1f;border:1px solid var(--red);border-radius:4px;padding:.75rem 1rem;color:var(--red);font-size:.9rem}.admin-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media (max-width: 700px){.admin-stats-row{grid-template-columns:repeat(2,1fr)}}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1rem 1.25rem;text-align:center}.admin-stat-value{font-size:2rem;font-weight:700;color:var(--gold);line-height:1}.admin-stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:.25rem}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1.25rem}.admin-sim-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.admin-sim-controls{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.admin-sim-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.85rem}.admin-sim-card{text-align:left}.admin-loadtest-routes{margin-top:1rem;display:grid;gap:.65rem}.admin-loadtest-route{display:grid;grid-template-columns:minmax(180px,1.5fr) repeat(5,minmax(0,1fr));gap:.65rem;align-items:center;padding:.75rem .9rem;border:1px solid rgba(158,232,255,.12);border-radius:14px;background:#ffffff08;color:var(--text-muted);font-size:.82rem}@media (max-width: 900px){.admin-loadtest-route{grid-template-columns:1fr 1fr}}.admin-table-wrapper{overflow-x:auto}.admin-user-toolbar{display:flex;justify-content:space-between;align-items:center;gap:.85rem;flex-wrap:wrap;margin-top:1rem}.admin-pagination{display:flex;gap:.5rem;align-items:center}.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}.admin-table th{text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.admin-table td{padding:.6rem .75rem;border-bottom:1px solid rgba(74,63,42,.4);vertical-align:middle}.admin-user-row{cursor:pointer;transition:background .15s}.admin-user-row:hover{background:var(--surface-hover)}.admin-user-row.expanded{background:var(--surface-raised)}.admin-user-row.own-row td:first-child{border-left:2px solid var(--gold)}.admin-username{font-weight:600;color:var(--text)}.admin-you-badge{margin-left:.4rem;font-size:.7rem;background:#c9a84c26;color:var(--gold);border:1px solid rgba(201,168,76,.3);border-radius:3px;padding:.1rem .35rem;vertical-align:middle}.admin-td-muted{color:var(--text-muted)}.admin-badge{display:inline-block;font-size:.72rem;font-weight:700;padding:.2rem .5rem;border-radius:3px;text-transform:uppercase;letter-spacing:.06em}.badge-admin{background:#e05c5c26;color:var(--red);border:1px solid rgba(224,92,92,.3)}.badge-player{background:#8a7a5a26;color:var(--text-muted);border:1px solid var(--border)}.admin-actions{display:flex;gap:.4rem;align-items:center}.admin-expand-row td{padding:0;background:#0d0b0899;border-bottom:1px solid var(--border)}.admin-village-editor{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.admin-village-title{color:var(--gold-light);font-size:.9rem}.admin-resource-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem}@media (max-width: 800px){.admin-resource-grid{grid-template-columns:repeat(3,1fr)}}.admin-resource-field{display:flex;flex-direction:column;gap:.3rem}.admin-checkbox-field{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.82rem;padding:.35rem .25rem}.admin-checkbox-field input{accent-color:var(--gold)}.admin-resource-label{font-size:.78rem;color:var(--text-muted)}.admin-resource-input{background:var(--surface-raised);border:1px solid var(--border);border-radius:3px;color:var(--text);padding:.35rem .5rem;font-size:.88rem;font-family:inherit;width:100%}.admin-resource-input:focus{outline:none;border-color:var(--gold-dark)}.btn-sm{padding:.3rem .65rem;font-size:.78rem}.btn-warning{background:#c9a84c1f;border:1px solid var(--gold-dark);color:var(--gold);border-radius:3px;cursor:pointer;font-family:inherit;transition:background .15s}.btn-warning:hover:not(:disabled){background:#c9a84c38}.btn-danger{background:#e05c5c1a;border:1px solid rgba(224,92,92,.4);color:var(--red);border-radius:3px;cursor:pointer;font-family:inherit;transition:background .15s}.btn-danger:hover:not(:disabled){background:#e05c5c33}.btn-confirm-delete{background:var(--red);border:1px solid var(--red);color:#fff;border-radius:3px;cursor:pointer;font-family:inherit;font-weight:700;animation:pulse-red .6s ease-in-out infinite alternate}@keyframes pulse-red{0%{opacity:.85}to{opacity:1}}.btn-secondary{background:#5c8ae01a;border:1px solid rgba(92,138,224,.35);color:var(--blue-light);border-radius:3px;cursor:pointer;font-family:inherit;transition:background .15s;padding:.4rem .85rem;font-size:.85rem}.btn-secondary:hover{background:#5c8ae02e}button:disabled{opacity:.4;cursor:not-allowed}.admin-feedback{position:fixed;bottom:1.5rem;right:1.5rem;padding:.65rem 1.1rem;border-radius:4px;font-size:.88rem;z-index:1000;box-shadow:0 4px 16px #00000080;animation:slide-in-right .2s ease-out}.admin-feedback.success{background:#6aaa6426;border:1px solid var(--green);color:var(--green)}.admin-feedback.error{background:#e05c5c26;border:1px solid var(--red);color:var(--red)}@keyframes slide-in-right{0%{transform:translate(2rem);opacity:0}to{transform:translate(0);opacity:1}}.admin-expand-inner{padding:.75rem 1.25rem 1rem}.admin-village-title{font-size:.9rem;color:var(--gold-light);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.admin-inner-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1rem;flex-wrap:wrap}.admin-inner-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:.8rem;letter-spacing:.06em;padding:.4rem .85rem;text-transform:uppercase;transition:color .15s,border-color .15s;margin-bottom:-1px}.admin-inner-tab:hover{color:var(--text)}.admin-inner-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.admin-tab-content{display:flex;flex-direction:column;gap:.75rem}.admin-hint{color:var(--text-muted);font-size:.8rem;font-style:italic}.admin-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem}@media (max-width: 700px){.admin-grid-3{grid-template-columns:repeat(2,1fr)}}.admin-queue-section{display:flex;flex-direction:column;gap:.4rem}.admin-queue-label{font-size:.78rem;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.15rem}.admin-queue-row{display:flex;align-items:center;gap:.75rem;padding:.35rem .5rem;background:var(--surface-raised);border-radius:3px;font-size:.85rem}.admin-queue-row span:first-child{flex:1}.admin-account-grid{display:flex;flex-direction:column;gap:1rem}.admin-account-block{display:flex;flex-direction:column;gap:.4rem}.admin-account-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}:root{--bg: #081217;--surface: rgba(13, 24, 30, .9);--surface-raised: rgba(18, 33, 41, .95);--surface-hover: rgba(24, 42, 52, .98);--border: rgba(126, 162, 170, .18);--border-light: rgba(161, 208, 214, .34);--gold: #f2c66d;--gold-light: #ffe4a8;--gold-dark: #a8782b;--text: #edf5f7;--text-muted: #9eb3b8;--text-dim: #70878d;--green: #7ad28f;--red: #ff7d74;--blue: #5eb8df;--blue-light: #9ee8ff}body{background:radial-gradient(circle at top left,rgba(94,184,223,.1),transparent 28%),radial-gradient(circle at top right,rgba(242,198,109,.08),transparent 24%),linear-gradient(180deg,#071116,#0b171d 45%,#081217);color:var(--text);font-family:Georgia,Times New Roman,serif;overflow-x:hidden;overflow-y:auto}.btn,.auth-tab,.game-tab,.map-controls button,.logout-btn,.btn-upgrade,.btn-attack,.btn-cancel,.btn-secondary,.troop-count-input,.form-group input{border-radius:16px}.game-layout{position:relative;min-height:100vh;background:radial-gradient(circle at top center,rgba(94,184,223,.06),transparent 28%),linear-gradient(180deg,#050a0ee6,#050a0e99)}.game-header{flex-shrink:0;z-index:120;padding:.8rem 1.25rem;background:#071014d1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(158,232,255,.12);box-shadow:0 18px 40px #0000003d}.game-logo{width:3rem;height:3rem;display:inline-flex;align-items:center;justify-content:center;border-radius:18px;background:linear-gradient(145deg,#f2c66d4d,#a8782b33),#ffffff08;border:1px solid rgba(242,198,109,.28);color:var(--gold-light);font-size:1rem;font-weight:700;letter-spacing:.18em}.game-title{font-size:clamp(1.35rem,2vw,1.85rem);letter-spacing:.18em;text-transform:uppercase}.village-name{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;color:var(--text-muted)}.coord-badge{background:#ffffff0a;border:1px solid rgba(158,232,255,.12);border-radius:999px;padding:.22rem .6rem;color:var(--blue-light)}.player-name{font-size:1rem}.logout-btn{background:#ff7d7414;border:1px solid rgba(255,125,116,.25);color:#ffb3ad}.logout-btn:hover{background:#ff7d7424;color:#ffd3cd}.resource-bar{flex-shrink:0;z-index:110;display:grid;grid-template-columns:minmax(180px,1.2fr) repeat(6,minmax(0,1fr));gap:.6rem;align-items:stretch;padding:.8rem 1.25rem .9rem;background:#081217c7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(158,232,255,.08)}.resource-bar-title,.resource-item{min-height:64px}.resource-bar-title{display:flex;flex-direction:column;justify-content:center;padding:.8rem 1rem;border:1px solid rgba(242,198,109,.18);border-radius:22px;background:radial-gradient(circle at top left,rgba(242,198,109,.14),transparent 55%),#ffffff08}.resource-bar-label{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}.resource-bar-subtitle{margin-top:.35rem;color:var(--text-muted);font-size:.92rem}.resource-item{gap:.75rem;justify-content:flex-start;padding:.75rem .9rem;background:#ffffff08;border:1px solid rgba(158,232,255,.12);border-radius:22px;box-shadow:inset 0 1px #ffffff0a}.resource-item:hover{transform:translateY(-1px);border-color:#9ee8ff3d}.resource-icon{width:2.25rem;height:2.25rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#f2c66d1f;border:1px solid rgba(242,198,109,.2);color:var(--gold-light);font-size:.82rem;font-weight:700;letter-spacing:.08em}.resource-value{font-size:1rem;color:var(--text)}.resource-label{color:var(--text-dim)}.game-content{max-width:1500px;width:100%;padding:.85rem 1.25rem 1.25rem;margin:0 auto}.game-subbar,.subbar-stat,.command-surface,.queue-section,.building-card,.troop-card,.research-card,.report-card,.admin-section,.admin-stat-card,.auth-card,.modal{background:linear-gradient(180deg,#ffffff09,#ffffff04),var(--surface);border:1px solid var(--border);box-shadow:0 18px 45px #0000003d,inset 0 1px #ffffff0a}.game-subbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.8rem;padding:.8rem .95rem;border-radius:20px}.game-subbar-main{display:flex;flex-direction:column;gap:.15rem}.game-subbar-title{color:#f7fafb;font-size:1rem;font-weight:700}.game-subbar-meta{color:var(--text-muted);font-size:.82rem}.game-subbar-stats{display:flex;gap:.6rem;flex-wrap:wrap}.subbar-stat{min-width:110px;padding:.55rem .7rem;border-radius:16px}.subbar-stat-label{display:block;color:var(--text-dim);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase}.subbar-stat-value{display:block;margin-top:.2rem;color:#f7fafb;font-size:1rem}.command-surface{padding:.8rem;border-radius:24px}.game-tabs{gap:.65rem;margin-bottom:.75rem;border-bottom:none;flex-wrap:wrap}.game-tab{margin-bottom:0;padding:.62rem .95rem;border:1px solid rgba(158,232,255,.1);border-radius:999px;background:#ffffff08;color:var(--text-muted);font-size:.82rem}.game-tab:hover{border-color:#9ee8ff3d;background:#ffffff0d}.game-tab.active{color:#071116;border-color:transparent;background:linear-gradient(135deg,var(--gold-light),var(--gold));box-shadow:0 10px 25px #f2c66d3d}.tab-panel{overflow:visible;padding:.15rem}.section-title{border-bottom:none;margin-bottom:.8rem;padding-bottom:0;color:#f4f7f8;font-size:1rem}.section-title:before{width:10px;height:10px;border-radius:999px;background:linear-gradient(135deg,var(--gold-light),var(--gold-dark))}.panel-empty-state{padding:2rem 0;color:var(--text-muted);font-style:italic}.queue-section,.building-card,.troop-card,.research-card,.report-card,.auth-card,.modal,.admin-section,.admin-stat-card{border-radius:26px}.queue-section{padding:.85rem .95rem}.queue-item{padding:.7rem .8rem;border-radius:15px;background:#5eb8df14;border:1px solid rgba(94,184,223,.16)}.buildings-grid,.troops-grid,.research-grid{gap:.8rem}.buildings-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.building-card,.troop-card,.research-card{padding:.9rem;gap:.65rem;overflow:visible}.building-card:before,.troop-card:before,.research-card:before{height:2px;background:linear-gradient(90deg,transparent,rgba(242,198,109,.55),transparent)}.building-card:hover,.troop-card:hover,.research-card:hover,.report-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.building-name{font-size:.98rem}.building-level-badge,.research-level{border-radius:999px;padding:.3rem .7rem}.building-production,.cost-item,.stat-item,.upkeep-bar,.queue-status{border-radius:14px}.btn-upgrade,.btn-attack,.btn-cancel,.btn-secondary,.btn-primary{min-height:38px}.building-production,.upgrade-time,.cost-item,.queue-building,.queue-level,.queue-timer{font-size:.76rem}.btn-upgrade{background:linear-gradient(135deg,#153125,#1b4530);border:1px solid rgba(122,210,143,.28);color:#cbffd8}.btn-upgrade:hover:not(:disabled){background:linear-gradient(135deg,#1d402f,#23523b)}.map-stage{display:grid;gap:1rem}.map-stage-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.map-stage-text{color:var(--text-muted);max-width:48ch}.map-legend{display:flex;gap:.6rem;flex-wrap:wrap}.map-legend-item{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .8rem;background:#ffffff08;border:1px solid rgba(158,232,255,.12);border-radius:999px;color:var(--text-muted);font-size:.82rem}.map-legend-swatch{width:.75rem;height:.75rem;border-radius:999px;display:inline-block}.map-legend-swatch.own{background:var(--gold)}.map-legend-swatch.enemy{background:#74b9ff}.map-legend-swatch.neutral{background:#b8c7ce}.map-legend-swatch.npc{background:#cb7b2c}.map-legend-swatch.movement-own{background:linear-gradient(135deg,#ffe4a8,#f2c66d)}.map-legend-swatch.movement-world{background:linear-gradient(135deg,#9ee8ff,#5eb8df)}.map-container{position:relative;width:100%;height:min(68vh,720px);min-height:520px;overflow:hidden;border-radius:30px;border:1px solid rgba(158,232,255,.18);background:linear-gradient(180deg,#091419fa,#0c191ffa);box-shadow:inset 0 1px #ffffff0a,0 24px 50px #00000047}.map-atmosphere{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top left,rgba(94,184,223,.12),transparent 24%),radial-gradient(circle at bottom right,rgba(242,198,109,.08),transparent 22%),linear-gradient(135deg,transparent 0%,rgba(255,255,255,.015) 48%,transparent 100%);pointer-events:none;z-index:0}.map-container canvas{position:relative;z-index:1}.map-topbar,.map-tooltip,.map-controls button,.map-hud-chip{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-topbar{position:absolute;top:1rem;left:1rem;right:1rem;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:1rem;pointer-events:none}.map-topbar-badge,.map-topbar-coords{padding:.45rem .85rem;border-radius:999px;background:#091419a8;border:1px solid rgba(158,232,255,.14);color:var(--text-muted);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase}.map-topbar-badge{color:var(--gold-light);border-color:#f2c66d2e}.map-tooltip{border-radius:16px;background:#091419eb;border:1px solid rgba(158,232,255,.2);box-shadow:0 20px 35px #00000061}.map-hud{position:absolute;left:1rem;bottom:1rem;display:flex;gap:.55rem;flex-wrap:wrap;z-index:2}.map-hud-chip{padding:.45rem .75rem;border-radius:999px;background:#091419c7;border:1px solid rgba(158,232,255,.12);color:var(--text-muted);font-size:.76rem}.map-controls{bottom:1rem;right:1rem;gap:.5rem;z-index:2}.map-controls button{background:#091419d1;border:1px solid rgba(158,232,255,.18);color:var(--text);min-width:2.75rem;padding:.55rem .9rem;box-shadow:0 12px 24px #0000002e}.map-controls button:hover{border-color:#f2c66d52;color:var(--gold-light)}.tooltip-name{color:#f6fbfc}.tooltip-player{color:var(--blue-light)}.tooltip-npc{color:#ffbf7f}.tooltip-plunder{color:var(--gold-light)}.tooltip-coord{color:var(--text-dim)}.tooltip-recommendation{margin-top:.35rem;display:inline-flex;align-items:center;padding:.18rem .55rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);font-size:.74rem;font-weight:700}.tooltip-recommendation.strong{color:#c9ffd7;background:#6aaa642e;border-color:#6aaa6452}.tooltip-recommendation.favored{color:#ffe6a8;background:#f2c66d29;border-color:#f2c66d4d}.tooltip-recommendation.risky{color:#ffd5a8;background:#ef9d4729;border-color:#ef9d474d}.tooltip-recommendation.avoid{color:#ffb8b0;background:#e05c5c29;border-color:#e05c5c47}.site-legal-footer{width:min(1500px,calc(100% - 2.5rem));margin:0 auto 1.1rem;display:flex;justify-content:center}.auth-legal-footer{width:100%;margin-top:1.35rem}.legal-links{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}.legal-links a,.legal-backlink{color:var(--text-muted);text-decoration:none;font-size:.82rem;transition:color .15s,opacity .15s}.legal-links a:hover,.legal-backlink:hover{color:var(--gold-light)}.legal-page{min-height:100vh;padding:1.4rem 1rem 2rem;background:radial-gradient(circle at top left,rgba(94,184,223,.08),transparent 28%),radial-gradient(circle at top right,rgba(242,198,109,.08),transparent 24%),linear-gradient(180deg,#071116,#0b171d 45%,#081217)}.legal-shell{width:min(980px,100%);margin:0 auto}.legal-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.legal-card{padding:1.4rem 1.45rem;border-radius:26px;background:linear-gradient(180deg,#ffffff09,#ffffff04),var(--surface);border:1px solid var(--border);box-shadow:0 18px 45px #0000003d,inset 0 1px #ffffff0a}.legal-card h1{color:#f6fbfc;font-size:1.8rem;margin-bottom:.5rem}.legal-card h2{color:var(--gold-light);font-size:1.02rem;margin-bottom:.45rem}.legal-card p{color:var(--text);line-height:1.7}.legal-note{color:var(--text-muted);margin-bottom:1rem}.legal-section+.legal-section{margin-top:1.1rem}.legal-list{margin-left:1.2rem;color:var(--text);display:grid;gap:.35rem}.legal-meta{margin-top:.85rem;display:flex;justify-content:space-between;gap:.75rem;flex-wrap:wrap;color:var(--text-dim);font-size:.8rem}.reports-panel{gap:1rem}.report-card{padding:1rem 1.1rem}.report-card.victory,.report-card.defeat{border-left-width:4px}.auth-page{background:radial-gradient(circle at top left,rgba(94,184,223,.08),transparent 32%),radial-gradient(circle at bottom right,rgba(242,198,109,.08),transparent 28%),linear-gradient(180deg,#071116,#081217)}.auth-title,.loading-title{letter-spacing:.18em;text-transform:uppercase}@media (max-width: 1100px){.resource-bar{grid-template-columns:repeat(3,minmax(0,1fr))}.resource-bar-title{grid-column:1 / -1}.game-subbar{flex-direction:column;align-items:flex-start}.village-overview-panel{grid-template-columns:1fr}}@media (max-width: 700px){.game-header{padding:.85rem 1rem}.game-header-left,.game-header-right{width:100%;justify-content:space-between}.game-header{flex-wrap:wrap}.resource-bar{grid-template-columns:repeat(2,minmax(0,1fr));padding:.8rem 1rem 1rem}.game-content{padding:1.2rem 1rem 2rem}.village-overview-grid{grid-template-columns:1fr}.command-surface,.game-subbar,.subbar-stat,.queue-section,.building-card,.troop-card,.research-card,.report-card,.map-container{border-radius:22px}.map-container{height:min(60vh,520px);min-height:420px}.map-topbar{flex-direction:column;align-items:flex-start}.game-subbar-stats{width:100%}.subbar-stat{min-width:0;flex:1}}.alliance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:1rem}.alliance-form{display:flex;flex-direction:column;gap:.75rem}.alliance-form input,.alliance-form textarea,.alliance-form select{width:100%;background:#ffffff08;border:1px solid rgba(158,232,255,.12);color:var(--text);padding:.75rem .9rem;border-radius:18px;font-family:inherit;resize:vertical}.alliance-form input:focus,.alliance-form textarea:focus,.alliance-form select:focus{outline:none;border-color:#f2c66d73;box-shadow:0 0 0 3px #f2c66d1f}.forum-shell{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:1rem}.forum-main{min-width:0}.forum-category-list,.forum-thread-list,.forum-posts{display:flex;flex-direction:column;gap:.75rem}.forum-category-card,.forum-thread-card{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;width:100%;text-align:left;border:1px solid rgba(158,232,255,.12);background:#ffffff08;color:var(--text);border-radius:18px;padding:.8rem .9rem;cursor:pointer;transition:border-color .15s,background .15s,transform .15s;font-family:inherit}.forum-category-card:hover,.forum-thread-card:hover,.forum-category-card.active,.forum-thread-card.active{border-color:#f2c66d47;background:#ffffff0d;transform:translateY(-1px)}.forum-category-card.active,.forum-thread-card.active{box-shadow:inset 0 0 0 1px #f2c66d33,0 14px 30px #00000038;background:linear-gradient(180deg,#f2c66d14,#ffffff0a),#ffffff0a}.forum-category-topline{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.forum-category-pill,.forum-header-chip{display:inline-flex;align-items:center;padding:.28rem .65rem;border-radius:999px;background:#f2c66d1f;border:1px solid rgba(242,198,109,.2);color:var(--gold-light);font-size:.74rem;white-space:nowrap}.forum-category-name,.forum-thread-title,.forum-thread-detail-title,.forum-subtitle{color:#f7fafb;font-weight:700}.forum-category-meta,.forum-category-description,.forum-thread-meta{display:block;color:var(--text-muted);font-size:.82rem}.forum-category-description{display:block;margin-top:.4rem}.forum-category-preview{width:100%;margin-top:.45rem;padding:.7rem .8rem;border-radius:14px;background:#0812178c;border:1px solid rgba(158,232,255,.08)}.forum-category-preview.empty{opacity:.78}.forum-category-preview-label,.forum-compose-note{color:var(--text-dim);font-size:.72rem}.forum-category-preview-title{margin-top:.2rem;color:var(--text);font-size:.88rem;font-weight:600}.forum-compose,.forum-reply-box{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.forum-compose-header{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-bottom:-.1rem}.forum-compose input,.forum-compose textarea,.forum-reply-box textarea{width:100%;background:#ffffff08;border:1px solid rgba(158,232,255,.12);color:var(--text);padding:.75rem .9rem;border-radius:18px;font-family:inherit;resize:vertical}.forum-compose input:focus,.forum-compose textarea:focus,.forum-reply-box textarea:focus{outline:none;border-color:#f2c66d73;box-shadow:0 0 0 3px #f2c66d1f}.forum-content-grid{display:grid;grid-template-columns:minmax(300px,420px) minmax(0,1fr);gap:1rem}.forum-thread-title-row,.forum-post-header,.forum-header{display:flex;align-items:center;gap:.5rem;justify-content:space-between;flex-wrap:wrap}.forum-thread-title-row{width:100%}.forum-thread-detail{padding-bottom:.75rem;border-bottom:1px solid rgba(158,232,255,.08)}.forum-post-card{border:1px solid rgba(158,232,255,.12);background:#ffffff08;border-radius:18px;padding:.9rem 1rem}.forum-post-body{margin-top:.65rem;color:var(--text);white-space:pre-wrap;word-break:break-word}@media (max-width: 1000px){.forum-shell,.forum-content-grid{grid-template-columns:1fr}}.mini-filter-bar{display:flex;gap:.45rem;flex-wrap:wrap}.mini-filter-btn{border:1px solid rgba(158,232,255,.12);background:#ffffff08;color:var(--text-muted);border-radius:999px;padding:.42rem .72rem;font-family:inherit;font-size:.76rem;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.mini-filter-btn:hover{border-color:#9ee8ff3d;color:var(--text)}.mini-filter-btn.active{background:linear-gradient(135deg,var(--gold-light),var(--gold));border-color:transparent;color:#071116;box-shadow:0 8px 20px #f2c66d2e}
