:root{--color-bg-primary:#0a0e1a;--color-bg-secondary:#111827;--color-bg-card:#111827cc;--color-bg-card-hover:#1e293be6;--color-bg-modal:#000000b3;--color-accent-gold:#f6c343;--color-accent-blue:#3b82f6;--color-accent-teal:#14b8a6;--color-recruited:#22c55e;--color-not-recruited:#6b7280;--color-missable:#ef4444;--color-missable-bg:#ef44441a;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--glass-bg:#ffffff0d;--glass-border:#ffffff1a;--glass-blur:blur(12px);--font-body:"Inter", system-ui, sans-serif;--font-heading:"Cinzel", serif;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--header-height:3.5rem;--bottom-nav-height:3.5rem;--content-max-width:960px;--sidebar-width:240px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);color:var(--color-text-primary);background-color:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-weight:400;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-text-primary);font-weight:600;line-height:1.3}h1{letter-spacing:.02em;font-size:1.75rem}h2{letter-spacing:.01em;font-size:1.375rem}h3{font-size:1.125rem}h4{font-size:1rem}p{color:var(--color-text-secondary);margin-bottom:var(--space-sm)}small{color:var(--color-text-muted);font-size:.8125rem}strong{font-weight:600}a{color:var(--color-accent-blue);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-teal)}ul,ol{list-style:none}img,svg{max-width:100%;height:auto;display:block}button{font-family:var(--font-body);cursor:pointer;color:var(--color-text-primary);transition:all var(--transition-fast);background:0 0;border:none;outline:none;font-size:.875rem;font-weight:500}button:active{transform:scale(.97)}input,select,textarea{font-family:var(--font-body);color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);transition:border-color var(--transition-fast);outline:none;font-size:.875rem}input:focus,select:focus,textarea:focus{border-color:var(--color-accent-blue)}input::placeholder{color:var(--color-text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}::selection{background-color:var(--color-accent-blue);color:var(--color-text-primary)}#app{flex-direction:column;min-height:100dvh;display:flex}.page-content{padding:var(--space-md);padding-top:calc(var(--header-height) + var(--space-md));padding-bottom:calc(var(--bottom-nav-height) + var(--space-md));max-width:var(--content-max-width);flex:1;width:100%;margin:0 auto}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.page-enter{animation:pageEnter var(--transition-slow) forwards}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (width>=768px){h1{font-size:2rem}h2{font-size:1.5rem}.page-content{padding-bottom:var(--space-md)}}.header{height:var(--header-height);padding:0 var(--space-md);background:var(--color-bg-secondary);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);z-index:100;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.header__title{font-family:var(--font-heading);color:var(--color-accent-gold);white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:600;overflow:hidden}.header__back-btn{align-items:center;gap:var(--space-xs);color:var(--color-text-secondary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);display:flex}.header__back-btn:hover{color:var(--color-text-primary);background:var(--glass-bg)}.bottom-nav{height:var(--bottom-nav-height);background:var(--color-bg-secondary);border-top:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);z-index:100;padding-bottom:env(safe-area-inset-bottom);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav__item{padding:var(--space-xs) var(--space-sm);color:var(--color-text-muted);border-radius:var(--radius-sm);transition:color var(--transition-fast);text-transform:uppercase;letter-spacing:.05em;flex-direction:column;align-items:center;gap:2px;font-size:.625rem;font-weight:500;display:flex}.bottom-nav__item:hover{color:var(--color-text-secondary)}.bottom-nav__item.active{color:var(--color-accent-gold)}.bottom-nav__item svg{width:20px;height:20px}@media (width>=768px){.bottom-nav{display:none}}.sidebar-nav{display:none}@media (width>=768px){.sidebar-nav{top:var(--header-height);width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--glass-border);padding:var(--space-md);gap:var(--space-xs);z-index:90;flex-direction:column;display:flex;position:fixed;bottom:0;left:0}.sidebar-nav__item{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:.875rem;font-weight:500;display:flex}.sidebar-nav__item:hover{background:var(--glass-bg);color:var(--color-text-primary)}.sidebar-nav__item.active{color:var(--color-accent-gold);background:#f6c3431a}.sidebar-nav__item svg{width:18px;height:18px}}.card{background:var(--color-bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md);-webkit-backdrop-filter:var(--glass-blur);transition:all var(--transition-normal)}.card:hover{background:var(--color-bg-card-hover);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.card--clickable{cursor:pointer}.card--disabled{opacity:.4;pointer-events:none}.card--disabled:hover{box-shadow:none;transform:none}.character-card{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--color-bg-card);border:1px solid var(--glass-border);cursor:pointer;transition:all var(--transition-normal);display:flex}.character-card:hover{background:var(--color-bg-card-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0003}.character-card.recruited{border-left:3px solid var(--color-recruited)}.character-card.missable:not(.recruited){border-left:3px solid var(--color-missable)}.character-card__avatar{width:40px;height:40px;font-family:var(--font-heading);color:var(--color-bg-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8125rem;font-weight:600;display:flex}.character-card__info{flex:1;min-width:0}.character-card__name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:600;overflow:hidden}.character-card__meta{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.character-card__location{color:var(--color-text-muted);align-items:center;gap:var(--space-xs);font-size:.75rem;display:flex}.checkbox{cursor:pointer;flex-shrink:0;width:24px;height:24px;position:relative}.checkbox__input{opacity:0;cursor:pointer;z-index:1;width:100%;height:100%;position:absolute}.checkbox__indicator{border:2px solid var(--color-not-recruited);width:24px;height:24px;transition:all var(--transition-fast);background:0 0;border-radius:6px;justify-content:center;align-items:center;display:flex}.checkbox__input:checked+.checkbox__indicator{background:var(--color-recruited);border-color:var(--color-recruited);animation:.3s checkBounce}.checkbox__indicator svg{color:#fff;opacity:0;width:14px;height:14px;transition:opacity var(--transition-fast)}.checkbox__input:checked+.checkbox__indicator svg{opacity:1}@keyframes checkBounce{0%{transform:scale(1)}40%{transform:scale(1.2)}to{transform:scale(1)}}.badge{align-items:center;gap:var(--space-xs);text-transform:uppercase;letter-spacing:.03em;border-radius:999px;padding:2px 8px;font-size:.6875rem;font-weight:600;display:inline-flex}.badge--missable{background:var(--color-missable-bg);color:var(--color-missable);border:1px solid #ef44444d}.badge--recruited{color:var(--color-recruited);background:#22c55e1a;border:1px solid #22c55e4d}.badge--exclusive{color:var(--color-accent-blue);background:#3b82f61a;border:1px solid #3b82f64d}.badge--castle{color:var(--color-accent-gold);background:#f6c3431a;border:1px solid #f6c3434d}.progress-ring{justify-content:center;align-items:center;display:inline-flex;position:relative}.progress-ring__svg{transform:rotate(-90deg)}.progress-ring__circle-bg{fill:none;stroke:var(--glass-border)}.progress-ring__circle-fg{fill:none;stroke:var(--color-accent-gold);stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.progress-ring__label{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute}.progress-ring__count{font-family:var(--font-heading);color:var(--color-text-primary);font-size:1.75rem;font-weight:700;line-height:1}.progress-ring__total{color:var(--color-text-muted);font-size:.75rem}.progress-bar{background:var(--glass-border);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar__fill{background:linear-gradient(90deg, var(--color-accent-gold), var(--color-accent-teal));border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.filter-bar{gap:var(--space-sm);margin-bottom:var(--space-md);flex-direction:column;display:flex}.filter-bar__search{position:relative}.filter-bar__search-input{width:100%;padding-left:2.5rem}.filter-bar__search-icon{left:var(--space-sm);width:18px;height:18px;color:var(--color-text-muted);position:absolute;top:50%;transform:translateY(-50%)}.filter-bar__chips{gap:var(--space-xs);flex-wrap:wrap;display:flex}.filter-chip{padding:var(--space-xs) var(--space-sm);background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:999px;font-size:.75rem;font-weight:500}.filter-chip:hover{background:var(--color-bg-card-hover);color:var(--color-text-primary)}.filter-chip.active{border-color:var(--color-accent-gold);color:var(--color-accent-gold);background:#f6c34326}.filter-bar__selects{gap:var(--space-sm);display:flex}.filter-bar__selects select{flex:1;min-width:0}.modal-overlay{background:var(--color-bg-modal);z-index:200;opacity:0;pointer-events:none;transition:opacity var(--transition-normal);justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--color-bg-secondary);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);width:100%;max-width:560px;max-height:85vh;padding:var(--space-lg);transition:transform var(--transition-slow);overflow-y:auto;transform:translateY(100%)}.modal-overlay.open .modal{transform:translateY(0)}.modal__header{margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;display:flex}.modal__close{background:var(--glass-bg);width:32px;height:32px;color:var(--color-text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal__close:hover{background:var(--color-bg-card-hover);color:var(--color-text-primary)}@media (width>=768px){.modal-overlay{align-items:center}.modal{border-radius:var(--radius-lg);opacity:0;max-height:80vh;transform:translateY(24px)}.modal-overlay.open .modal{opacity:1;transform:translateY(0)}}.wt-step{padding:var(--space-md);border-radius:var(--radius-md);background:var(--color-bg-card);border:1px solid var(--glass-border);margin-bottom:var(--space-md)}.wt-step.completed{opacity:.6}.wt-step__header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.wt-step__title{font-size:1rem;font-weight:600}.wt-step__content{color:var(--color-text-secondary);margin-bottom:var(--space-md);font-size:.875rem}.wt-step__substeps{gap:var(--space-xs);flex-direction:column;display:flex}.wt-substep{align-items:flex-start;gap:var(--space-sm);color:var(--color-text-secondary);padding:var(--space-xs) 0;font-size:.8125rem;display:flex}.wt-substep.checked{color:var(--color-text-muted);text-decoration:line-through}.recruit-callout{margin:var(--space-sm) 0;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border-left:3px solid var(--color-accent-teal);justify-content:space-between;align-items:center;gap:var(--space-sm);background:#14b8a60d;display:flex}.recruit-callout.missable{border-left-color:var(--color-missable);background:var(--color-missable-bg)}.recruit-callout__info{flex:1;min-width:0}.recruit-callout__name{color:var(--color-text-primary);font-size:.875rem;font-weight:600}.recruit-callout__detail{color:var(--color-text-muted);font-size:.75rem}.boss-tip{margin:var(--space-sm) 0;padding:var(--space-md);border-radius:var(--radius-sm);background:#f6c3430d;border:1px solid #f6c3434d}.boss-tip__title{color:var(--color-accent-gold);margin-bottom:var(--space-xs);align-items:center;gap:var(--space-xs);font-size:.875rem;font-weight:600;display:flex}.boss-tip__content{color:var(--color-text-secondary);font-size:.8125rem}.missable-warning{padding:var(--space-md);border-radius:var(--radius-sm);background:var(--color-missable-bg);margin:var(--space-sm) 0;border:1px solid #ef444433}.missable-warning__title{color:var(--color-missable);margin-bottom:var(--space-xs);align-items:center;gap:var(--space-xs);font-size:.875rem;font-weight:600;display:flex}.missable-warning__text{color:var(--color-text-secondary);font-size:.8125rem}.toast-container{top:calc(var(--header-height) + var(--space-sm));right:var(--space-md);z-index:300;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:var(--color-bg-secondary);border:1px solid var(--glass-border);color:var(--color-text-primary);animation:toastIn var(--transition-normal) ease forwards;align-items:center;gap:var(--space-sm);font-size:.8125rem;font-weight:500;display:flex;box-shadow:0 8px 24px #0006}.toast--success{border-left:3px solid var(--color-recruited)}.toast--warning{border-left:3px solid var(--color-accent-gold)}.toast--error{border-left:3px solid var(--color-missable)}.toast.removing{animation:toastOut var(--transition-normal) ease forwards}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:.875rem;font-weight:600;display:inline-flex}.btn--primary{background:var(--color-accent-gold);color:var(--color-bg-primary)}.btn--primary:hover{background:#e5b23e;box-shadow:0 4px 12px #f6c3434d}.btn--secondary{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--color-text-primary)}.btn--secondary:hover{background:var(--color-bg-card-hover)}.btn--danger{color:var(--color-missable);background:#ef44441a;border:1px solid #ef44444d}.btn--danger:hover{background:#ef444433}.btn--block{width:100%}.install-prompt{bottom:calc(var(--bottom-nav-height) + var(--space-md));left:var(--space-md);right:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--glass-border);-webkit-backdrop-filter:var(--glass-blur);align-items:center;gap:var(--space-md);z-index:150;animation:slideUp var(--transition-slow) ease forwards;background:linear-gradient(135deg,#3b82f626,#14b8a626);display:flex;position:fixed}.install-prompt.hidden{display:none}.install-prompt__text{color:var(--color-text-secondary);flex:1;font-size:.8125rem}.install-prompt__text strong{color:var(--color-text-primary);margin-bottom:2px;display:block}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (width>=768px){.install-prompt{max-width:360px;left:auto;bottom:var(--space-lg);right:var(--space-lg)}}.section-divider{font-family:var(--font-heading);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;padding:var(--space-md) 0 var(--space-sm);border-bottom:1px solid var(--glass-border);margin-bottom:var(--space-sm);font-size:.75rem;font-weight:600}.empty-state{text-align:center;padding:var(--space-xl) var(--space-md);color:var(--color-text-muted)}.empty-state__icon{margin-bottom:var(--space-sm);font-size:2.5rem}.empty-state__text{font-size:.875rem}.confetti-container{pointer-events:none;z-index:400;position:fixed;inset:0;overflow:hidden}.confetti-piece{width:8px;height:8px;animation:3s ease-in forwards confettiFall;position:absolute;top:-10px}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.page-home{text-align:center;flex-direction:column;align-items:center;display:flex}.page-home__logo{margin-bottom:var(--space-md)}.page-home__logo-icon{margin-bottom:var(--space-xs);font-size:2.5rem}.page-home__title{font-family:var(--font-heading);color:var(--color-accent-gold);margin-bottom:var(--space-xs);font-size:1.5rem}.page-home__subtitle{color:var(--color-text-muted);font-size:.875rem}.page-home__grid{gap:var(--space-md);width:100%;margin:var(--space-lg) 0;grid-template-columns:repeat(2,1fr);display:grid}.game-card{text-align:left;padding:var(--space-lg) var(--space-md)}.game-card__title{font-family:var(--font-heading);margin-bottom:var(--space-xs);font-size:.9375rem;font-weight:600}.game-card__count{color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:.75rem}.game-card__status{color:var(--color-text-muted);font-size:.6875rem;font-style:italic}.page-home__continue{text-align:left;width:100%;padding:var(--space-md);margin-bottom:var(--space-md)}.page-home__continue-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-xs);font-size:.6875rem}.page-home__continue-game{color:var(--color-text-primary);margin-bottom:var(--space-xs);font-size:1rem;font-weight:600}.page-home__continue-meta{color:var(--color-text-muted);font-size:.75rem}@media (width>=768px){.page-home__grid{grid-template-columns:repeat(3,1fr)}}.page-dashboard{gap:var(--space-lg);flex-direction:column;display:flex}.dashboard__hero{text-align:center;padding:var(--space-lg) 0;flex-direction:column;align-items:center;display:flex}.dashboard__game-title{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.15em;color:var(--color-accent-gold);margin-bottom:var(--space-md);font-size:.75rem}.dashboard__progress-label{color:var(--color-text-secondary);margin-top:var(--space-sm);font-size:.875rem}.dashboard__alert{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.8125rem;display:flex}.dashboard__alert--warning{background:var(--color-missable-bg);color:var(--color-missable);border:1px solid #ef444433}.dashboard__nav-cards{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.dashboard__nav-card{text-align:center;padding:var(--space-xl) var(--space-md)}.dashboard__nav-card-icon{margin-bottom:var(--space-sm);font-size:1.5rem}.dashboard__nav-card-title{margin-bottom:var(--space-xs);font-size:.9375rem;font-weight:600}.dashboard__nav-card-meta{color:var(--color-text-muted);font-size:.75rem}.dashboard__save-section{padding:var(--space-md)}.dashboard__save-title{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:.75rem}.dashboard__save-name{margin-bottom:var(--space-xs);font-size:1rem;font-weight:600}.dashboard__save-meta{color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:.75rem}.dashboard__save-actions{gap:var(--space-sm);display:flex}.page-tracker{gap:var(--space-sm);flex-direction:column;display:flex}.tracker__summary{color:var(--color-text-muted);padding:var(--space-xs) 0;justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.tracker__list{gap:var(--space-sm);flex-direction:column;display:flex}.page-walkthrough{gap:var(--space-md);flex-direction:column;display:flex}.walkthrough__chapter-list{gap:var(--space-sm);flex-direction:column;display:flex}.chapter-card{padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.chapter-card__title{font-size:1rem;font-weight:600}.chapter-card__meta{color:var(--color-text-muted);justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.walkthrough-detail__header{margin-bottom:var(--space-md)}.walkthrough-detail__title{font-family:var(--font-heading);margin-bottom:var(--space-xs);font-size:1.25rem}.walkthrough-detail__progress{align-items:center;gap:var(--space-sm);color:var(--color-text-muted);font-size:.75rem;display:flex}.walkthrough-detail__steps{gap:var(--space-md);flex-direction:column;display:flex}.page-settings{gap:var(--space-lg);flex-direction:column;display:flex}.settings__section{padding:var(--space-md)}.settings__section-title{text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted);margin-bottom:var(--space-md);padding-bottom:var(--space-xs);border-bottom:1px solid var(--glass-border);font-size:.6875rem}.settings__row{padding:var(--space-sm) 0;justify-content:space-between;align-items:center;display:flex}.settings__row-label{color:var(--color-text-primary);font-size:.875rem}.settings__row-value{color:var(--color-text-muted);font-size:.8125rem}.settings__actions{gap:var(--space-sm);flex-direction:column;display:flex}.settings__about{text-align:center;padding:var(--space-lg);color:var(--color-text-muted);font-size:.8125rem}.settings__about-title{font-family:var(--font-heading);color:var(--color-accent-gold);margin-bottom:var(--space-xs);font-size:1rem}
