*{box-sizing:border-box;margin:0;padding:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}:root{--bg-dark:#0a0e27;--bg-card:#1a1f3a;--bg-card-elevated:#2a2f4a;--accent-primary:#f36;--accent-primary-dark:#c03;--accent-secondary:#00d4ff;--accent-secondary-dark:#08c;--accent-gold:gold;--accent-orange:#f59e0b;--accent-purple:#7b52d4;--accent-purple-dark:#5a3fa0;--accent-danger:#e74c3c;--accent-danger-dark:#c0392b;--accent-success:#4caf50;--text-primary:#fff;--text-secondary:#a0a8c0;--text-muted:#6b7280;--navbar-height:60px;--notation-p:#f5c542;--notation-k:#ff4d4d;--notation-t:#3b8eea;--notation-h:#2ecc71;--notation-s:#c084fc;--notation-a:#f472b6;--font-heading:"Orbitron", sans-serif;--font-body:"Inter", sans-serif;--border-color:#ffffff1f;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-neon:0 0 20px #f366;--shadow-neon-blue:0 0 20px #00d4ff66}body{font-family:var(--font-body);background:var(--bg-dark);color:var(--text-primary);background-image:radial-gradient(circle at 20% 20%,#ff33661a 0%,#0000 50%),radial-gradient(circle at 80% 80%,#00d4ff1a 0%,#0000 50%);height:100vh;overflow:hidden}#app{height:100vh;position:relative;overflow:hidden}.navbar{z-index:100;height:var(--navbar-height);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0e27d9;border-bottom:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:sticky;top:0}.navbar-brand{cursor:pointer;align-items:center;gap:.6rem;text-decoration:none;transition:opacity .2s;display:flex}.navbar-brand:hover .navbar-logo{filter:drop-shadow(0 0 6px var(--accent-primary));transform:scale(1.1)rotate(-5deg)}.navbar-brand:hover .navbar-name{text-shadow:0 0 12px var(--accent-primary)}.navbar-logo{object-fit:contain;width:28px;height:28px;transition:transform .25s,filter .25s}.navbar-name{font-family:var(--font-heading);color:var(--accent-primary);letter-spacing:.5px;font-size:1rem;font-weight:700;transition:text-shadow .25s}.navbar-actions{align-items:center;gap:1rem;display:flex}.navbar-links{align-items:center;gap:.25rem;display:flex}.navbar-link{color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.4rem .9rem;font-size:.9rem;transition:all .2s}.navbar-link:hover{color:var(--text-primary);background:#ffffff0f;transform:translateY(-1px)}.navbar-link.active{color:var(--accent-secondary);background:#00d4ff14}.navbar-user{align-items:center;gap:1rem;display:flex}.navbar-username{color:var(--text-secondary);font-size:.9rem}.navbar-login-btn{border:1px solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:8px;padding:.45rem 1.2rem;font-size:.9rem;transition:all .2s}.navbar-login-btn:hover{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-neon)}.navbar-logout-btn{color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:8px;padding:.45rem 1.2rem;font-size:.9rem;transition:all .2s}.navbar-logout-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.navbar-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;padding:.4rem;display:none}.navbar-hamburger span{background:var(--text-secondary);border-radius:2px;width:22px;height:2px;transition:all .25s;display:block}.navbar-hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.navbar-hamburger.open span:nth-child(2){opacity:0}.navbar-hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.navbar-drawer{top:var(--navbar-height);z-index:99;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0e27f7;border-bottom:1px solid #ffffff12;flex-direction:column;align-items:flex-start;gap:.25rem;padding:1rem 1.5rem 1.5rem;animation:.2s drawerSlideDown;display:flex;position:fixed;left:0;right:0}@keyframes drawerSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.navbar-drawer .navbar-link{text-align:left;width:100%;padding:.65rem .9rem;font-size:1rem}.navbar-drawer-divider{background:#ffffff12;width:100%;height:1px;margin:.5rem 0}.navbar-drawer .navbar-username{padding:.25rem .9rem;font-size:.9rem}.navbar-drawer .navbar-login-btn,.navbar-drawer .navbar-logout-btn{margin-left:.5rem}@media (width<=640px){.navbar-links,.navbar-actions{display:none}.navbar-hamburger{display:flex}.page-top-bar{flex-wrap:wrap}.page-top-bar .breadcrumb{flex-wrap:wrap;flex-shrink:1;min-width:0}.page-top-bar .search-box{flex:none;order:3;width:100%;padding:0}}.login-page{justify-content:center;align-items:center;min-height:100%;padding:2rem;display:flex}.login-card{background:var(--bg-card);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid #ffffff12;border-radius:20px;padding:3rem 2.5rem}.login-header{text-align:center;margin-bottom:2rem}.login-logo{object-fit:contain;width:100px;height:100px;filter:drop-shadow(0 0 10px var(--accent-primary));margin-bottom:1rem}.login-title{font-family:var(--font-heading);color:var(--accent-primary);margin-bottom:.5rem;font-size:1.8rem}.login-subtitle{color:var(--text-secondary);font-size:.95rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-error{color:var(--accent-primary);background:#ff33661a;border:1px solid #ff33664d;border-radius:8px;padding:.75rem 1rem;font-size:.9rem}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:600}.form-input{color:var(--text-primary);font-family:var(--font-body);background:#0000004d;border:1px solid #ffffff1a;border-radius:8px;padding:.75rem 1rem;font-size:.95rem;transition:all .2s}.form-input:focus{border-color:var(--accent-secondary);outline:none;box-shadow:0 0 10px #00d4ff33}.form-input::placeholder{color:var(--text-muted)}.login-btn{background:linear-gradient(135deg, var(--accent-primary), var(--accent-primary-dark));color:#fff;width:100%;font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;border:none;border-radius:8px;margin-top:.5rem;padding:.85rem;font-size:.95rem;font-weight:600;transition:all .3s}.login-btn:hover:not(:disabled){box-shadow:var(--shadow-neon);transform:translateY(-2px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-btn-secondary{width:100%;color:var(--text-muted);border:1px solid var(--border-color);font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;background:0 0;border-radius:8px;margin-top:.5rem;padding:.85rem;font-size:.95rem;font-weight:600;transition:all .3s}.login-btn-secondary:hover{color:var(--text-primary);border-color:var(--text-muted);transform:translateY(-2px)}.fade-in{animation:.5s ease-in fadeIn}.slide-up{animation:.6s ease-out slideUp}.slide-down{animation:.6s ease-out slideDown}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.breadcrumb{flex-wrap:wrap;align-items:center;gap:.35rem;margin-bottom:2rem;padding:0;font-size:.9rem;display:flex}.breadcrumb-item{align-items:center;gap:.35rem;display:flex}.breadcrumb-btn{color:var(--text-secondary);font-size:.875rem;font-family:var(--font-body);cursor:pointer;white-space:nowrap;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50px;align-items:center;padding:.4rem 1rem;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.breadcrumb-btn:hover{border-color:var(--accent-secondary);color:var(--text-primary);background:#ffffff1f}.breadcrumb-current{color:var(--text-primary);opacity:.5;white-space:nowrap;background:#ffffff05;border:1px solid #ffffff0d;border-radius:50px;align-items:center;padding:.4rem 1rem;font-size:.875rem;font-weight:600;display:inline-flex}.breadcrumb-separator{color:var(--text-muted);-webkit-user-select:none;user-select:none;opacity:.4;font-size:1rem}.loading-spinner{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.spinner{border:4px solid #00d4ff1a;border-top-color:var(--accent-secondary);border-radius:50%;width:50px;height:50px;margin-bottom:1rem;animation:1s linear infinite spin}.loading-spinner p{color:var(--text-secondary);font-size:1.1rem}.error-message{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.error-message p{color:var(--accent-primary);margin-bottom:1.5rem;font-size:1.1rem}.error-message .btn-primary{background:linear-gradient(135deg, var(--accent-primary), var(--accent-primary-dark));color:#fff;font-family:var(--font-heading);cursor:pointer;border:none;border-radius:8px;padding:.75rem 2rem;font-size:1rem;transition:all .3s}.error-message .btn-primary:hover{box-shadow:var(--shadow-neon);transform:translateY(-2px)}.landing-page{text-align:center;flex-direction:column;align-items:center;gap:5rem;max-width:960px;margin:0 auto;padding:3rem 2rem 5rem;display:flex}.section-title{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:2px;color:var(--accent-primary);margin-bottom:2rem;font-size:1.2rem;font-weight:700}.hero-section{flex-direction:column;align-items:center;gap:.75rem;padding-top:1rem;display:flex}.hero-avatar{border:3px solid var(--accent-primary);border-radius:50%;width:110px;height:110px;margin-bottom:.5rem;overflow:hidden;box-shadow:0 0 24px #ff336673}.hero-avatar img{object-fit:cover;width:100%;height:100%}.hero-name{font-family:var(--font-heading);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;letter-spacing:1px;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2rem,6vw,3.5rem);font-weight:900}.hero-tagline{color:var(--text-secondary);margin:0;font-size:1rem}.hero-location{color:var(--text-muted);margin:0;font-size:.85rem}.about-section{width:100%}.about-grid{text-align:left;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;display:grid}.about-card{background:var(--bg-card);border:1px solid #ffffff0d;border-radius:14px;padding:1.5rem;transition:transform .25s,box-shadow .25s}.about-card:hover{box-shadow:var(--shadow-neon);transform:translateY(-4px)}.about-card h3{font-family:var(--font-heading);color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.6rem;font-size:1rem}.about-card p{color:var(--text-secondary);margin:0;font-size:.875rem;line-height:1.6}.explore-section{width:100%}.explore-grid{text-align:left;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;display:grid}.explore-card{background:var(--bg-card);cursor:pointer;border:1px solid #ffffff0d;border-radius:14px;flex-direction:column;gap:.6rem;padding:2rem;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex}.explore-card:hover{box-shadow:var(--shadow-neon);border-color:var(--accent-primary);transform:translateY(-5px)}.explore-card h3{font-family:var(--font-heading);color:var(--text-primary);margin:0;font-size:1.2rem}.explore-card p{color:var(--text-secondary);flex:1;margin:0;font-size:.875rem;line-height:1.6}.explore-card-link{color:var(--accent-primary);margin-top:.25rem;font-size:.85rem;font-weight:600}.links-section{width:100%}.links-bar{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.link-badge{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);border-radius:999px;align-items:center;gap:.4rem;padding:.5rem 1.1rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:border-color .2s,box-shadow .2s,transform .2s;display:flex}.link-badge:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 0 10px #ff33664d}.link-badge--muted{opacity:.4}.link-badge--muted:hover{opacity:.6;border-color:var(--border-color);box-shadow:none;transform:none}.link-badge-icon{object-fit:contain;width:18px;height:18px}.btn-primary{font-family:var(--font-heading);background:linear-gradient(135deg, var(--accent-primary), var(--accent-primary-dark));color:#fff;cursor:pointer;box-shadow:var(--shadow-neon);text-transform:uppercase;letter-spacing:1px;border:none;border-radius:50px;padding:1rem 3rem;font-size:1.2rem;font-weight:700;transition:all .3s}.btn-primary:hover{transform:translateY(-2px)scale(1.05);box-shadow:0 0 30px #f369}.btn-primary:active{transform:translateY(0)scale(1)}.game-selection{max-width:1200px;min-height:100%;margin-left:auto;margin-right:auto;padding:2rem}.game-selection>.page-top-bar{max-width:1200px;margin-left:auto;margin-right:auto}.page-header{text-align:center;margin-bottom:3rem;position:relative}.page-header-row{justify-content:center;align-items:center;gap:1rem;display:flex;position:relative}.page-header-row>div{text-align:center}.page-header-row .btn-add{position:absolute;top:50%;right:0;transform:translateY(-50%)}.page-header-row .btn-add:hover{transform:translateY(calc(-50% - 1px))}.search-box{flex:1;justify-content:center;padding:0 1rem;display:flex}.search-input{background:var(--bg-card);color:var(--text-primary);font-size:.875rem;font-family:var(--font-body);border:1px solid #ffffff2e;border-radius:24px;outline:none;width:100%;padding:.45rem 1rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--accent-secondary);box-shadow:0 0 0 3px #00d4ff26}.search-input::placeholder{color:var(--text-muted)}.search-input::-webkit-search-cancel-button{appearance:none;cursor:pointer;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M1 1l12 12M13 1L1 13' stroke='%23888' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") 50% no-repeat;width:14px;height:14px}.page-title{font-family:var(--font-heading);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:clamp(2rem,5vw,3.5rem)}.page-subtitle{color:var(--text-secondary);font-size:1.2rem}.games-grid{flex-wrap:wrap;justify-content:center;gap:2rem;max-width:1200px;min-height:260px;margin:0 auto;display:flex}.game-card{background:var(--bg-card);cursor:pointer;border:2px solid #ffffff0d;border-radius:20px;flex-direction:column;flex-shrink:0;width:340px;transition:all .3s;display:flex;position:relative;overflow:hidden}.game-card:before{content:"";opacity:0;background:linear-gradient(135deg,#ff33661a,#00d4ff1a);transition:opacity .4s;position:absolute;inset:0}.game-card:hover{box-shadow:var(--shadow-lg), var(--shadow-neon);border-color:var(--accent-primary);transform:translateY(-4px)}.game-card:hover:before{opacity:1}.game-cover{background:linear-gradient(135deg, var(--bg-card), var(--bg-card-elevated));justify-content:center;align-items:center;width:100%;height:300px;font-size:4rem;display:flex;position:relative;overflow:hidden}.game-cover img{object-fit:cover;width:100%;height:100%}.game-cover:after{content:"";opacity:0;background:radial-gradient(circle,#f363 0%,#0000 70%);width:200%;height:200%;transition:opacity .4s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.game-card:hover .game-cover:after{opacity:1}.game-info{z-index:1;flex-direction:column;flex:1;padding:1.5rem;display:flex;position:relative}.game-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:.5rem;font-size:1.5rem}.game-meta{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.game-description{color:var(--text-muted);-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;flex:1;font-size:.95rem;line-height:1.6;display:-webkit-box;overflow:hidden}.card-admin-actions{z-index:10;opacity:0;gap:.4rem;transition:opacity .2s,transform .2s;display:flex;position:absolute;top:.75rem;right:.75rem;transform:translateY(-4px)}.game-card:hover .card-admin-actions,.character-card:hover .card-admin-actions{opacity:1;transform:translateY(0)}.btn-edit-small,.btn-delete-small{cursor:pointer;font-size:.75rem;font-family:var(--font-heading);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:.3rem;padding:.35rem .75rem;font-weight:600;transition:all .2s;display:flex}.btn-edit-small{color:var(--text-primary);background:#141428bf;border:1px solid #ffffff26}.btn-edit-small:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#ffc80040;transform:translateY(-1px)}.btn-delete-small{color:var(--text-primary);background:#141428bf;border:1px solid #ffffff26}.btn-delete-small:hover{border-color:var(--accent-danger);color:var(--accent-danger);background:#ff323240;transform:translateY(-1px)}.doa-disclaimer{text-align:center;color:var(--text-muted);opacity:.7;border-top:1px solid #ffffff0d;margin-top:3rem;padding:.75rem 1rem;font-size:1rem;line-height:1.6}.doa-disclaimer a{color:var(--text-muted);text-underline-offset:2px;text-decoration:underline}.game-details-page{max-width:1200px;min-height:100%;margin:0 auto;padding:2rem}.game-details-header{background:var(--bg-card);box-shadow:var(--shadow-md);border:1px solid #ffffff0d;border-radius:16px;align-items:flex-start;gap:2rem;margin-bottom:2rem;padding:2rem;display:flex}.game-title-row{display:none}.game-left{flex-direction:column;flex-shrink:0;align-items:center;gap:1rem;width:min(280px,60vw);display:flex}.game-cover-large{background:linear-gradient(135deg, var(--bg-card), var(--bg-card-elevated));border:3px solid var(--accent-primary);width:min(280px,60vw);height:min(280px,60vw);box-shadow:var(--shadow-neon);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;font-size:5rem;display:flex;overflow:hidden}.game-cover-img{object-fit:cover;object-position:center top;width:100%;height:100%}.game-version-badge{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-secondary-dark));color:#fff;text-align:center;box-sizing:border-box;border-radius:8px;width:100%;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-block}.game-version-select{color:#fff;width:100%;font-size:.85rem;font-weight:600;font-family:var(--font-body);cursor:pointer;appearance:auto;background:0 0;border:none;padding:0}.game-version-select option{background:var(--bg-card);color:var(--text-primary)}.version-picker-list{flex-direction:column;gap:.6rem;margin:1rem 0;display:flex}.btn-version-pick{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-secondary-dark));color:#fff;width:100%;font-family:var(--font-heading);cursor:pointer;text-align:left;border:none;border-radius:8px;padding:.7rem 1.2rem;font-size:1rem;font-weight:600;transition:all .2s}.btn-version-pick:hover{box-shadow:var(--shadow-neon-blue);transform:translate(4px)}.btn-version-pick-delete{background:linear-gradient(135deg, var(--accent-danger-dark), var(--accent-danger))}.btn-version-pick-delete:hover{box-shadow:0 0 12px #e74c3c99}.game-details-full{flex:1}.game-main-title{font-family:var(--font-heading);color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;margin-bottom:1.5rem;font-size:2.5rem}.game-info-list{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.info-row-description{flex-direction:column;grid-column:1/-1;align-items:flex-start;gap:.5rem}.character-roster-section{background:var(--bg-card);box-shadow:var(--shadow-md);border:1px solid #ffffff0d;border-radius:16px;padding:2rem}.section-header{border-bottom:2px solid #ffffff1a;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;display:flex}.section-header h2{font-family:var(--font-heading);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:1px;white-space:nowrap;font-size:1.8rem}.section-header-actions{flex-shrink:0;align-items:center;gap:1rem;display:flex}.character-count{color:var(--accent-secondary);background:#00d4ff1a;border-radius:20px;padding:.4rem 1rem;font-size:.9rem;font-weight:600}.character-selection{min-height:100%;padding:2rem}.selected-game-banner{background:var(--bg-card);text-align:center;box-shadow:var(--shadow-md);border:1px solid #ffffff0d;border-radius:16px;margin-bottom:3rem;padding:2rem}.selected-game-banner h2{font-family:var(--font-heading);color:var(--accent-secondary);margin-bottom:.5rem;font-size:2rem}.characters-grid{flex-wrap:wrap;justify-content:center;gap:1.5rem;max-width:1400px;margin:0 auto;padding:2rem;display:flex}.character-card{background:var(--bg-card);cursor:pointer;border:2px solid #ffffff0d;border-radius:16px;flex-direction:column;flex-shrink:0;width:220px;transition:all .3s;display:flex;position:relative;overflow:hidden}.character-card:hover{box-shadow:var(--shadow-lg), var(--shadow-neon-blue);border-color:var(--accent-secondary);transform:translateY(-4px)}.character-portrait{background:linear-gradient(135deg, var(--bg-card), var(--bg-card-elevated));justify-content:center;align-items:center;width:100%;height:220px;font-size:3rem;display:flex;position:relative;overflow:hidden}.character-portrait-img{object-fit:contain;width:100%;height:100%}.character-info{text-align:center;background:#0000004d;flex-direction:column;flex:1;justify-content:center;width:100%;padding:.75rem;display:flex}.character-name{font-family:var(--font-heading);margin-bottom:.25rem;font-size:1.1rem}.character-style{color:var(--text-secondary);font-size:.85rem;font-style:italic}.frame-data-page{max-width:1200px;min-height:100%;margin:0 auto;padding:2rem}.character-header{background:var(--bg-card);box-shadow:var(--shadow-md);border:1px solid #ffffff0d;border-radius:16px;align-items:flex-start;gap:2rem;margin-bottom:2rem;padding:2rem;display:flex}.character-title-row{display:none}.character-left{flex-direction:column;flex-shrink:0;align-items:center;gap:1rem;width:min(280px,60vw);display:flex}.character-avatar-large{background:linear-gradient(135deg, var(--bg-card), var(--bg-card-elevated));border:3px solid var(--accent-primary);width:min(280px,60vw);height:min(280px,60vw);box-shadow:var(--shadow-neon);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;font-size:5rem;display:flex;overflow:hidden}.character-image{object-fit:contain;width:100%;height:100%}.character-details-full{flex:1}.character-main-name{font-family:var(--font-heading);color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;margin-bottom:1.5rem;font-size:2.5rem}.character-game-badge{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-secondary-dark));color:#fff;text-align:center;box-sizing:border-box;border-radius:8px;width:100%;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-block}.character-info-list{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.info-row{border-bottom:1px solid #ffffff0d;align-items:baseline;gap:.5rem;padding-bottom:.5rem;display:flex}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-secondary);min-width:140px;font-weight:600}.info-value{color:var(--text-primary);flex:1}.move-row-wrapper{position:relative}.move-category-separator{background:#00000040;border-top:2px solid #ffffff0f;border-bottom:1px solid #ffffff0a;align-items:center;padding:.6rem 1.5rem;display:flex}.move-category-label{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);white-space:nowrap;font-size:.7rem;font-weight:700}.move-row-admin{background:#00000026;border-top:1px solid #ffffff0a;justify-content:flex-end;gap:.4rem;padding:.3rem 1rem .5rem;display:flex}.move-string-form{flex:1;min-height:0;padding-right:.5rem;overflow-y:auto}.modal-xl .move-entry .edit-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.move-entry .form-input{padding:.55rem .75rem;font-size:.88rem}.move-entry .form-label{font-size:.78rem}.moves-section{margin-top:1.5rem}.moves-section-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.btn-add-move{color:var(--accent-secondary);cursor:pointer;background:#00d4ff26;border:1px solid #00d4ff4d;border-radius:8px;padding:.35rem .9rem;font-size:.8rem;font-weight:600;transition:all .2s}.btn-add-move:hover{border-color:var(--accent-secondary);background:#00d4ff4d}.move-entry{background:#0003;border:1px solid #ffffff12;border-radius:12px;margin-bottom:1rem;padding:1rem}.move-entry-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.move-entry-title{font-family:var(--font-heading);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:1px;font-size:.9rem}.btn-remove-move{color:var(--accent-danger);cursor:pointer;background:#ff32321a;border:1px solid #ff323233;border-radius:6px;padding:.25rem .7rem;font-size:.75rem;transition:all .2s}.btn-remove-move:hover{border-color:var(--accent-danger);background:#ff323240}.move-entry-order-btns{gap:.3rem;display:flex}.btn-move-order{color:var(--text-secondary);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;padding:.2rem .5rem;font-size:.8rem;line-height:1;transition:all .2s}.btn-move-order:hover:not(:disabled){color:var(--text-primary);background:#ffffff1f;border-color:#ffffff40}.btn-move-order:disabled{opacity:.25;cursor:not-allowed}.move-flags{border-top:1px solid #ffffff12;flex-wrap:wrap;gap:.75rem;margin-top:.75rem;padding-top:.75rem;display:flex}.flag-checkbox{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;font-size:.85rem;display:flex}.flag-checkbox input[type=checkbox]{accent-color:var(--accent-secondary);cursor:pointer;width:14px;height:14px}.modal-card.modal-xl{width:90vw;max-width:clamp(600px,90vw,1200px);max-height:calc(100vh - 3rem)}.modal-xl>form{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.modal-xl .move-string-form{flex:1;max-height:none;overflow-y:auto}.modal-xl .modal-actions{border-top:1px solid #ffffff12;flex-shrink:0;margin-top:0;padding-top:1rem}.notation-badge{font-family:var(--font-heading);color:var(--text-primary);flex-wrap:wrap;align-items:center;gap:3px;font-size:.95em;line-height:1;display:inline-flex}.notation-token{letter-spacing:.02em;font-weight:700;display:inline-block}.notation-button{background:color-mix(in srgb, currentColor 15%, transparent);width:1.6em;height:1.6em;text-shadow:none;border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8em;font-weight:800;line-height:1;display:inline-flex}.notation-button.notation-button-taunt{background:0 0;border:none;width:auto;height:auto;font-size:1.1em}.notation-button-img{vertical-align:middle;object-fit:contain;width:1.2em;height:1.2em}.notation-direction{color:var(--text-primary);font-size:1.05em}.notation-held{color:var(--text-primary);text-underline-offset:2px;text-decoration:underline;text-decoration-thickness:1.5px}.notation-pause{color:var(--text-primary);padding:0 2px;font-size:1.2em;font-weight:700}.notation-connector{padding:0 1px}.notation-space{width:.35em;display:inline-block}.frame-data-table{background:var(--bg-card);box-shadow:var(--shadow-md);border:1px solid #ffffff0d;border-radius:16px;overflow:hidden}.table-header{border-bottom:2px solid var(--accent-primary);background:#0000004d;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.table-header h2{font-family:var(--font-heading);color:var(--accent-secondary);font-size:1.8rem}.move-row{cursor:default;border-bottom:1px solid #ffffff0d;transition:all .3s}.move-row:hover{background:#ff33660d}.move-summary{cursor:default;grid-template-columns:2fr 5fr 40px;align-items:center;gap:1rem;padding:1rem 1.5rem;display:grid}.move-summary .expand-icon{cursor:pointer}.move-summary-stats{flex-direction:row;flex:1;gap:0;display:flex}.move-summary-stats .move-stat{text-align:center;flex:1}.move-input{flex-direction:column;justify-content:center;gap:.25rem;min-width:120px;display:flex}.move-notation{color:var(--accent-gold);font-family:Courier New,monospace;font-size:1.2rem;font-weight:700}.move-name{color:var(--text-secondary);font-size:.8rem;font-style:italic}.move-stance-transition{color:var(--text-muted);font-size:.8rem}.move-stat{text-align:center}.move-stat-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:.25rem;font-size:.75rem;display:block}.move-stat-value{color:var(--text-primary);font-size:1.1rem;font-weight:600;display:block}.move-stat-value.positive{color:var(--notation-h)}.move-stat-value.negative{color:var(--accent-danger)}.expand-icon{color:var(--text-secondary);justify-content:center;align-items:center;font-size:1.5rem;transition:transform .3s;display:flex}.expand-icon.open{transform:rotate(180deg)}.individual-move-header-right{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.individual-move-meta{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.4rem;display:flex}.move-tag{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:#ffffff14;border:1px solid #ffffff1a;border-radius:20px;padding:.2rem .6rem;font-size:.75rem;font-weight:600}.move-tag.stance{color:var(--notation-h);background:#22c55e26;border-color:#22c55e4d}.move-tag.hit-type{color:var(--notation-t);background:#3b82f626;border-color:#3b82f64d}.move-tag.stun{color:var(--accent-gold);background:#eab30826;border-color:#eab3084d}.move-tag.tracking{color:var(--notation-s);background:#a855f726;border-color:#a855f759}.move-tag.launcher{color:var(--accent-secondary);background:#14b8a626;border-color:#14b8a64d}.move-tag.guard-break{color:var(--accent-danger);background:#ef444426;border-color:#ef44444d}.move-tag.unblockable{color:var(--accent-primary);background:#ef444440;border-color:#ef444480}.move-tag.crush{color:var(--accent-secondary);background:#00d4ff26;border-color:#00d4ff4d}.move-description-text{color:var(--text-secondary);border-left:3px solid var(--accent-secondary);background:#0003;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:1rem;font-style:italic;line-height:1.6}.move-row.expanded .expand-icon{transform:rotate(180deg)}.move-details{background:#0003;max-height:0;transition:max-height .3s;overflow:hidden}.move-row.expanded .move-details{max-height:4000px}.move-details-content{padding:1.5rem}.move-breakdown{gap:1rem;display:grid}.individual-move{border:1px solid #ffffff1f;border-left:3px solid var(--accent-secondary);background:#ffffff08;border-radius:8px;overflow:hidden;box-shadow:0 6px 10px #0009}.individual-move-header{background:#00000040;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:.65rem 1rem;display:flex}.individual-move-input{color:var(--accent-gold);font-family:Courier New,monospace;font-size:1.1rem;font-weight:700}.individual-move-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;padding:.75rem 1rem;display:grid}.stat-item{text-align:center;flex-direction:column;align-items:center;display:flex}.stat-item-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:.25rem;font-size:.75rem}.stat-item-value{color:var(--text-primary);font-size:1rem;font-weight:600}.frame-gap{color:var(--text-secondary);border:1px solid #fff3;border-radius:4px;margin:0 1px;padding:0 3px;font-size:.8em;font-style:italic}.page-top-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;width:100%;margin-bottom:1rem;display:flex}.page-top-bar .breadcrumb{margin-bottom:0}.details-title-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.details-title-row .game-main-title,.details-title-row .character-main-name{margin-bottom:0}.btn-add{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-secondary-dark));color:#fff;font-family:var(--font-heading);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;transition:all .2s}.btn-add:hover{box-shadow:var(--shadow-neon-blue);transform:translateY(-1px)}.btn-save{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-secondary-dark));color:#fff;font-family:var(--font-heading);cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s}.btn-save-another{background:linear-gradient(135deg, var(--accent-purple-dark), var(--accent-purple));color:#fff;font-family:var(--font-heading);cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s}.btn-save-another:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 12px #7b52d499}.btn-save-another:disabled{opacity:.6;cursor:not-allowed}.btn-save:hover:not(:disabled){box-shadow:var(--shadow-neon-blue);transform:translateY(-1px)}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:8px;padding:.6rem 1.5rem;font-size:.9rem;transition:all .2s}.btn-cancel:hover:not(:disabled){color:var(--text-primary);border-color:#ffffff4d}.btn-delete-confirm{background:linear-gradient(135deg, var(--accent-primary), var(--accent-danger-dark));color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;transition:all .2s}.btn-delete-confirm:hover:not(:disabled){box-shadow:var(--shadow-neon);transform:translateY(-1px)}.btn-delete-confirm:disabled{opacity:.6;cursor:not-allowed}.edit-error{color:var(--accent-primary);background:#ff33661a;border:1px solid #ff33664d;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.edit-error-summary{display:block}.edit-error-details{flex-direction:column;gap:.25rem;margin:.5rem 0 0;padding:0;list-style:none;display:flex}.edit-error-details li{opacity:.85;padding-left:1rem;font-size:.8rem}.edit-error-desc{font-weight:400}.edit-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;display:grid}.edit-full-width{grid-column:1/-1}.form-textarea{resize:vertical;min-height:80px;font-family:Courier New,monospace;font-size:.875rem;line-height:1.6}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-card);width:100%;max-width:460px;height:auto;max-height:calc(100vh - 3rem);box-shadow:var(--shadow-lg);border:1px solid #ffffff12;border-radius:20px;flex-direction:column;padding:2rem;display:flex;overflow:hidden}.modal-card.modal-large{max-width:clamp(480px,75vw,720px);max-height:90vh;overflow-y:auto}.modal-title{font-family:var(--font-heading);color:var(--accent-primary);flex-shrink:0;margin-bottom:1rem;font-size:1.4rem}.modal-body{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.modal-body strong{color:var(--text-primary)}.modal-actions{gap:.75rem;margin-top:1.5rem;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}*{scrollbar-width:thin;scrollbar-color:#ffffff26 transparent}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.empty-state-title{font-family:var(--font-heading);color:var(--text-secondary);font-size:1.1rem}.empty-state-subtitle{color:var(--text-muted);font-size:.9rem}.error-boundary{justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.error-boundary-inner{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:480px;display:flex}.error-boundary-icon{font-size:3.5rem}.error-boundary-title{font-family:var(--font-heading);color:var(--accent-primary);font-size:1.6rem}.error-boundary-message{color:var(--text-secondary);font-size:1rem}.error-boundary-detail{color:var(--accent-primary);word-break:break-word;background:#0000004d;border:1px solid #ffffff12;border-radius:8px;width:100%;padding:.75rem 1rem;font-family:monospace;font-size:.8rem}.article-list-page,.article-page{max-width:1200px;margin:0 auto;padding:2rem}.articles-grid{flex-wrap:wrap;justify-content:center;gap:1.5rem;min-height:260px;display:flex}.article-card{background:var(--bg-card);cursor:pointer;border:1px solid #ffffff12;border-radius:16px;flex-direction:column;flex-shrink:0;width:340px;transition:all .3s;display:flex;position:relative;overflow:hidden}.article-card:hover{border-color:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 8px 30px #00d4ff1f}.article-card:hover .card-admin-actions{opacity:1;transform:translateY(0)}.article-card-cover{position:relative}.article-card-cover img{object-fit:cover;width:100%;height:180px;display:block}.article-card-cover-placeholder{background:linear-gradient(135deg, var(--bg-card), var(--bg-card-elevated));width:100%;height:180px}.article-card-cover-meta{z-index:2;flex-wrap:wrap;gap:.35rem;display:flex;position:absolute;bottom:.6rem;left:.6rem}.article-card-body{flex-direction:column;flex:1;gap:.5rem;padding:1.25rem;display:flex}.article-card-meta{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.article-category{text-transform:uppercase;letter-spacing:.8px;color:var(--accent-orange);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;border-radius:4px;padding:.2rem .6rem;font-size:.75rem;font-weight:600}.article-date{color:var(--text-muted);font-size:.9rem}.article-draft-badge{text-transform:uppercase;letter-spacing:.6px;color:var(--accent-primary);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:600}.article-card-title{font-family:var(--font-heading);color:var(--text-primary);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1.5rem;line-height:1.3;display:-webkit-box;overflow:hidden}.article-card-subtitle{color:var(--text-muted);-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;flex:1;margin:0;font-size:.95rem;line-height:1.6;display:-webkit-box;overflow:hidden}.article-card-byline{color:var(--text-muted);margin-top:auto;padding-top:.5rem;font-size:.8rem}.article-tag{color:var(--text-secondary);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;border:1px solid #fff3;border-radius:4px;padding:.2rem .6rem;font-size:.75rem;font-weight:500}.article-page-inner{max-width:1200px;margin:0 auto}.article-header{border-bottom:1px solid #ffffff12;margin-bottom:2.5rem;padding-bottom:2rem}.article-header-meta{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.article-header-labels{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.article-title{font-family:var(--font-heading);color:var(--text-primary);margin:0 0 .75rem;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.2}.article-subtitle{color:var(--text-secondary);margin:0;font-size:1.1rem;line-height:1.6}.article-audit{color:var(--text-muted);margin:.75rem 0 0;font-size:.85rem}.move-audit{color:var(--text-muted);border-top:1px solid #ffffff0f;margin:1rem 0 0;padding-top:.75rem;font-size:.8rem}.article-cover-image{border-radius:12px;margin-bottom:2.5rem;overflow:hidden}.article-cover-image img{object-fit:cover;width:100%;height:auto;max-height:420px;display:block}.article-body{color:var(--text-secondary);font-size:1rem;line-height:1.8}.article-body h1,.article-body h2,.article-body h3,.article-body h4{font-family:var(--font-heading);color:var(--text-primary);margin:2rem 0 .75rem;line-height:1.3}.article-body h2{font-size:1.5rem}.article-body h3{font-size:1.2rem}.article-body p{margin:0 0 1.2rem}.article-body strong{color:var(--text-primary);font-weight:600}.article-body em{color:var(--accent-secondary);font-style:italic}.article-body a{color:var(--accent-secondary);text-underline-offset:3px;text-decoration:underline}.article-body ul,.article-body ol{margin:0 0 1.2rem;padding-left:1.5rem}.article-body li{margin-bottom:.4rem}.article-body blockquote{border-left:3px solid var(--accent-primary);color:var(--text-secondary);background:#ff33660d;border-radius:0 8px 8px 0;margin:1.5rem 0;padding:.75rem 1.25rem;font-style:italic}.article-body code{color:var(--accent-secondary);background:#ffffff12;border:1px solid #ffffff1a;border-radius:4px;padding:.15em .4em;font-family:Courier New,monospace;font-size:.875em}.article-body pre{background:#0006;border:1px solid #ffffff12;border-radius:8px;margin:1.5rem 0;padding:1.25rem;overflow-x:auto}.article-body pre code{color:var(--text-primary);background:0 0;border:none;padding:0;font-size:.875rem}.article-body table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.9rem}.article-body th{color:var(--text-primary);font-family:var(--font-heading);text-align:left;background:#ffffff0d;border-bottom:1px solid #ffffff1a;padding:.65rem .9rem;font-weight:600}.article-body td{color:var(--text-secondary);border-bottom:1px solid #ffffff0d;padding:.6rem .9rem}.article-body tr:last-child td{border-bottom:none}.article-body hr{border:none;border-top:1px solid #ffffff12;margin:2rem 0}.article-body-editor{min-height:360px}.markdown-preview{background:#0003;border:1px solid #ffffff12;border-radius:8px;min-height:200px;padding:1rem}@media (width<=860px){.game-details-header{flex-direction:column;align-items:center}.game-title-row{text-align:center;order:0;width:100%;display:block}.game-title-row .game-main-title{text-align:center}.game-details-full .details-title-row{display:none}.game-left{order:1;align-items:center;width:min(280px,60vw)}.game-details-full{order:2;width:100%}.game-details-full .info-row{text-align:left}.game-info-list{grid-template-columns:1fr;width:fit-content;margin:0 auto}.table-header{flex-wrap:wrap;gap:.75rem}.table-header h2{word-break:break-word;flex-shrink:1;min-width:0}.table-header .section-header-actions{margin-left:auto}.table-header .search-box{order:3;width:100%;padding:0}}@media (width<=900px){.games-grid{gap:1.5rem;padding:1rem}.section-header{gap:.75rem}.section-header h2{font-size:1.4rem}.section-header-actions{justify-content:flex-start;width:100%}.section-header .search-box{order:3;width:100%;padding:0}.characters-grid{gap:1rem}.move-summary{grid-template-columns:1fr auto;grid-template-areas:"input expand""stats stats";align-items:start;gap:.4rem 0;padding:.75rem 1rem;display:grid}.move-summary .move-input{grid-area:input;padding-right:.5rem}.move-summary .move-summary-stats{grid-area:stats}.move-summary .expand-icon{grid-area:expand;align-self:center}.move-summary .counter-reasons-row{border-top:1px solid #ffffff0f;grid-area:stats;justify-content:flex-start;padding:.4rem 0 0}.move-summary-stats{border-top:1px solid #ffffff0f;flex-wrap:wrap;grid-column:1/-1;gap:0;padding-top:.4rem;display:flex}.move-stat{text-align:center;flex-direction:column;flex:auto;align-items:center;min-width:52px;padding:.2rem .25rem;display:flex}.move-stat-label{margin-bottom:.1rem;font-size:.65rem}.move-stat-value{font-size:.95rem}.individual-move-header{flex-wrap:wrap;gap:.4rem}.individual-move-input{font-size:1rem}.individual-move-meta{flex-wrap:wrap;justify-content:flex-end}.individual-move-stats{grid-template-columns:repeat(2,1fr);gap:.5rem .75rem}.stat-item{border-bottom:1px solid #ffffff0d;flex-direction:row;justify-content:space-between;align-items:baseline;gap:.25rem;padding:.25rem 0;display:flex}.stat-item-label{white-space:nowrap;font-size:.7rem}.stat-item-value{text-align:right;font-size:.9rem}.character-header{flex-direction:column;align-items:center}.character-title-row{text-align:center;order:0;width:100%;display:block}.character-title-row .character-main-name{text-align:center}.character-details-full .character-main-name{display:none}.character-left{order:1;align-items:center;width:min(280px,60vw)}.character-details-full{order:2;width:100%}.character-details-full .info-row{text-align:left}.character-info-list{grid-template-columns:1fr;width:fit-content;margin:0 auto}}.app-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-main{flex:1;padding-bottom:6rem;scroll-padding-bottom:6rem;overflow-y:auto}.footer{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;background:#0a0e27d9;border-top:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:.6rem 2rem;display:flex;position:fixed;bottom:0;left:0;right:0}.footer-copy{color:var(--text-muted,#ffffff4d);letter-spacing:.3px;text-align:center;white-space:nowrap;pointer-events:none;font-size:.9rem;position:absolute;left:0;right:0}.footer-copy-exclude{opacity:.5;font-size:.65rem}.footer-version{color:var(--text-muted,#ffffff4d);letter-spacing:.3px;font-size:.75rem;font-family:var(--font-heading);white-space:nowrap;flex-shrink:0}@media (width<=640px){.footer{justify-content:center;gap:.5rem}.footer-copy{text-align:center;position:static}.footer-version{display:none}.individual-move-stats{grid-template-columns:1fr}}@media (width<=480px){.individual-move-stats{grid-template-columns:1fr}}.lab-selector-card{background:var(--bg-card);border:1px solid #ffffff12;border-radius:16px;margin-bottom:2rem;padding:1.5rem}.lab-selector-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));align-items:end;gap:1rem;display:grid}.lab-selector-action{align-items:flex-end;display:flex}.lab-btn-calculate{width:100%;padding:.75rem 1.5rem;font-size:.95rem}.counter-reasons-row{flex-wrap:wrap;flex:1;justify-content:flex-end;gap:.4rem;display:flex}.counter-reason-tag{color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;background:#00d4ff1f;border:1px solid #00d4ff40;border-radius:999px;padding:.2rem .55rem;font-size:.7rem;font-weight:600}.btn-lab{font-size:.72rem;font-weight:600;font-family:var(--font-heading);color:var(--accent-secondary);cursor:pointer;white-space:nowrap;background:#00d4ff14;border:1px solid #00d4ff4d;border-radius:6px;flex-shrink:0;padding:.2rem .6rem;transition:background .2s,border-color .2s,transform .15s}.btn-lab:hover{border-color:var(--accent-secondary);background:#00d4ff2e;transform:translateY(-1px)}.frame-timeline{background:#ffffff08;border:1px solid #ffffff1f;border-radius:8px;margin-bottom:1rem;padding:1rem 1.25rem;box-shadow:0 6px 10px #0009}.frame-timeline-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.85rem;display:flex}.frame-timeline-title{font-family:var(--font-heading);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:700}.frame-timeline-legend{flex-wrap:wrap;gap:.75rem;display:flex}.timeline-legend-item{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.75rem;display:flex}.timeline-legend-dot{border-radius:2px;flex-shrink:0;width:10px;height:10px}.timeline-row{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.timeline-row:last-of-type{margin-bottom:0}.timeline-row-label{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;min-width:120px;max-width:160px;font-size:.75rem;overflow:hidden}.timeline-label-notation{color:var(--accent-primary);font-weight:700}.timeline-track{background:repeating-linear-gradient(-45deg,#ffffff08 0 4px,#ffffff12 4px 8px);border-radius:6px;flex:1;align-items:stretch;height:28px;display:flex;overflow:hidden}.timeline-segments{isolation:isolate;background:var(--bg-card);height:100%;display:flex}.timeline-segment{justify-content:center;align-items:center;min-width:2px;height:100%;display:flex}.frame-timeline-note{color:var(--text-muted);margin-top:.6rem;font-size:.75rem;font-style:italic}.timeline-segment-label{color:#fffffff2;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 1px 3px #000000e6,0 0 6px #000c;font-size:.65rem;font-weight:700}.media-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem;display:grid}.media-card{background:var(--bg-card);border:1px solid #ffffff12;border-radius:12px;flex-direction:column;transition:border-color .2s,transform .2s;display:flex;overflow:hidden}.media-card:hover{border-color:var(--accent-gold);transform:translateY(-2px)}.media-preview{aspect-ratio:1;background:linear-gradient(135deg, var(--bg-card), var(--bg-card-elevated));justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.media-preview-img{object-fit:cover;width:100%;height:100%}.media-preview-icon{opacity:.6;font-size:3rem}.media-info{flex-direction:column;flex:1;gap:.3rem;padding:.75rem;display:flex}.media-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:1.05rem;font-weight:600;overflow:hidden}.media-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.media-slug{color:var(--accent-gold);white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-family:Courier New,monospace;font-size:.75rem;overflow:hidden}.media-size{color:var(--text-muted);white-space:nowrap;font-size:.8rem}.media-type{color:var(--text-muted);opacity:.7;white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.media-actions{gap:.5rem;padding:.5rem .75rem .75rem;display:flex}.btn-copy{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;flex:1;padding:.4rem .6rem;font-size:.78rem;transition:background .2s,color .2s}.btn-copy:hover{color:var(--text-primary);background:#ffffff14}.btn-copy.copied{border-color:var(--accent-success);color:var(--accent-success)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;transition:background .2s,color .2s}.btn-secondary:hover:not(:disabled){color:var(--text-primary);background:#ffffff14}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--accent-danger-dark);color:var(--text-primary);cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:background .2s}.btn-danger:hover:not(:disabled){background:var(--accent-danger)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.media-dropzone{border:2px dashed var(--border);text-align:center;color:var(--text-muted);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:1.5rem;font-size:.9rem;transition:border-color .2s,background .2s;display:flex}.media-dropzone:hover,.media-dropzone.has-file{border-color:var(--accent-gold);color:var(--text-primary);background:#d4af370d}.media-dropzone-icon{font-size:1.4rem}.form-error{color:var(--accent-danger);margin-top:.5rem;font-size:.85rem}.modal-body-text{color:var(--text-secondary);margin-bottom:.5rem;font-size:.95rem;line-height:1.6}.modal-small{max-width:420px}
