:root{--sumi:#2b2320;--kinari:#f6efe1;--kinari-dark:#ece1c8;--kin:#c9a227;--kin-light:#e8c95a;--shu:#b3402a;--shu-dark:#8d2f1e;--kon:#1f2a44;--kon-light:#33456e;--midori:#7a8c5a;--midori-light:#9cb075;--font-display:"Shippori Mincho", serif;--font-body:"Zen Maru Gothic", sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);color:var(--sumi);background:radial-gradient(ellipse at top, #c9a22714, transparent 60%), linear-gradient(180deg, #f9f4e8 0%, var(--kinari) 40%, #efe5cf 100%);min-height:100vh}#root{max-width:560px;min-height:100vh;margin:0 auto}.app{flex-direction:column;min-height:100vh;padding:12px;display:flex}.btn{font-family:var(--font-body);border:2px solid var(--sumi);color:var(--sumi);cursor:pointer;background:#fff;border-radius:10px;padding:12px 20px;font-size:1rem;font-weight:700;transition:transform 80ms,box-shadow 80ms;box-shadow:0 3px #2b23208c}.btn:active:not(:disabled){transform:translateY(2px);box-shadow:0 1px #2b23208c}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:linear-gradient(180deg, var(--shu) 0%, var(--shu-dark) 100%);border-color:var(--shu-dark);color:#fff;box-shadow:0 3px #5f2015}.btn--ghost{box-shadow:none;background:0 0;border-color:#2b232059}.btn--small{padding:8px 12px;font-size:.85rem}.btn--danger{border-color:var(--shu-dark);color:var(--shu-dark)}.sprite{object-fit:contain;vertical-align:middle;width:1.6em;height:1.6em;display:inline-block}.sprite--emoji{width:auto;height:auto;font-size:1.3em;line-height:1}.title-screen{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;padding:32px 16px;display:flex}.title-crest{filter:drop-shadow(0 4px 6px #2b232040);font-size:3.2rem}.title-logo{font-family:var(--font-display);color:var(--kon);text-shadow:0 2px #c9a22759;flex-direction:column;gap:6px;margin:0;font-size:2.6rem;font-weight:800;line-height:1.25;display:flex}.title-logo__sub{font-family:var(--font-body);letter-spacing:.35em;color:var(--shu);font-size:.8rem;font-weight:500}.title-tagline{color:#2b2320bf;margin:0}.title-buttons{flex-direction:column;gap:12px;width:min(300px,100%);margin-top:8px;display:flex}.title-version{color:#2b232080;font-size:.75rem}.account-panel{border:2px solid var(--kinari-dark);text-align:left;background:#ffffffd1;border-radius:12px;width:min(420px,100%);padding:12px}.account-panel__header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.account-panel__crest{flex-shrink:0;font-size:1.6rem}.account-panel h2{font-family:var(--font-display);color:var(--kon);margin:0;font-size:1rem}.account-panel p{color:#2b2320a8;margin:2px 0 0;font-size:.72rem}.account-panel__setup{background:var(--kinari);border:1px solid var(--kinari-dark);border-radius:8px;padding:10px}.account-panel__setup code{color:var(--shu-dark);font-size:.68rem;font-weight:700}.account-panel__message{font-weight:700;color:var(--shu-dark)!important}.google-signin-slot{min-height:44px}.account-card{grid-template-columns:auto 1fr auto;align-items:center;gap:10px;display:grid}.account-card__avatar{border:2px solid var(--kin);object-fit:cover;border-radius:50%;width:42px;height:42px}.account-card__avatar--fallback{background:var(--kon);color:var(--kinari);justify-content:center;align-items:center;font-weight:700;display:inline-flex}.account-card__body{flex-direction:column;gap:4px;min-width:0;display:flex}.account-card__name{color:var(--kon);font-weight:700}.account-card__email{color:#2b232094;text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;overflow:hidden}.lord-name-field{grid-template-columns:auto 1fr;align-items:center;gap:6px;font-size:.78rem;font-weight:700;display:grid}.lord-name-field input{border:1px solid var(--kinari-dark);width:100%;min-width:0;font-family:var(--font-body);border-radius:8px;padding:7px 8px;font-weight:700}.account-card__actions{flex-direction:column;gap:6px;display:flex}.google-sync-slot{grid-column:1/-1;min-height:40px}.account-panel__sync{font-weight:700;color:var(--kon)!important;margin-top:8px!important}.town-screen{flex-direction:column;flex:1;gap:12px;display:flex}.town-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.town-header__left{flex-direction:column;gap:3px;display:flex}.town-header__title{font-family:var(--font-display);color:var(--kon);margin:0;font-size:1.3rem}.rank-chip{color:var(--shu-dark);font-size:.75rem;font-weight:700}.lord-chips{flex-wrap:wrap;gap:5px;display:flex}.title-chip{color:var(--kon);font-size:.72rem;font-weight:700}.cloud-sync-chip{color:var(--kon);font-size:.7rem;font-weight:800}.cloud-sync-chip--syncing{color:var(--shu-dark)}.cloud-sync-chip--error,.cloud-sync-chip--auth-error{color:#9f1d1d}.resource-bar{gap:8px;display:flex}.resource{background:var(--kon);color:var(--kinari);border:1px solid var(--kin);border-radius:999px;align-items:center;gap:4px;padding:6px 12px;font-size:.9rem;font-weight:700;display:inline-flex}.resource small{opacity:.8;font-weight:400}.quest-bar{border:2px solid var(--kinari-dark);background:#fff;border-radius:12px;align-items:center;gap:10px;padding:8px 12px;display:flex}.quest-bar--done{border-color:var(--kin);box-shadow:0 0 0 2px #c9a22740}.quest-bar__jii{flex-shrink:0;font-size:1.8rem}.quest-bar__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.quest-bar__title{color:var(--kon);font-size:.85rem;font-weight:700}.quest-bar__text{color:#2b2320b3;font-size:.72rem}.quest-bar__exp{align-items:center;gap:6px;display:flex}.quest-bar__exp small{color:#2b23208c;white-space:nowrap;font-size:.62rem}.exp-bar{background:#2b232026;border-radius:999px;flex:1;max-width:120px;height:6px;overflow:hidden}.exp-bar__fill{background:linear-gradient(90deg, var(--kin), var(--kin-light));border-radius:999px;height:100%;transition:width .3s}.quest-bar__claim{white-space:nowrap;flex-shrink:0}.quest-bar--done .quest-bar__claim{background:linear-gradient(180deg, var(--kin-light) 0%, var(--kin) 100%);border-color:var(--kin);animation:1.2s ease-in-out infinite pulse}.lord-profile{border:2px solid var(--kinari-dark);background:#ffffffeb;border-radius:12px;overflow:hidden}.lord-profile__summary{width:100%;color:var(--sumi);text-align:left;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:10px 12px;display:grid}.lord-profile__crest{font-size:1.45rem}.lord-profile__body{flex-direction:column;gap:2px;min-width:0;display:flex}.lord-profile__name{color:var(--kon);text-overflow:ellipsis;white-space:nowrap;font-weight:800;overflow:hidden}.lord-profile__meta{color:#2b23209e;overflow-wrap:anywhere;font-size:.7rem}.lord-profile__toggle{border:1px solid var(--kinari-dark);color:var(--shu-dark);background:var(--kinari);border-radius:999px;padding:4px 9px;font-size:.72rem;font-weight:700}.lord-profile__details{flex-direction:column;gap:12px;padding:0 12px 12px;display:flex}.profile-block h3{font-family:var(--font-display);color:var(--kon);margin:0 0 6px;font-size:.95rem}.title-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.title-option{border:2px solid var(--kinari-dark);min-height:64px;color:var(--sumi);text-align:left;font-family:var(--font-body);cursor:pointer;background:#fff;border-radius:8px;flex-direction:column;gap:2px;padding:8px;display:flex}.title-option--selected{border-color:var(--kin);background:#fdf8ea;box-shadow:0 0 0 2px #c9a22733}.title-option__name{color:var(--kon);font-size:.78rem;font-weight:800}.title-option__desc{color:#2b23209e;font-size:.66rem;line-height:1.35}.achievement-list{flex-direction:column;gap:6px;display:flex}.achievement{border:1px solid var(--kinari-dark);background:#fff;border-radius:8px;grid-template-columns:54px 1fr;align-items:center;gap:8px;padding:7px 8px;display:grid}.achievement--done{border-color:var(--kin);background:#fff8df}.achievement__mark{background:var(--kon);min-height:24px;color:var(--kinari);white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;font-size:.65rem;font-weight:800;display:inline-flex}.achievement--done .achievement__mark{background:var(--shu)}.achievement__body{flex-direction:column;gap:1px;min-width:0;display:flex}.achievement__name{color:var(--kon);font-size:.78rem;font-weight:800}.achievement__desc{color:#2b23209e;font-size:.66rem}.town-grid{grid-template-columns:repeat(var(--grid-size), 1fr);background:linear-gradient(180deg, var(--midori) 0%, #6a7c4d 100%);border:3px solid var(--sumi);border-radius:14px;gap:2px;padding:6px;display:grid;box-shadow:inset 0 2px 8px #00000040}.tile{aspect-ratio:1;cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:clamp(.7rem,2.4vw,1.15rem);transition:transform 80ms;display:flex;position:relative}.tile--empty{background:var(--midori-light);box-shadow:inset 0 -2px #0000001f}.tile--empty:hover{background:#b1c48a}.tile--built{background:var(--kinari-dark);box-shadow:inset 0 -3px #00000026}.tile--selected{outline:2px solid var(--kin);outline-offset:1px;z-index:1;transform:scale(1.15)}.tile--move-target{background:var(--kin-light);animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.tile__level{color:var(--kon);background:#ffffffd9;border-radius:3px;padding:0 2px;font-size:.45rem;font-weight:700;line-height:1.3;position:absolute;bottom:0;right:1px}.town-panel{min-height:96px}.town-panel__hint{text-align:center;color:#2b232099;margin:0;padding:16px 8px;font-size:.85rem}.panel{border:2px solid var(--sumi);background:#fff;border-radius:12px;padding:12px;box-shadow:0 4px #2b232033}.panel__header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.panel__header h3{font-family:var(--font-display);color:var(--kon);margin:0;font-size:1.05rem}.panel__close{cursor:pointer;color:#2b232080;background:0 0;border:none;padding:4px;font-size:1rem}.panel__desc,.panel__prod,.panel__note{color:#2b2320bf;margin:4px 0;font-size:.85rem}.panel__prod{color:var(--kon);font-weight:700}.panel__options{grid-template-columns:repeat(3,1fr);gap:6px;max-height:38vh;display:grid;overflow-y:auto}.build-option{border:2px solid var(--kinari-dark);background:var(--kinari);cursor:pointer;font-family:var(--font-body);border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:10px 6px;transition:border-color .1s;display:flex}.build-option:hover:not(:disabled){border-color:var(--kin)}.build-option:disabled{opacity:.45;cursor:not-allowed}.build-option .sprite--emoji{font-size:1.6rem}.build-option__name{font-size:.9rem;font-weight:700}.build-option__cost{color:var(--shu-dark);gap:4px;font-size:.72rem;font-weight:700;display:flex}.build-option__desc{color:#2b232099;font-size:.65rem}.panel__actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.panel--moving{background:var(--kin-light);justify-content:space-between;align-items:center;gap:8px;display:flex}.panel--moving p{margin:0;font-weight:700}.town-footer{flex-direction:column;gap:8px;padding-bottom:8px;display:flex}.town-footer__secondary{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.town-footer__secondary .btn{white-space:nowrap;padding:10px 8px;font-size:.85rem}.battle-screen{flex-direction:column;flex:1;gap:14px;padding-top:8px;display:flex}.battle-header{justify-content:space-between;align-items:center;display:flex}.battle-header h2{font-family:var(--font-display);color:var(--kon);margin:0}.battle-turn{background:var(--kon);color:var(--kinari);border-radius:999px;padding:4px 12px;font-size:.85rem;font-weight:700}.battle-field{border:3px solid var(--sumi);background:linear-gradient(#d8ccae 0%,#c9bb97 100%);border-radius:14px;flex-direction:column;gap:8px;padding:12px;display:flex}.battle-vs{text-align:center;color:var(--kon);min-height:1.4em;font-size:.95rem;font-weight:700}.battle-row{justify-content:center;gap:8px;display:flex}.unit-card{max-width:150px;font-family:var(--font-body);cursor:default;background:#fffc;border:2px solid #0000;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:8px 6px;display:flex;position:relative}.unit-card:disabled{opacity:1;color:var(--sumi)}.unit-card--active{border-color:var(--kin);box-shadow:0 0 0 2px #c9a22759}.unit-card--targetable{border-color:var(--shu);cursor:pointer;animation:1s ease-in-out infinite pulse}.unit-card--dead{opacity:.45;filter:grayscale()}.unit-card__marker{color:var(--kin);text-shadow:0 1px 2px #0006;font-size:.8rem;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.unit-card__adv{color:#fff;z-index:1;border-radius:999px;padding:1px 6px;font-size:.65rem;font-weight:700;position:absolute;top:-8px;right:-4px}.unit-card__adv--good{background:var(--shu)}.unit-card__adv--bad{background:#6b7280}.unit-card__sprite.sprite--emoji{font-size:1.9rem}.unit-card__name{text-align:center;font-size:.68rem;font-weight:700;line-height:1.2}.unit-card .hp-bar{width:100%}.hp-bar{background:#2b232033;border-radius:999px;height:10px;overflow:hidden}.hp-bar__fill{background:linear-gradient(90deg,#6fae5c,#8fcc72);border-radius:999px;height:100%;transition:width .3s}.hp-bar__fill--low{background:linear-gradient(90deg, var(--shu), #d9603f)}.unit-card__hp{color:#2b2320b3;font-size:.7rem;font-weight:700}.battle-log{background:var(--kon);color:var(--kinari);border-radius:10px;min-height:110px;padding:10px 14px;font-size:.85rem}.battle-log p{margin:3px 0}.battle-log p:last-child{color:var(--kin-light);font-weight:700}.battle-actions{flex-direction:column;gap:8px;display:flex}.battle-actions__prompt{color:var(--kon);align-items:center;gap:6px;min-height:1.5em;font-size:.9rem;display:flex}.battle-actions__buttons{gap:8px;display:flex}.battle-actions__buttons .btn{flex:1}.btn--pressed{transform:translateY(2px);box-shadow:0 1px #5f2015}.troop-badge{align-items:center;gap:4px;display:inline-flex}.troop-badge__kanji{color:#fff;border-radius:5px;justify-content:center;align-items:center;width:1.4em;height:1.4em;font-size:.75rem;font-weight:700;line-height:1;display:inline-flex}.troop-badge__name{font-size:.75rem;font-weight:700}.formation-screen{flex-direction:column;flex:1;gap:12px;padding-top:8px;display:flex}.formation-header{justify-content:space-between;align-items:center;display:flex}.formation-header h2{font-family:var(--font-display);color:var(--kon);margin:0}.formation-count{background:var(--kon);color:var(--kinari);border-radius:999px;padding:4px 12px;font-size:.85rem;font-weight:700}.troop-triangle{border:2px solid var(--kinari-dark);background:#fff;border-radius:10px;justify-content:space-between;gap:8px;padding:8px 12px;display:flex}.troop-triangle__item{flex-direction:column;align-items:center;gap:2px;display:flex}.troop-triangle__item small{color:#2b2320a6;font-size:.65rem}.warlord-list{flex-direction:column;gap:8px;display:flex}.warlord-card{border:2px solid var(--kinari-dark);cursor:pointer;font-family:var(--font-body);text-align:left;background:#fff;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;transition:border-color .1s;display:flex}.warlord-card--selected{border-color:var(--kin);background:#fdf8ea;box-shadow:0 0 0 2px #c9a22740}.warlord-card__slot{text-align:center;width:3em;color:var(--kinari);background:var(--kon);border-radius:6px;flex-shrink:0;padding:3px 0;font-size:.7rem;font-weight:700}.warlord-card:not(.warlord-card--selected) .warlord-card__slot{background:#2b232059}.warlord-card__sprite.sprite--emoji{font-size:1.8rem}.warlord-card__body{flex-direction:column;gap:3px;display:flex}.warlord-card__name{align-items:center;gap:6px;font-size:.9rem;font-weight:700;display:flex}.warlord-card__stats{color:#2b2320b3;align-items:center;gap:8px;font-size:.75rem;display:flex}.rarity{color:#fff;background:#9aa0a6;border-radius:4px;padding:1px 6px;font-size:.65rem;font-weight:700}.rarity--N{background:#9aa0a6}.rarity--R{background:#4a7fbc}.rarity--SR{background:#8c5fc2}.rarity--SSR{background:linear-gradient(135deg, var(--kin), var(--shu))}.formation-hint{text-align:center;color:#2b232099;margin:0;font-size:.8rem}.formation-footer{justify-content:center;padding-bottom:8px;display:flex}.warlords-screen,.gacha-screen{flex-direction:column;flex:1;gap:12px;padding-top:8px;display:flex}.gacha-stage{background:linear-gradient(180deg, var(--kon) 0%, var(--kon-light) 100%);border:3px solid var(--sumi);border-radius:14px;justify-content:center;align-items:center;min-height:220px;padding:16px;display:flex}.gacha-placeholder{color:var(--kinari);opacity:.75;font-weight:700}.gacha-result{background:#fff;border:3px solid #9aa0a6;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:18px 28px;animation:.35s gacha-pop;display:flex}@keyframes gacha-pop{0%{opacity:0;transform:scale(.6)}70%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}.gacha-result--R{border-color:#4a7fbc}.gacha-result--SR{border-color:#8c5fc2;box-shadow:0 0 14px #8c5fc28c}.gacha-result--SSR{border-color:var(--kin);box-shadow:0 0 20px #c9a227bf}.gacha-result__sprite.sprite--emoji{font-size:3rem}.gacha-result__name{font-family:var(--font-display);color:var(--kon);font-size:1.15rem;font-weight:800}.gacha-result__note{color:#2b2320b3;text-align:center;font-size:.8rem}.gacha-pull{align-self:center;min-width:240px}.gacha-warning{text-align:center;color:var(--shu-dark);margin:0;font-size:.8rem;font-weight:700}.gacha-rates{text-align:center;color:#2b2320a6;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;font-size:.75rem;display:flex}.modal-overlay{z-index:100;background:#1f2a44a6;justify-content:center;align-items:center;animation:.25s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.rankup-modal{background:linear-gradient(180deg, #fffdf6 0%, var(--kinari) 100%);border:3px solid var(--kin);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:8px;max-width:min(360px,88vw);padding:26px 30px;animation:.4s gacha-pop;display:flex;box-shadow:0 0 30px #c9a2278c}.rankup-modal__envoy{font-size:2.4rem}.rankup-modal__heading{font-family:var(--font-display);color:var(--kon);margin:0;font-size:1.2rem}.rankup-modal__body{color:#2b2320bf;margin:0;font-size:.85rem}.rankup-modal__rank{font-family:var(--font-display);color:var(--shu);text-shadow:0 1px #c9a22766;margin:6px 0 0;font-size:1.5rem;font-weight:800}.rankup-modal__note{margin:0 0 6px;font-size:.9rem;font-weight:700}.unit-card--hit{animation:.4s hit-shake}@keyframes hit-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.dmg-pop{color:var(--shu);text-shadow:-1px -1px #fff,1px -1px #fff,-1px 1px #fff,1px 1px #fff;pointer-events:none;z-index:2;font-size:1rem;font-weight:800;animation:.9s ease-out forwards dmg-float;position:absolute;top:-4px;left:50%;transform:translate(-50%)}@keyframes dmg-float{0%{opacity:0;transform:translate(-50%,6px)scale(.7)}20%{opacity:1;transform:translate(-50%,-4px)scale(1.15)}to{opacity:0;transform:translate(-50%,-26px)scale(1)}}.town-screen,.battle-screen,.formation-screen,.warlords-screen,.gacha-screen,.title-screen{animation:.25s screen-in}@keyframes screen-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.title-crest{animation:3s ease-in-out infinite crest-float}@keyframes crest-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.battle-result{flex-direction:column;align-items:center;gap:10px;display:flex}.battle-result__msg{margin:0;font-size:1.05rem;font-weight:700}.battle-result__msg--win{color:var(--shu);font-size:1.2rem}
