@import"https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;700;900&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0a0a14;--bg-secondary: #1a1a2e;--bg-card: #16213e;--accent-red: #e94560;--accent-green: #4ade80;--accent-yellow: #fbbf24;--accent-purple: #533483;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;font-family:"Noto Serif JP",Hiragino Sans,Meiryo,sans-serif;font-size:16px;line-height:1.5;color:var(--text-primary);color-scheme:dark;background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100dvh;background:var(--bg-primary);background-image:radial-gradient(circle at 20% 80%,rgba(233,69,96,.05) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(83,52,131,.05) 0%,transparent 50%)}#root{min-height:100dvh}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#333;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#555}.lobby{display:flex;flex-direction:column;align-items:center;padding:40px 20px;max-width:480px;margin:0 auto;gap:24px}.lobby__title-area{text-align:center}.lobby__title{font-family:"Noto Serif JP",serif;font-size:48px;font-weight:900;color:#e94560;margin:0;text-shadow:0 0 30px rgba(233,69,96,.4);letter-spacing:8px}.lobby__subtitle{font-size:14px;color:#64748b;margin:4px 0 0}.lobby__description{font-size:13px;color:#94a3b8;text-align:center;line-height:1.6}.lobby__ai-section{width:100%;max-width:280px}.lobby__btn--ai{width:100%;padding:16px 24px;border:none;border-radius:8px;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;background:linear-gradient(135deg,#4ade80,#22c55e);color:#0a0a0a;letter-spacing:2px}.lobby__btn--ai:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #4ade8066}.lobby__btn--ai:disabled{opacity:.5;cursor:not-allowed}.lobby__separator{display:flex;align-items:center;gap:12px;width:100%;max-width:280px}.lobby__separator-line{flex:1;height:1px;background:#1e3a5f}.lobby__separator-text{font-size:12px;color:#64748b;white-space:nowrap}.lobby__room{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:280px}.lobby__room-label{font-size:13px;color:#94a3b8;font-weight:600}.lobby__room-input{width:100%;padding:12px 16px;border:2px solid #1e3a5f;border-radius:8px;background:#16213e99;color:#e2e8f0;font-size:24px;font-weight:700;text-align:center;letter-spacing:8px;font-family:Courier New,monospace;outline:none;transition:border-color .2s ease}.lobby__room-input::placeholder{color:#475569;letter-spacing:2px;font-size:16px}.lobby__room-input:focus{border-color:#e94560;box-shadow:0 0 12px #e945604d}.lobby__room-input:disabled{opacity:.5}.lobby__actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:280px}.lobby__btn{padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit}.lobby__btn:disabled{opacity:.5;cursor:not-allowed}.lobby__btn--create{background:linear-gradient(135deg,#e94560,#c73659);color:#fff}.lobby__btn--create:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #e9456066}.lobby__btn--join{background:linear-gradient(135deg,#0f3460,#16213e);color:#e2e8f0;border:1px solid #1e3a5f}.lobby__btn--join:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #0f346066;border-color:#4ade80}.lobby__error{color:#ef4444;font-size:13px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);padding:8px 14px;border-radius:6px;width:100%;text-align:center}.lobby__rules{background:#16213e66;border:1px solid #1e3a5f;border-radius:8px;padding:16px;width:100%}.lobby__rules h3{font-size:13px;color:#e94560;margin:0 0 8px}.lobby__rules ul{margin:0;padding-left:20px;font-size:12px;color:#94a3b8;line-height:1.8}.waiting-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:60px 20px;max-width:480px;margin:0 auto;min-height:60dvh}.waiting-screen__spinner{width:48px;height:48px;border:4px solid #222;border-top-color:#e94560;border-radius:50%;animation:waiting-spin 1s linear infinite}@keyframes waiting-spin{to{transform:rotate(360deg)}}.waiting-screen__title{font-family:"Noto Serif JP",serif;font-size:20px;color:#e2e8f0;margin:0}.waiting-screen__game-id{font-size:12px;color:#64748b}.waiting-screen__game-id code{background:#64748b33;padding:2px 6px;border-radius:4px;font-family:monospace}.waiting-screen__room-id{font-size:16px;color:#94a3b8;text-align:center}.waiting-screen__room-number{display:inline-block;font-size:32px;font-weight:900;color:#e94560;letter-spacing:8px;font-family:Courier New,monospace;background:#e945601a;border:2px solid rgba(233,69,96,.3);padding:8px 20px;border-radius:8px;margin-top:4px}.waiting-screen__hint{font-size:12px;color:#555;text-align:center;line-height:1.6}.hp-bar{display:flex;align-items:center;gap:8px;width:100%;padding:4px 0}.hp-bar__label{font-size:12px;font-weight:700;color:#ccc;min-width:50px;text-align:right}.hp-bar__track{flex:1;height:12px;background:#1a1a2e;border-radius:6px;overflow:hidden;border:1px solid #333}.hp-bar__fill{height:100%;border-radius:6px;transition:width .5s ease,background-color .3s ease}.hp-bar__value{font-size:12px;font-weight:700;color:#eee;min-width:40px}.card{position:relative;border-radius:8px;background:#16213e;border:2px solid #0f3460;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:default;transition:all .2s ease;-webkit-user-select:none;user-select:none;overflow:hidden}.card--medium{width:80px;height:110px;padding:6px}.card--small{width:56px;height:72px;padding:3px}.card--facedown{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);border-color:#533483}.card__back{font-family:"Noto Serif JP",serif;font-size:28px;color:#533483;opacity:.6}.card--small .card__back{font-size:20px}.card--unit{border-color:#0f3460}.card--range-1{border-color:#e94560;background:linear-gradient(180deg,#16213e,#2a1525)}.card--range-2{border-color:#3b82f6;background:linear-gradient(180deg,#16213e,#152040)}.card--range-3{border-color:#8b5cf6;background:linear-gradient(180deg,#16213e,#1e1540)}.card--range-1 .card__range{color:#e94560;background:#e9456040}.card--range-2 .card__range{color:#3b82f6;background:#3b82f640}.card--range-3 .card__range{color:#8b5cf6;background:#8b5cf640}.card--spell{border-color:#533483;background:linear-gradient(180deg,#16213e,#1e1040)}.card--selected{border-color:#e94560;box-shadow:0 0 12px #e9456099;transform:translateY(-4px)}.card--placeable{border-color:#4ade80;box-shadow:0 0 8px #4ade8066;animation:placeable-pulse 1.5s infinite}@keyframes placeable-pulse{0%,to{box-shadow:0 0 8px #4ade8066}50%{box-shadow:0 0 16px #4ade80b3}}.card--buffed{border-color:#fbbf24}.card[role=button]{cursor:pointer}.card[role=button]:hover{border-color:#e94560;transform:translateY(-2px)}.card__name{font-family:"Noto Serif JP",serif;font-weight:700;color:#eee;line-height:1}.card--medium .card__name{font-size:32px;margin-bottom:2px}.card--small .card__name{font-size:22px}.card__reading{font-size:9px;color:#888;line-height:1;margin-bottom:4px}.card--small .card__reading{font-size:7px;margin-bottom:2px}.card__stats{display:flex;align-items:center;gap:2px;font-size:13px;font-weight:700}.card--small .card__stats{font-size:10px}.card__atk{color:#e94560}.card__atk--buffed{color:#fbbf24;text-shadow:0 0 4px rgba(251,191,36,.5)}.card__atk--debuffed{color:#94a3b8}.card__sep{color:#555}.card__hp{color:#4ade80}.card__range{position:absolute;top:3px;right:3px;font-size:8px;color:#64748b;background:#0000004d;padding:1px 3px;border-radius:3px}.card--small .card__range{font-size:7px;top:2px;right:2px}.card__spell-icon{font-size:12px;color:#a78bfa;margin-top:2px}.card__effect{font-size:7px;color:#888;text-align:center;line-height:1.2;margin-top:4px;max-height:24px;overflow:hidden}.card-wrapper{position:relative;display:inline-block}.card-tooltip{position:absolute;z-index:1000;left:50%;transform:translate(-50%);width:180px;padding:10px 12px;background:#1a1a2e;border:2px solid #e94560;border-radius:10px;box-shadow:0 8px 32px #000000b3,0 0 12px #e945604d;pointer-events:none;animation:tooltip-fade-in .15s ease-out}.card-tooltip--above{bottom:calc(100% + 8px)}.card-tooltip--below{top:calc(100% + 8px)}@keyframes tooltip-fade-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.card-tooltip__name{font-family:"Noto Serif JP",serif;font-size:28px;font-weight:700;color:#eee;text-align:center;line-height:1.1}.card-tooltip__reading{font-size:11px;color:#999;text-align:center;margin-bottom:6px}.card-tooltip__type{font-size:10px;color:#a78bfa;text-align:center;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid #333}.card-tooltip__stats{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#ccc;padding:2px 0}.card-tooltip__label{font-size:10px;color:#888;min-width:32px}.card-tooltip__atk{color:#e94560;font-weight:700}.card-tooltip__atk--buffed{color:#fbbf24;text-shadow:0 0 4px rgba(251,191,36,.5)}.card-tooltip__atk--debuffed{color:#94a3b8}.card-tooltip__hp{color:#4ade80;font-weight:700}.card-tooltip__base{font-size:10px;color:#666;font-weight:400}.card-tooltip__direct{font-size:10px;color:#fbbf24;text-align:center;margin-top:4px}.card-tooltip__effect{font-size:10px;color:#aaa;margin-top:6px;padding-top:4px;border-top:1px solid #333;line-height:1.4}.card-tooltip__effect-label{color:#a78bfa;font-weight:600}.card-tooltip__buffs{font-size:10px;color:#fbbf24;text-align:center;margin-top:4px}.card-tooltip__range{font-weight:700}.card-tooltip__range--1{color:#e94560}.card-tooltip__range--2{color:#3b82f6}.card-tooltip__range--3{color:#8b5cf6}.card-slot{width:60px;height:76px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.card-slot--empty{border:1px dashed #333;background:#16213e4d}.card-slot--placeable{border:2px dashed #4ade80;background:#4ade8014;cursor:pointer;animation:slot-pulse 1.5s infinite}.card-slot--placeable:hover{background:#4ade8026;transform:scale(1.05)}@keyframes slot-pulse{0%,to{border-color:#4ade80}50%{border-color:#22c55e}}.card-slot__plus{font-size:24px;color:#4ade80;font-weight:300}.card-slot__empty{width:100%;height:100%}.card-slot--ghost{opacity:.5;border:1px dashed #fbbf24;background:#fbbf240f}.player-field{display:flex;flex-direction:column;gap:4px;padding:8px;border-radius:8px;background:#0f346026}.player-field--opponent{border-bottom:2px solid #e94560}.player-field--own{border-top:2px solid #4ade80}.player-field__row{display:flex;align-items:center;gap:6px}.player-field__row-label{font-size:9px;color:#64748b;min-width:72px;text-align:center;font-weight:700;white-space:nowrap}.hand-area{padding:8px}.hand-area__label{font-size:11px;color:#64748b;margin-bottom:6px;font-weight:700}.hand-area__cards{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.hand-area__empty{font-size:12px;color:#555;padding:20px}.battle-log{background:#0a0a1499;border-radius:8px;border:1px solid #222;overflow:hidden;display:flex;flex-direction:column;max-height:200px}.battle-log__header{font-size:11px;font-weight:700;color:#888;padding:6px 10px;border-bottom:1px solid #222;background:#0000004d}.battle-log__entries{overflow-y:auto;padding:6px 10px;flex:1}.battle-log__empty{font-size:11px;color:#555;text-align:center;padding:10px}.battle-log__turn{margin-bottom:6px}.battle-log__turn-header{font-size:10px;color:#e94560;font-weight:700;margin-bottom:2px}.battle-log__event{font-size:10px;color:#aaa;padding:1px 0 1px 8px;line-height:1.4}.waiting-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.waiting-overlay__content{display:flex;flex-direction:column;align-items:center;gap:16px}.waiting-overlay__spinner{width:40px;height:40px;border:3px solid #333;border-top-color:#e94560;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.waiting-overlay__message{font-size:14px;color:#ccc;text-align:center}.game-board{position:relative;display:flex;flex-direction:column;gap:6px;padding:8px;max-width:480px;margin:0 auto;min-height:100dvh}.game-board__header{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.game-board__title{font-family:"Noto Serif JP",serif;font-size:16px;font-weight:700;color:#e94560}.game-board__turn{font-size:13px;font-weight:700;color:#fbbf24}.game-board__role{font-size:11px;color:#64748b;background:#64748b33;padding:2px 8px;border-radius:4px}.game-board__quit-btn{font-size:11px;padding:3px 10px;border:1px solid #e94560;border-radius:4px;background:#e9456026;color:#e94560;cursor:pointer;transition:background .2s}.game-board__quit-btn:hover{background:#e9456059}.game-board__center{display:flex;align-items:center;gap:8px;padding:2px 0}.game-board__divider{flex:1;height:1px;background:linear-gradient(to right,transparent,#333,transparent)}.game-board__vs{font-size:10px;font-weight:700;color:#555;letter-spacing:2px}.game-board__staging{display:flex;flex-direction:column;gap:6px;padding:6px 0}.game-board__staging-label{font-size:11px;font-weight:700;color:#fbbf24}.game-board__staged-list{display:flex;flex-direction:column;gap:3px}.game-board__staged-item{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background:#fbbf241a;border:1px solid rgba(251,191,36,.25);border-radius:4px;font-size:12px;color:#e2e8f0;animation:staged-enter .2s ease-out}@keyframes staged-enter{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.game-board__staged-text{flex:1}.game-board__staged-remove{background:none;border:none;color:#e94560;cursor:pointer;font-size:12px;padding:2px 6px;border-radius:3px;transition:background .15s}.game-board__staged-remove:hover{background:#e9456033}.game-board__actions{display:flex;gap:8px;justify-content:center;padding:4px 0}.game-board__action-btn{padding:8px 20px;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit}.game-board__action-btn--spell{background:linear-gradient(135deg,#533483,#3b0764);color:#e2e8f0}.game-board__action-btn--spell:hover{transform:translateY(-1px);box-shadow:0 2px 8px #53348380}.game-board__action-btn--confirm{background:linear-gradient(135deg,#e94560,#c0392b);color:#fff}.game-board__action-btn--confirm:hover{transform:translateY(-1px);box-shadow:0 2px 8px #e9456080}.game-board__action-btn--skip{background:#3339;color:#94a3b8;border:1px solid #444}.game-board__action-btn--skip:hover{background:#333333e6;color:#e2e8f0}.game-board__rules-hint{padding:4px 0}.game-board__rules-hint details{border:1px solid #333;border-radius:6px;background:#0f346026}.game-board__rules-hint summary{padding:6px 10px;font-size:11px;color:#64748b;cursor:pointer;-webkit-user-select:none;user-select:none}.game-board__rules-hint summary:hover{color:#94a3b8}.game-board__rules-content{padding:6px 12px 10px;font-size:11px;color:#94a3b8;line-height:1.6}.game-board__rules-content p{margin:2px 0}.game-board__rules-content strong{color:#e2e8f0}.game-board__info{display:flex;justify-content:space-around;font-size:10px;color:#555;padding:2px 0}.field-anim-place{animation:field-place .4s ease-out}@keyframes field-place{0%{transform:scale(.95);opacity:.6}50%{transform:scale(1.03)}to{transform:scale(1);opacity:1}}.field-anim-attack{animation:field-attack .35s ease-in-out}@keyframes field-attack{0%{transform:translateY(0)}30%{transform:translateY(-6px)}60%{transform:translateY(3px)}to{transform:translateY(0)}}.field-anim-damage{animation:field-damage .4s ease-in-out}@keyframes field-damage{0%{transform:translate(0);box-shadow:none}15%{transform:translate(-5px);box-shadow:inset 0 0 20px #e9456066}30%{transform:translate(5px)}45%{transform:translate(-3px);box-shadow:inset 0 0 15px #e945604d}60%{transform:translate(3px)}to{transform:translate(0);box-shadow:none}}.field-anim-destroy{animation:field-destroy .5s ease-out}@keyframes field-destroy{0%{opacity:1;filter:brightness(1)}30%{opacity:1;filter:brightness(2)}to{opacity:.6;filter:brightness(.7)}}.field-anim-heal{animation:field-heal .4s ease-in-out}@keyframes field-heal{0%{box-shadow:none}50%{box-shadow:inset 0 0 25px #4ade8066}to{box-shadow:none}}.field-anim-spell{animation:field-spell .4s ease-in-out}@keyframes field-spell{0%{box-shadow:none}30%{box-shadow:0 0 20px #a855f780}70%{box-shadow:0 0 30px #a855f74d}to{box-shadow:none}}.battle-float-container{position:absolute;inset:0;pointer-events:none;z-index:20;overflow:visible}.battle-float{position:absolute;left:50%;top:30%;transform:translate(-50%);font-size:14px;font-weight:700;white-space:nowrap;text-shadow:0 1px 4px rgba(0,0,0,.8);animation:float-up .9s ease-out forwards;pointer-events:none;z-index:25}@keyframes float-up{0%{opacity:1;transform:translate(-50%) translateY(0)}70%{opacity:1;transform:translate(-50%) translateY(-30px)}to{opacity:0;transform:translate(-50%) translateY(-45px)}}.float-damage{color:#f44;font-size:18px}.float-heal{color:#4ade80;font-size:16px}.float-info{color:#93c5fd;font-size:13px}.float-destroy{color:#f97316;font-size:16px}.float-base{color:#fbbf24;font-size:20px}.battle-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:100;padding:12px 40px;border-radius:8px;background:#000000d9;color:#fff;font-size:20px;font-weight:700;text-align:center;white-space:nowrap;animation:banner-pop .3s ease-out;pointer-events:none}.battle-banner--phase{border:2px solid #e94560}.battle-banner--info{border:2px solid #93c5fd}@keyframes banner-pop{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.battle-skip-btn{position:fixed;bottom:16px;right:16px;z-index:110;padding:8px 16px;background:#1e293be6;color:#94a3b8;border:1px solid #475569;border-radius:6px;cursor:pointer;font-size:13px;transition:all .15s}.battle-skip-btn:hover{background:#334155f2;color:#e2e8f0}.hp-flash{animation:hp-flash-anim .5s ease-in-out}@keyframes hp-flash-anim{0%{filter:brightness(1)}25%{filter:brightness(1.5) saturate(2)}50%{filter:brightness(.8)}75%{filter:brightness(1.3) saturate(1.5)}to{filter:brightness(1)}}.result-screen{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 20px;max-width:480px;margin:0 auto}.result-screen__banner{text-align:center;padding:32px;border-radius:12px;width:100%}.result--win{background:linear-gradient(135deg,#4ade8026,#22c55e14);border:2px solid #4ade80}.result--lose{background:linear-gradient(135deg,#ef444426,#dc262614);border:2px solid #ef4444}.result--draw{background:linear-gradient(135deg,#fbbf2426,#f59e0b14);border:2px solid #fbbf24}.result-screen__text{font-family:"Noto Serif JP",serif;font-size:36px;font-weight:900;margin-bottom:8px}.result--win .result-screen__text{color:#4ade80;text-shadow:0 0 20px rgba(74,222,128,.4)}.result--lose .result-screen__text{color:#ef4444;text-shadow:0 0 20px rgba(239,68,68,.4)}.result--draw .result-screen__text{color:#fbbf24;text-shadow:0 0 20px rgba(251,191,36,.4)}.result-screen__score{font-size:14px;color:#94a3b8;margin-bottom:4px}.result-screen__turn{font-size:12px;color:#64748b}.result-screen__btn{padding:12px 32px;border:none;border-radius:8px;background:linear-gradient(135deg,#0f3460,#16213e);color:#e2e8f0;border:1px solid #1e3a5f;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit}.result-screen__btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0f346066}
