.deck-list{padding:8px;animation:.4s fadeIn}.deck-stats{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px;display:grid}.stat-card{border:1px solid #30363d;border-radius:16px;align-items:center;gap:16px;padding:24px;transition:all .3s;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";opacity:.8;height:3px;position:absolute;top:0;left:0;right:0}.stat-card-blue{background:linear-gradient(135deg, #4285f426 0%, #161b22 100%)}.stat-card-blue:before{background:linear-gradient(90deg,#4285f4,#8ab8ff)}.stat-card-blue .stat-icon{color:#8ab8ff}.stat-card-purple{background:linear-gradient(135deg, #4285f426 0%, #161b22 100%)}.stat-card-purple:before{background:linear-gradient(90deg,#4285f4,#66a3ff)}.stat-card-purple .stat-icon{color:#66a3ff}.stat-card-green{background:linear-gradient(135deg, #34a85326 0%, #161b22 100%)}.stat-card-green:before{background:linear-gradient(90deg,#34a853,#81c995)}.stat-card-green .stat-icon{color:#81c995}.stat-icon{background:#21262d;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-icon svg{width:18px;height:18px}.stat-content{flex-direction:column;gap:4px;display:flex}.stat-value{color:#f0f6fc;font-size:2rem;font-weight:700;line-height:1}.stat-label{color:#8b949e;font-size:.875rem;font-weight:500}.deck-header{border-bottom:1px solid #30363d;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:20px;display:flex}.deck-header-title{align-items:center;gap:16px;display:flex}.header-icon{background:linear-gradient(135deg, #6d28d9, #7c3aed);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.header-icon svg{width:20px;height:20px}.deck-header h2{color:#f0f6fc;margin:0;font-size:1.75rem;font-weight:700}.deck-header-subtitle{color:#8b949e;margin:4px 0 0;font-size:.9375rem}.btn-create{align-items:center;gap:10px;font-weight:600;display:flex;background:#21262d!important;border:1px solid #30363d!important;color:#8b949e!important;box-shadow:none!important;border-radius:9999px!important;padding:12px 24px!important;font-size:.9375rem!important}.btn-create:hover{background:#30363d!important;color:#f0f6fc!important;border-color:#6e7681!important;transform:none!important}.header-buttons{align-items:center;gap:8px;display:flex}.btn-diagrama{cursor:pointer;align-items:center;gap:8px;font-weight:600;text-decoration:none;transition:all .2s;display:flex;color:#34a853!important;box-shadow:none!important;background:#34a8531a!important;border:1px solid #34a8534d!important;border-radius:9999px!important;padding:12px 20px!important;font-size:.9375rem!important}.btn-diagrama:hover{color:#34a853!important;background:#34a85333!important;border-color:#34a853!important;transform:none!important}.btn-icon{justify-content:center;align-items:center;width:16px;height:16px;display:flex}.btn-icon svg{width:100%;height:100%}.subject-filter{flex-wrap:wrap;gap:10px;margin-bottom:28px;display:flex}.filter-pill{border:1px solid #30363d;background:#21262d;color:#8b949e;cursor:pointer;border-radius:9999px;align-items:center;gap:6px;padding:8px 18px;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.filter-pill:hover{border-color:#6e7681;color:#f0f6fc;background:#30363d}.filter-pill.active{border-color:#6d28d9;color:#7c3aed;background:#6d28d91a}.decks-grid{grid-template-columns:repeat(auto-fill,minmax(520px,1fr));align-items:stretch;gap:24px;display:grid}.deck-card{background:#161b22;border:1px solid #30363d;border-radius:20px;flex-direction:column;height:100%;transition:all .3s;display:flex;position:relative;overflow:hidden}.deck-card:hover{border-color:#30363d;box-shadow:0 8px 24px rgba(0, 0, 0, 0.5);transform:translateY(-4px)}.deck-card.has-due{border-color:#6d28d9;box-shadow:0 0 0 1px #6d28d9}.due-badge-inline{background:linear-gradient(135deg, #6d28d9, #7c3aed);color:#fff;box-shadow:0 1px 2px rgba(0, 0, 0, 0.3);border-radius:20px;align-self:flex-start;margin-bottom:12px;padding:5px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.deck-card-content{flex-direction:column;flex:1;padding:24px;display:flex;position:relative}.deck-card-header{margin-bottom:8px}.deck-name{color:#f0f6fc;margin:0 0 8px;font-size:1.25rem;font-weight:700;line-height:1.3}.deck-subject{background:linear-gradient(135deg, #6d28d9, #7c3aed);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;align-self:flex-start;align-items:center;gap:4px;margin-bottom:10px;padding:5px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.deck-description{color:#8b949e;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:20px;font-size:.9375rem;line-height:1.6;display:-webkit-box;overflow:hidden}.deck-progress{margin-bottom:20px}.progress-info{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.progress-label{color:#8b949e;font-size:.9375rem;font-weight:500}.progress-value{color:#8b949e;font-size:.875rem;font-weight:500}.progress-bar{background:#21262d;border-radius:4px;height:32px;overflow:hidden}.progress-fill{background:#8b949e;border-radius:4px;height:100%;transition:width .5s}.deck-stats-row{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.deck-stat{background:#21262d;border-radius:12px;align-items:center;gap:10px;padding:12px;display:flex}.stat-icon-small{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.stat-icon-small svg{width:14px;height:14px}.icon-new{color:#66a3ff;background:#4285f426}.icon-learning{color:#fdd835;background:#fbbc0426}.icon-review{color:#81c995;background:#34a85326}.stat-info{flex-direction:column;gap:2px;display:flex}.stat-number{color:#f0f6fc;font-size:1.125rem;font-weight:700;line-height:1}.stat-text{color:#6e7681;text-transform:uppercase;letter-spacing:.5px;font-size:.6875rem;font-weight:500}.deck-actions{grid-template-columns:2fr 1fr 1fr 1fr;gap:8px;margin-top:auto;display:grid}.deck-actions .btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.btn-complete{width:48px;height:48px;color:#8b949e;border:1px solid #30363d;background:linear-gradient(135deg,#222,#111);padding:0;font-size:1.1rem}.btn-complete.active{color:#34a853;background:linear-gradient(135deg,#34a8532e,#34a8530f);border-color:#34a85399}.deck-card.done{opacity:.95;background:linear-gradient(180deg, #34a85308, #161b22);border-color:#34a85333}.deck-card.done .deck-name{text-decoration:line-through}.deck-done-badge{z-index:30;letter-spacing:.4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;border:1px solid #ffffff0a;border-radius:999px;padding:8px 14px;font-size:.95rem;font-weight:800;position:absolute;top:12px;right:12px;box-shadow:0 6px 20px #0009}.deck-done-badge:focus{outline:none;box-shadow:0 0 0 4px #4285f41f}.deck-done-badge.on{color:#fff;background:linear-gradient(135deg,#34a853f2,#228b22f2);border-color:#34a85399}.deck-done-badge.off{color:#8b949e;background:#00000073;border-color:#ffffff0a}@media (width<=480px){.deck-done-badge{padding:6px 10px;font-size:.85rem;top:10px;right:10px}}.btn-study{background:linear-gradient(135deg, #6d28d9, #7c3aed)!important;color:#fff!important}.btn-study:hover{filter:brightness(1.1)}.btn-icon-only{border:1px solid #30363d!important;background:#0a0a0a!important;padding:12px!important}.btn-icon-only svg{width:18px;height:18px}.btn-stats{color:#8ab8ff!important}.btn-edit{color:#fdd835!important}.btn-reset{color:#d1d5db!important}.btn-delete{color:#f28b82!important}.btn-icon-only:hover{background:#141414!important}.empty-state{text-align:center;background:#161b22;border:2px dashed #30363d;border-radius:20px;padding:80px 24px}.empty-icon-wrapper{background:linear-gradient(135deg, #6d28d9, #7c3aed);width:72px;height:72px;box-shadow:0 8px 24px rgba(0, 0, 0, 0.5);border-radius:18px;justify-content:center;align-items:center;margin-bottom:20px;display:inline-flex}.empty-icon{color:#fff;width:32px;height:32px}.empty-icon svg{width:100%;height:100%}.empty-state h3{color:#f0f6fc;margin-bottom:12px;font-size:1.5rem}.empty-state p{color:#8b949e;margin-bottom:28px;font-size:1rem}.modal-reset{max-width:480px}.modal-reset .modal-body{padding:8px 0 16px}.modal-reset .modal-text{color:#8b949e;margin-bottom:12px;font-size:.9375rem;line-height:1.6}.modal-reset .modal-text strong{color:#f0f6fc}.modal-reset .modal-text.danger-text{color:#f28b82}.modal-reset .modal-text.highlight-text{border-left:3px solid #6d28d9;background:#4285f41a;border-radius:8px;padding:12px}.modal-reset .modal-list{margin:16px 0;padding:0;list-style:none}.modal-reset .modal-list li{color:#8b949e;padding:8px 0 8px 24px;font-size:.875rem;position:relative}.modal-reset .modal-list li:before{content:"✕";color:#ea4335;font-weight:700;position:absolute;left:0}.modal-reset .modal-info-box{text-align:center;background:#fbbc041a;border:1px solid #fbbc044d;border-radius:8px;margin-top:16px;padding:12px}.modal-reset .info-label{color:#fdd835;font-size:.875rem;font-weight:500}.modal-reset .modal-danger-box{text-align:center;background:#ea43351a;border:1px solid #ea43354d;border-radius:8px;margin-top:16px;padding:12px}.modal-reset .danger-label{color:#f28b82;font-size:.9375rem;font-weight:600}.modal-reset .warning-icon{color:#fdd835!important;background:#fbbc0426!important}.modal-reset .danger-icon{color:#f28b82!important;background:#ea433526!important}.modal-reset .btn-warning{color:#fdd835;background:#fbbc0433;border:1px solid #fbbc0466}.modal-reset .btn-warning:hover{background:#fbbc044d}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000c;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:#161b22;border:1px solid #30363d;width:100%;max-width:460px;box-shadow:0 16px 48px rgba(0, 0, 0, 0.6);border-radius:20px;padding:32px;animation:.3s slideUp}.modal-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.modal-icon{background:linear-gradient(135deg, #6d28d9, #7c3aed);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.modal-icon svg{width:20px;height:20px}.modal h3{margin:0;font-size:1.375rem;font-weight:700}.form-group{margin-bottom:20px}.form-group label{color:#8b949e;margin-bottom:8px;font-size:.875rem;font-weight:600;display:block}.input,.textarea{background:#21262d;border:1px solid #30363d;width:100%;color:#f0f6fc;border-radius:10px;padding:12px 16px;font-size:.9375rem;transition:all .2s}.input:focus,.textarea:focus{border-color:#6d28d9;outline:none;box-shadow:0 0 0 3px #4285f41a}.textarea{resize:vertical;min-height:80px}.modal-actions{justify-content:flex-end;gap:12px;margin-top:28px;display:flex}.modal-actions .btn{padding:12px 24px;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=1200px){.decks-grid{grid-template-columns:repeat(auto-fill,minmax(480px,1fr))}}@media (width<=1024px){.decks-grid{grid-template-columns:repeat(2,1fr);gap:20px}.deck-card{min-width:0}.stat-value{font-size:1.75rem}}@media (width<=900px){.decks-grid{grid-template-columns:1fr;max-width:600px;margin-left:auto;margin-right:auto}.deck-stats{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.deck-stats{grid-template-columns:1fr;gap:12px;margin-bottom:24px}.stat-card{padding:16px}.stat-value{font-size:1.5rem}.deck-header{flex-direction:column;align-items:flex-start;gap:16px}.decks-grid{grid-template-columns:1fr}.deck-card-content{padding:20px}.deck-stats-row{gap:8px}.deck-stat{padding:10px}.deck-actions{gap:6px}.modal{padding:24px}.due-badge-inline{padding:4px 10px;font-size:.6875rem}}@media (width<=480px){.deck-stats-row{grid-template-columns:1fr}.deck-actions{grid-template-columns:repeat(4,1fr)}.btn-study span:not(.btn-icon){display:none}.decks-grid{grid-template-columns:1fr;gap:16px}.deck-card-content{padding:16px}.deck-name{font-size:1.1rem}.stat-value{font-size:1.5rem}}@media (width<=375px){.deck-stats{grid-template-columns:1fr;gap:10px}.stat-card{flex-direction:row;justify-content:flex-start;padding:14px}.stat-icon{width:32px;height:32px}.deck-header h2{font-size:1.4rem}.btn-create{padding:10px 16px!important;font-size:.875rem!important}.deck-actions .btn{padding:10px 4px}.btn-icon-only svg{width:14px;height:14px}}@media (width<=320px){.app-main{padding:12px}.deck-card-content{padding:14px}.deck-stats-row{flex-direction:column;gap:8px}.deck-stat{flex-direction:row;justify-content:space-between;width:100%}.deck-actions{gap:4px}.modal{margin:16px;padding:20px 16px}.modal-actions{flex-direction:column;gap:8px}.modal-actions .btn{width:100%}}.clear-data-section{border-top:1px solid #30363d;flex-direction:column;justify-content:center;align-items:center;margin-top:60px;padding:40px 20px;display:flex}.btn-clear-data{border:1px solid #30363d;color:#6e7681;cursor:pointer;opacity:.7;background:0 0;border-radius:10px;justify-content:center;align-self:center;align-items:center;gap:8px;padding:12px 24px;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.btn-clear-data:hover{opacity:1;color:#f28b82;background:#ea43351a;border-color:#ea433566}.btn-clear-data .btn-icon{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.btn-clear-data .btn-icon svg{width:16px;height:16px}.clear-data-hint{color:#6e7681;opacity:.6;text-align:center;margin-top:8px;font-size:.75rem}.deck-card.theme-blue.has-due{border-color:#1a73e8;box-shadow:0 0 0 1px #1a73e8}.deck-card.theme-blue .due-badge-inline{background:linear-gradient(135deg,#1a73e8,#4285f4)}.deck-card.theme-blue .progress-value{color:#8b949e}.deck-card.theme-blue .progress-fill{background:#8b949e}.deck-card.theme-blue .btn-study{background:linear-gradient(135deg,#4285f4,#1a73e8)!important}.deck-card.theme-blue .btn-stats{color:#93c5fd!important}.deck-card.theme-blue .icon-new{color:#8ab8ff;background:#2563eb26}.extras-section{border-top:1px solid #30363d;margin-top:32px;padding-top:24px}.extras-toggle{background:#161b22;border:1px solid #30363d;width:100%;color:#f0f6fc;cursor:pointer;border-radius:16px;align-items:center;gap:12px;padding:16px 20px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.extras-toggle:hover{border-color:#30363d;background:#21262d}.extras-icon{color:#fdd835;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.extras-icon svg{width:100%;height:100%}.extras-label{text-align:left;flex:1}.extras-count{color:#6e7681;background:#21262d;border-radius:20px;padding:4px 12px;font-size:.875rem;font-weight:500}.extras-chevron{width:24px;height:24px;color:#6e7681;justify-content:center;align-items:center;transition:transform .3s;display:flex}.extras-chevron svg{width:20px;height:20px}.extras-chevron.open{transform:rotate(0)}.extras-grid{margin-top:20px}.modal-clear{max-width:480px}.modal-clear .modal-list{margin:12px 0;padding:0;list-style:none}.modal-clear .modal-list li{color:#8b949e;padding:6px 0 6px 24px;font-size:.9375rem;position:relative}.modal-clear .modal-list li:before{content:"•";color:#6e7681;position:absolute;left:8px}.info-green{background:#34a8531a!important;border-color:#34a8534d!important}.info-green .info-label{color:#81c995!important}.materias-section{border-top:1px solid #30363d;margin-top:32px;padding-top:24px}.materias-toggle{background:linear-gradient(135deg, #4285f414, #161b22);width:100%;color:#f0f6fc;cursor:pointer;border:1px solid #4285f44d;border-radius:16px;align-items:center;gap:12px;padding:16px 20px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.materias-toggle:hover{background:linear-gradient(135deg, #4285f426, #21262d);border-color:#4285f499}.materias-icon{flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.5rem;display:flex}.materias-label{text-align:left;flex:1}.materias-count{color:#6e7681;background:#21262d;border-radius:20px;padding:4px 12px;font-size:.875rem;font-weight:500}.materias-chevron{width:24px;height:24px;color:#6e7681;justify-content:center;align-items:center;transition:transform .3s;display:flex}.materias-chevron svg{width:20px;height:20px}.materias-chevron.open{transform:rotate(180deg)}.materias-content{flex-direction:column;gap:24px;margin-top:20px;display:flex}.materias-subgroup{background:#161b22;border:1px solid #30363d;border-radius:16px;padding:20px}.materias-subject-header{background:#21262d;color:#f0f6fc;border-left:4px solid;border-radius:12px;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;font-size:.9375rem;font-weight:600;display:flex}.materias-subject-icon{flex-shrink:0;font-size:1.25rem}.materias-subject-name{flex:1}.materias-subject-count{color:#6e7681;background:#161b22;border-radius:20px;padding:4px 10px;font-size:.8125rem;font-weight:500}.materias-subgrid{gap:20px}.pruebas-section{border-top:1px solid #30363d;margin-top:32px;padding-top:24px}.pruebas-toggle{background:linear-gradient(135deg, #fbbc0414, #161b22);width:100%;color:#f0f6fc;cursor:pointer;border:1px solid #fbbc044d;border-radius:16px;align-items:center;gap:12px;padding:16px 20px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.pruebas-toggle:hover{background:linear-gradient(135deg, #fbbc0426, #21262d);border-color:#fbbc0499}.pruebas-icon{flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.5rem;display:flex}.pruebas-label{text-align:left;flex:1}.pruebas-count{color:#6e7681;background:#21262d;border-radius:20px;padding:4px 12px;font-size:.875rem;font-weight:500}.pruebas-chevron{width:24px;height:24px;color:#6e7681;justify-content:center;align-items:center;transition:transform .3s;display:flex}.pruebas-chevron svg{width:20px;height:20px}.pruebas-chevron.open{transform:rotate(180deg)}.pruebas-grid{margin-top:20px}.deck-card.theme-prueba.has-due{border-color:#fbbc04;box-shadow:0 0 0 1px #fbbc04}.deck-card.theme-prueba .progress-value{color:#8b949e}.deck-card.theme-prueba .progress-fill{background:#8b949e}.deck-card.theme-prueba .btn-study{color:#1a1a1a!important;background:linear-gradient(135deg,#fbbc04,#f9a825)!important}.deck-card.theme-prueba .btn-stats{color:#fdd835!important}.deck-card.theme-prueba .icon-new{color:#fdd835;background:#fbbc0426}.pruebas-content{flex-direction:column;gap:24px;margin-top:20px;display:flex}.pruebas-subgroup{background:#161b22;border:1px solid #30363d;border-radius:16px;padding:20px}.pruebas-subject-header{background:#21262d;color:#f0f6fc;border-left:4px solid;border-radius:12px;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;font-size:.9375rem;font-weight:600;display:flex}.pruebas-subject-icon{flex-shrink:0;font-size:1.25rem}.pruebas-subject-name{flex:1}.pruebas-subject-count{color:#6e7681;background:#161b22;border-radius:20px;padding:4px 10px;font-size:.8125rem;font-weight:500}.pruebas-subgrid{gap:20px}.practicas-section{border-top:1px solid #30363d;margin-top:32px;padding-top:24px}.practicas-toggle{background:linear-gradient(135deg, #34a85314, #161b22);width:100%;color:#f0f6fc;cursor:pointer;border:1px solid #34a8534d;border-radius:16px;align-items:center;gap:12px;padding:16px 20px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.practicas-toggle:hover{background:linear-gradient(135deg, #34a85326, #21262d);border-color:#34a85399}.practicas-icon{flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.5rem;display:flex}.practicas-label{text-align:left;flex:1}.practicas-count{color:#6e7681;background:#21262d;border-radius:20px;padding:4px 12px;font-size:.875rem;font-weight:500}.practicas-chevron{width:24px;height:24px;color:#6e7681;justify-content:center;align-items:center;transition:transform .3s;display:flex}.practicas-chevron svg{width:20px;height:20px}.practicas-chevron.open{transform:rotate(180deg)}.practicas-grid{margin-top:20px}.examenes-section{border-top:1px solid #30363d;margin-top:32px;padding-top:24px}.examenes-toggle{background:linear-gradient(135deg, #9c27b014, #161b22);width:100%;color:#f0f6fc;cursor:pointer;border:1px solid #9c27b04d;border-radius:16px;align-items:center;gap:12px;padding:16px 20px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.examenes-toggle:hover{background:linear-gradient(135deg, #9c27b026, #21262d);border-color:#9c27b099}.examenes-icon{flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.5rem;display:flex}.examenes-label{text-align:left;flex:1}.examenes-count{color:#6e7681;background:#21262d;border-radius:20px;padding:4px 12px;font-size:.875rem;font-weight:500}.examenes-chevron{width:24px;height:24px;color:#6e7681;justify-content:center;align-items:center;transition:transform .3s;display:flex}.examenes-chevron svg{width:20px;height:20px}.examenes-chevron.open{transform:rotate(180deg)}.examenes-content{flex-direction:column;gap:24px;margin-top:20px;display:flex}.examenes-subgroup{background:#161b22;border:1px solid #30363d;border-radius:16px;padding:20px}.examenes-subject-header{background:#21262d;color:#f0f6fc;border-left:4px solid;border-radius:12px;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;font-size:.9375rem;font-weight:600;display:flex}.examenes-subject-icon{flex-shrink:0;font-size:1.25rem}.examenes-subject-name{flex:1}.examenes-subject-count{color:#6e7681;background:#161b22;border-radius:20px;padding:4px 10px;font-size:.8125rem;font-weight:500}.examenes-subgrid{gap:20px}.deck-card.theme-practica.has-due{border-color:#34a853;box-shadow:0 0 0 1px #34a853}.deck-card.theme-practica .progress-value{color:#8b949e}.deck-card.theme-practica .progress-fill{background:#8b949e}.deck-card.theme-practica .btn-study{color:#fff!important;background:linear-gradient(135deg,#34a853,#2e7d32)!important}.deck-card.theme-practica .btn-stats{color:#81c995!important}.deck-card.theme-practica .icon-new{color:#81c995;background:#34a85326}.pd-section{border-top:1px solid #30363d;margin-top:32px;padding-top:24px}.pd-toggle{background:linear-gradient(135deg, #ea433514, #161b22);width:100%;color:#f0f6fc;cursor:pointer;border:1px solid #ea43354d;border-radius:16px;align-items:center;gap:12px;padding:16px 20px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.pd-toggle:hover{background:linear-gradient(135deg, #ea433526, #21262d);border-color:#ea433599}.pd-icon{flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.5rem;display:flex}.pd-label{text-align:left;flex:1}.pd-count{color:#6e7681;background:#21262d;border-radius:20px;padding:4px 12px;font-size:.875rem;font-weight:500}.pd-chevron{width:24px;height:24px;color:#6e7681;justify-content:center;align-items:center;transition:transform .3s;display:flex}.pd-chevron svg{width:20px;height:20px}.pd-chevron.open{transform:rotate(180deg)}.pd-grid{margin-top:20px}.deck-card.theme-pd.has-due{border-color:#ea4335;box-shadow:0 0 0 1px #ea4335}.deck-card.theme-pd .progress-value{color:#8b949e}.deck-card.theme-pd .progress-fill{background:#8b949e}.deck-card.theme-pd .btn-study{color:#fff!important;background:linear-gradient(135deg,#ea4335,#c62828)!important}.deck-card.theme-pd .btn-stats{color:#ef9a9a!important}.deck-card.theme-pd .icon-new{color:#ef9a9a;background:#ea433526}.study-view{background:#000;max-width:1300px;min-height:100vh;margin:0 auto}.study-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.study-header .btn-back{background:#21262d;border:1px solid #30363d;color:#f0f6fc;cursor:pointer;border-radius:10px;align-items:center;gap:10px;padding:12px 20px;font-size:.9375rem;font-weight:600;transition:all .2s;display:flex}.study-header .btn-back:hover{background:#30363d;border-color:#6d28d9}.study-info{text-align:center;position:absolute;left:50%;transform:translate(-50%)}.study-info h2{margin-bottom:4px;font-size:1.25rem;font-weight:600}.card-counter{color:#6e7681;font-size:.875rem}.step-number-display{background:linear-gradient(135deg,#2563eb1a,#4285f40d);border:1px solid #2563eb33;border-radius:16px;justify-content:center;align-items:baseline;gap:12px;margin-bottom:24px;padding:16px;display:flex}.step-number-label{color:#8b949e;text-transform:uppercase;letter-spacing:1px;font-size:1.25rem;font-weight:600}.step-number-value{color:#4285f4;font-size:3rem;font-weight:800;line-height:1}.step-number-total{color:#6e7681;font-size:1rem;font-weight:500}.card-progress-wrapper{background:#161b22;border:1px solid #30363d;border-radius:24px;align-items:center;gap:16px;width:100%;max-width:100%;margin-bottom:24px;margin-left:auto;margin-right:auto;padding:16px 24px;display:flex}.card-progress-number{color:#8b949e;text-align:center;flex-shrink:0;min-width:40px;font-size:1.25rem;font-weight:600}.card-progress-track{background:#21262d;cursor:grab;-webkit-user-select:none;user-select:none;border-radius:4px;flex:1;height:16px;position:relative;overflow:hidden}.card-progress-track:active{cursor:grabbing}.card-progress-fill{background:#8b949e;border-radius:4px;height:100%;transition:width .3s;position:relative}.card-progress-thumb{background:#f0f6fc;border-radius:50%;width:20px;height:20px;position:absolute;top:50%;right:-8px;transform:translateY(-50%);box-shadow:0 0 0 4px #ffffff1a}.flashcard-container{perspective:1000px;z-index:1;justify-content:center;align-items:center;max-width:1170px;min-height:48vh;margin-bottom:32px;margin-left:auto;margin-right:auto;display:flex;position:relative}.flashcard{width:100%;transform-style:preserve-3d;cursor:pointer;transition:transform .6s;display:flex;position:relative}.flashcard-inner{width:100%;height:auto;transform-style:preserve-3d;display:grid;position:relative}.flashcard-front,.flashcard-back{backface-visibility:hidden;border-radius:12px;width:100%;height:auto;min-height:300px;transition:all 0.2s ease;background:#000;border:3px solid #2a2a2a;flex-direction:column;grid-area:1/1;padding:48px;display:flex;box-shadow:0 4px 20px #000c}.flashcard-front{position:relative}.card-number-badge{color:#4285f4;-webkit-user-select:none;user-select:none;pointer-events:none;z-index:2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#ffffff0a;border:1px solid #ffffff0f;border-radius:20px;justify-content:center;align-items:center;gap:2px;padding:6px 16px;font-size:1.4rem;font-weight:700;line-height:1;display:inline-flex;position:absolute;top:16px;left:auto;right:20px}.card-number-display{color:#58a6ff;letter-spacing:.5px;font-variant-numeric:tabular-nums;font-weight:700}.flashcard-back{background:#000;position:relative;transform:rotateY(180deg)}.flashcard:hover .flashcard-front,.flashcard:hover .flashcard-back{border-color:#30363d;box-shadow:0 8px 24px rgba(0, 0, 0, 0.5)}.card-content{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:24px 0;display:flex}.card-label{color:#6e7681;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;font-size:.75rem;font-weight:600}.card-text{color:#f0f6fc;text-align:center;word-break:break-word;white-space:pre-wrap;width:100%;font-size:1.5rem;line-height:1.8;overflow-y:visible}.card-content-code{text-align:center;align-items:center;gap:16px}.card-text-paragraph{color:#f0f6fc;text-align:center;white-space:pre-wrap;margin:0;font-size:1.25rem;line-height:1.7}.paren{border-radius:4px;padding:0 2px;font-weight:700}.paren-round{color:#ff6d01;background:#ff6d010f}.paren-square{color:#4285f4;background:#4285f40f}.paren-curly{color:#8a2be2;background:#8a2be20f}.paren-angle{color:#34a853;background:#34a8530f}.card-link{color:#58a6ff;word-break:break-all;text-decoration:underline}.card-link:hover{color:#79c0ff}.study-header-actions{align-items:center;gap:8px;display:flex}.btn-diagram{color:#58a6ff;cursor:pointer;white-space:nowrap;background:#1f2937;border:1px solid #30363d;border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-diagram:hover{color:#79c0ff;background:#30363d;border-color:#58a6ff}.btn-card-diagram{color:#58a6ff;cursor:pointer;background:linear-gradient(135deg,#1f2937 0%,#161b22 100%);border:1px solid #30363d;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 20px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.btn-card-diagram:hover{color:#79c0ff;background:linear-gradient(135deg,#30363d 0%,#1f2937 100%);border-color:#58a6ff;transform:translateY(-1px);box-shadow:0 4px 12px #58a6ff26}.card-image-wrapper{margin-bottom:12px}.flashcard-front .card-text-paragraph{text-align:center}.inline-code{color:#d4d4d4;white-space:pre-wrap;word-break:break-word;background:#2d2d2d;border:1px solid #3e3e3e;border-radius:4px;padding:2px 6px;font-family:Fira Code,JetBrains Mono,Consolas,Courier New,monospace;font-size:.92em}.card-code-hint{background:#111;border:1px solid #333;border-radius:8px;flex-direction:column;align-self:center;gap:8px;max-width:90%;margin-top:24px;padding:14px 18px;display:flex}.hint-label{color:#888;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.hint-code-block{border:1px solid #2a2a2a;border-radius:6px;width:100%;overflow:hidden}.hint-code-block pre{text-align:left!important;background:#0d0d0d!important;margin:0!important;padding:10px 14px!important;font-size:1.05rem!important;line-height:1.5!important}.code-block-wrapper{background:#000;border:1px solid #333;border-radius:8px;align-self:flex-start;width:100%;margin:16px 0;overflow:hidden;box-shadow:0 8px 24px #0009}.code-block-header{background:#111;border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.code-lang-label{color:#ccc;text-transform:uppercase;letter-spacing:.5px;font-family:Fira Code,JetBrains Mono,Consolas,monospace;font-size:.75rem;font-weight:600}.code-block-wrapper pre{max-width:100%;text-align:left!important;background:#000!important;margin:0!important;padding:16px 20px!important;font-size:1.15rem!important;line-height:1.6!important;overflow-x:auto!important}.code-block-wrapper code{background:0 0!important;font-family:Fira Code,JetBrains Mono,Consolas,monospace!important;font-size:1.15rem!important}.code-block-wrapper .token.keyword,.code-block-wrapper .token.operator{font-weight:700;color:#569cd6!important}.code-block-wrapper .token.string,.code-block-wrapper .token.attr-value{color:#ce9178!important}.code-block-wrapper .token.function{color:#dcdcaa!important}.code-block-wrapper .token.comment{font-style:italic;color:#6a9955!important}.code-block-wrapper .token.number{color:#b5cea8!important}.code-block-wrapper .token.punctuation{color:#d4d4d4!important}.code-block-wrapper .token.tag{color:#569cd6!important}.code-block-wrapper .token.attr-name{color:#9cdcfe!important}.code-block-wrapper .token.builtin,.code-block-wrapper .token.class-name{color:#4ec9b0!important}.code-block-wrapper .token.regex{color:#d16969!important}.code-block-wrapper .token.boolean{color:#569cd6!important}.card-tags{border-top:1px solid #21262d;flex-wrap:wrap;justify-content:center;gap:8px;padding-top:16px;display:flex}.card-tag{background:#161b22;color:#8b949e;border-radius:12px;padding:4px 10px;font-size:.75rem}.rating-buttons{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:16px;padding:4px;display:grid}.rating-btn{cursor:pointer;color:#fff;border:none;border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;transition:all .2s;display:flex;position:relative;box-shadow:0 4px 6px #0003}.rating-btn:active{transform:scale(.98)}.rating-btn.again{color:#fff;background:#ea4335b3}.rating-btn.hard{color:#1a1a1a;background:#fbbc04b3}.rating-btn.good{color:#fff;background:#4285f4b3}.rating-btn.easy{color:#fff;background:#34a853b3}.rating-key{font-size:1rem}.rating-time{font-size:1.125rem}.rating-btn:hover{filter:brightness(1.25)}.rating-btn.again:hover{box-shadow:0 6px 20px #ea433580}.rating-btn.hard:hover{box-shadow:0 6px 20px #fbbc0480}.rating-btn.good:hover{box-shadow:0 6px 20px #4285f480}.rating-btn.easy:hover{box-shadow:0 6px 20px #34a85380}.rating-label{font-size:1.75rem;font-weight:700}.rating-key{background:#0003;border-radius:10px;padding:3px 10px;font-size:1rem;font-weight:700}.rating-time{opacity:.85;font-size:1.125rem;font-weight:500}.empty-study{text-align:center;background:#161b22;border:1px solid #30363d;border-radius:12px;padding:60px 24px}.empty-study .empty-icon{margin-bottom:16px;font-size:4rem}.empty-study h3{margin-bottom:8px;font-size:1.25rem}.empty-study p{color:#8b949e;margin-bottom:24px}.empty-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.complete-view{text-align:center;background:#161b22;border:1px solid #30363d;border-radius:12px;max-width:500px;margin:0 auto;padding:40px 24px}.complete-icon{margin-bottom:24px;font-size:5rem}.complete-view h2{margin-bottom:8px;font-size:1.75rem}.complete-subtitle{color:#8b949e;margin-bottom:32px}.session-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:32px;display:grid}.session-stat{background:#21262d;border-radius:8px;padding:16px 8px}.session-stat-value{margin-bottom:4px;font-size:1.5rem;font-weight:700;display:block}.session-stat-label{color:#8b949e;font-size:.75rem}.session-stat.again .session-stat-value{color:#da3633}.session-stat.hard .session-stat-value{color:#d29922}.session-stat.good .session-stat-value{color:#238636}.session-stat.easy .session-stat-value{color:#6d28d9}.accuracy-display{margin-bottom:32px}.accuracy-value{color:#6d28d9;font-size:3rem;font-weight:700}.accuracy-label{color:#8b949e;font-size:.875rem}.complete-actions{justify-content:center;gap:12px;display:flex}@media (width<=1024px){.study-view{padding:16px}.flashcard,.flashcard-inner,.flashcard-front,.flashcard-back{min-height:auto}.card-text{font-size:1.25rem}.rating-buttons{gap:12px}.rating-btn{padding:16px 10px}}@media (width<=768px){.flashcard,.flashcard-inner{min-height:auto}.flashcard-front,.flashcard-back{min-height:auto;padding:24px}.study-header{flex-wrap:wrap;gap:12px}.study-info{order:-1;width:100%;margin-bottom:8px;position:static;transform:none}.study-header .btn-back{order:1}.study-header .btn-reset{order:2}.card-progress-wrapper{gap:12px;padding:12px 16px}.card-progress-number{min-width:32px;font-size:1.1rem}.card-progress-track{height:14px}.card-progress-thumb{width:18px;height:18px;right:-7px}}@media (width<=640px){.flashcard,.flashcard-inner{min-height:auto}.flashcard-front,.flashcard-back{min-height:auto;padding:20px}.card-text{font-size:1rem}.rating-buttons{gap:10px}.rating-btn{border-radius:14px;padding:14px 6px}.rating-btn:before{border-radius:14px}.rating-label{font-size:1.5rem}.rating-key,.rating-time{font-size:1rem}.session-stats{grid-template-columns:repeat(2,1fr)}.card-progress-wrapper{gap:10px;padding:10px 12px}.card-progress-number{min-width:28px;font-size:1rem}.card-progress-track{height:12px}.card-progress-thumb{width:16px;height:16px;right:-6px}@media (width<=375px){.flashcard,.flashcard-inner{min-height:auto}.flashcard-front,.flashcard-back{min-height:auto;padding:16px}.card-text{font-size:1rem}.rating-buttons{gap:6px}.rating-btn{padding:12px 2px}.rating-label{font-size:1.25rem}.rating-key{padding:2px 6px;font-size:.875rem}.rating-time{font-size:.875rem}.card-progress-wrapper{gap:8px;padding:8px 10px}.card-progress-number{min-width:24px;font-size:.9375rem}.card-progress-track{height:10px}.card-progress-thumb{width:14px;height:14px;right:-5px}}@media (width<=320px){.study-view{padding:12px}.flashcard,.flashcard-inner{min-height:auto}.flashcard-front,.flashcard-back{min-height:auto;padding:12px}.card-text{font-size:.9375rem}.rating-buttons{gap:4px}.rating-btn{border-radius:10px;padding:10px 2px}.rating-label{font-size:1rem}.complete-view{padding:24px 16px}.complete-icon{font-size:3rem}.complete-view h2{font-size:1.25rem}}.card-image-wrapper{background:#0d1117;border:1px solid #30363d;border-radius:10px;justify-content:center;align-items:center;width:100%;max-height:300px;margin-bottom:20px;display:flex;overflow:hidden}.card-image{object-fit:contain;width:100%;height:auto;max-height:300px;display:block}@media (width<=768px){.card-image-wrapper,.card-image{max-height:200px}}.card-editor{max-width:900px;margin:0 auto}.editor-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.editor-title{text-align:center}.editor-title h2{margin-bottom:4px;font-size:1.25rem;font-weight:600}.editor-title span{color:#6e7681;font-size:.875rem}.editor-search{margin-bottom:24px}.editor-search .input{background:#161b22}.card-form-container{background:#161b22;border:1px solid #30363d;border-radius:12px;margin-bottom:24px;padding:24px}.card-form-container h3{margin-bottom:20px;font-size:1.125rem}.form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.form-group{margin-bottom:16px}.form-group label{color:#8b949e;margin-bottom:8px;font-size:.875rem;font-weight:500;display:block}.form-actions{border-top:1px solid #21262d;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:20px;display:flex}.cards-list{flex-direction:column;gap:12px;display:flex}.card-item{background:#161b22;border:1px solid #30363d;border-radius:8px;transition:all 0.2s ease;grid-template-columns:auto 1fr auto;align-items:start;gap:16px;padding:20px;display:grid}.card-item:hover{border-color:#30363d}.card-item-number{color:#6e7681;padding-top:4px;font-size:.75rem;font-weight:600}.card-item-content{grid-template-columns:1fr 1fr;gap:16px;display:grid}.card-item-front,.card-item-back{min-width:0}.item-label{text-transform:uppercase;letter-spacing:.5px;color:#6e7681;margin-bottom:6px;font-size:.6875rem;font-weight:600;display:block}.card-item-front p,.card-item-back p{color:#f0f6fc;text-overflow:ellipsis;-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:.9375rem;line-height:1.5;display:-webkit-box;overflow:hidden}.card-item-meta{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.card-item-tags{flex-wrap:wrap;justify-content:flex-end;gap:4px;display:flex}.item-tag{background:#21262d;color:#8b949e;border-radius:10px;padding:2px 8px;font-size:.6875rem}.card-item-stats{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.status-badge{border-radius:10px;padding:2px 8px;font-size:.6875rem;font-weight:500}.status-badge.new{background:#6d28d9;color:#fff}.status-badge.learning,.status-badge.relearning{background:#d29922;color:#000}.status-badge.review{background:#238636;color:#fff}.repetition-count{color:#6e7681;font-size:.6875rem}.card-item-actions{flex-direction:column;gap:8px;display:flex}.empty-cards{text-align:center;background:#161b22;border:1px solid #30363d;border-radius:12px;padding:60px 24px}.empty-cards .empty-icon{margin-bottom:16px;font-size:3rem}.empty-cards p{color:#8b949e;margin-bottom:20px}@media (width<=1024px){.card-editor,.editor-form,.cards-list{padding:20px}}@media (width<=768px){.form-row,.card-item-content{grid-template-columns:1fr}.card-item{grid-template-columns:1fr;gap:12px}.card-item-number{display:none}.card-item-meta{align-items:flex-start}.card-item-tags{justify-content:flex-start}.card-item-actions{flex-direction:row}}@media (width<=375px){.card-editor,.editor-form,.cards-list{padding:16px}.form-row{gap:12px}.card-item{padding:12px}.card-editor-header{flex-direction:column;align-items:flex-start;gap:12px}}@media (width<=320px){.card-editor,.editor-form{padding:12px}.form-group label{font-size:.8125rem}.card-item-actions{flex-wrap:wrap}.card-item-actions .btn{padding:6px 10px;font-size:.75rem}}.stats-view{max-width:1200px;margin:0 auto;padding:8px;animation:.4s fadeIn}.stats-header{border-bottom:1px solid #30363d;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:20px;display:flex}.btn-back{align-items:center;gap:10px;display:flex;padding:12px 20px!important;font-size:.9375rem!important}.btn-back .btn-icon{width:20px;height:20px}.btn-reset{align-items:center;gap:8px;display:flex}.btn-reset .btn-icon{width:16px;height:16px}.stats-title{align-items:center;gap:16px;display:flex}.title-icon{background:linear-gradient(135deg, #6d28d9, #7c3aed);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.title-icon svg{width:20px;height:20px}.stats-title h2{color:#f0f6fc;margin:0;font-size:1.5rem;font-weight:700}.stats-title span{color:#6e7681;font-size:.875rem}.stats-overview{grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:32px;display:grid}.stat-card{background:#161b22;border:1px solid #30363d;border-radius:16px;align-items:center;gap:16px;padding:20px;transition:all .3s;display:flex}.stat-card:hover{border-color:#30363d;box-shadow:0 4px 12px rgba(0, 0, 0, 0.4);transform:translateY(-3px)}.stat-mastery{background:linear-gradient(135deg, #4285f41a 0%, #161b22 100%);grid-column:span 2}.stat-mastery:hover{border-color:#4285f4}.stat-icon-bg{flex-shrink:0;width:64px;height:64px;position:relative}.circular-chart{width:100%;height:100%;display:block}.circle-bg{fill:none;stroke:#21262d;stroke-width:3px}.circle{fill:none;stroke:url(#gradient);stroke-width:3px;stroke-linecap:round;transform-origin:50%;animation:1s ease-out forwards circle-progress;transform:rotate(-90deg)}@keyframes circle-progress{0%{stroke-dasharray:0 100}}.mastery-value{color:#f0f6fc;font-size:1rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.stat-info{flex-direction:column;gap:4px;display:flex}.stat-sublabel{color:#6e7681;font-size:.75rem}.stat-icon-wrap{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-icon-wrap svg{width:18px;height:18px}.icon-purple{color:#66a3ff;background:#4285f426}.icon-green{color:#81c995;background:#34a85326}.icon-orange{color:#fdd835;background:#fbbc0426}.icon-red{color:#f28b82;background:#ea433526}.stat-content{flex-direction:column;gap:4px;display:flex}.stat-value{color:#f0f6fc;font-size:1.75rem;font-weight:700;line-height:1}.stat-label{color:#8b949e;font-size:.8125rem}.charts-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.chart-card{background:#161b22;border:1px solid #30363d;border-radius:20px;padding:24px;transition:all .3s}.chart-card:hover{border-color:#30363d;box-shadow:0 4px 12px rgba(0, 0, 0, 0.4)}.chart-card.wide{grid-column:span 2}.chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.chart-title{align-items:center;gap:12px;display:flex}.chart-icon{background:#21262d;width:32px;height:32px;color:#6d28d9;border-radius:8px;justify-content:center;align-items:center;display:flex}.chart-icon svg{width:16px;height:16px}.chart-title h3{color:#f0f6fc;margin:0;font-size:1.125rem;font-weight:600}.chart-container{height:260px}.time-range{background:#21262d;border-radius:10px;gap:4px;padding:4px;display:flex}.range-btn{color:#8b949e;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 16px;font-size:.8125rem;font-weight:500;transition:all .2s}.range-btn:hover{color:#f0f6fc}.range-btn.active{background:#6d28d9;color:#fff;box-shadow:0 1px 2px rgba(0, 0, 0, 0.3)}.chart-legend{border-top:1px solid #30363d;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:20px;padding-top:20px;display:grid}.legend-item{background:#21262d;border-radius:10px;align-items:center;gap:10px;padding:8px 12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.legend-name{color:#8b949e;flex:1;font-size:.875rem}.legend-value{color:#f0f6fc;font-size:1rem;font-weight:700}.difficulty-legend{flex-direction:column;gap:10px;margin-top:16px;display:flex}.difficulty-item{background:#21262d;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;display:flex}.difficulty-icon{font-size:1.25rem}.difficulty-info{flex-direction:column;flex:1;gap:6px;display:flex}.difficulty-name{color:#8b949e;font-size:.8125rem;font-weight:500}.difficulty-bar{background:#161b22;border-radius:3px;height:6px;overflow:hidden}.difficulty-fill{border-radius:3px;height:100%;transition:width .5s}.difficulty-count{color:#f0f6fc;text-align:right;min-width:30px;font-size:1rem;font-weight:700}.retention-cards{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px;display:grid}.retention-card{background:#21262d;border-radius:16px;flex-direction:column;gap:12px;padding:20px;display:flex}.retention-header{align-items:center;gap:8px;display:flex}.retention-icon{font-size:1.1rem}.retention-title{color:#8b949e;font-size:.8125rem;font-weight:500}.retention-value-large{color:#6d28d9;font-size:2.5rem;font-weight:700;line-height:1}.retention-value-large.success{color:#238636}.retention-bar-modern{background:#161b22;border-radius:4px;height:8px;overflow:hidden}.retention-fill-modern{background:linear-gradient(90deg, #6d28d9, #7c3aed);border-radius:4px;height:100%;transition:width .8s}.retention-fill-modern.success{background:linear-gradient(90deg, #238636, #81c995)}.stats-detail{border-top:1px solid #30363d;padding-top:20px}.detail-row{border-bottom:1px solid #21262d;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-label{color:#8b949e;align-items:center;gap:10px;font-size:.9375rem;display:flex}.detail-icon{color:#fff;border-radius:5px;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex}.detail-row strong{color:#f0f6fc;font-size:1rem;font-weight:600}.custom-tooltip{background:#161b22;border:1px solid #30363d;box-shadow:0 8px 24px rgba(0, 0, 0, 0.5);border-radius:10px;padding:12px 16px}.tooltip-label{color:#6e7681;margin-bottom:6px;font-size:.8125rem}.tooltip-value{margin:0;font-size:.9375rem;font-weight:600}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000c;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:#161b22;border:1px solid #30363d;width:100%;max-width:440px;box-shadow:0 16px 48px rgba(0, 0, 0, 0.6);border-radius:20px;padding:32px;animation:.3s slideUp}.modal-confirm{text-align:center}.confirm-icon-wrap{background:#ea433526;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex}.confirm-icon{color:#ea4335;width:28px;height:28px}.confirm-icon svg{width:100%;height:100%}.modal-confirm h3{color:#f0f6fc;margin:0 0 12px;font-size:1.375rem;font-weight:700}.modal-confirm p{color:#8b949e;margin-bottom:16px;font-size:.9375rem;line-height:1.6}.confirm-alert{color:#f28b82;background:#ea43351a;border:1px solid #ea433533;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-bottom:24px;padding:12px 16px;font-size:.875rem;font-weight:500;display:flex}.modal-actions{justify-content:center;gap:12px;display:flex}.modal-actions .btn{padding:12px 24px;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=1024px){.stats-overview{grid-template-columns:repeat(3,1fr)}.stat-mastery{grid-column:span 3}}@media (width<=768px){.stats-header{flex-wrap:wrap;gap:16px}.stats-header .btn-reset{order:3;justify-content:center;width:100%}.stats-overview{grid-template-columns:repeat(2,1fr)}.stat-mastery{grid-column:span 2}.charts-grid{grid-template-columns:1fr}.chart-card.wide{grid-column:span 1}.chart-header{flex-direction:column;align-items:flex-start;gap:12px}.time-range{width:100%}.range-btn{text-align:center;flex:1}.retention-cards,.chart-legend{grid-template-columns:1fr}}@media (width<=480px){.stats-title{flex-direction:column;align-items:flex-start;gap:8px}.title-icon{width:36px;height:36px}.stats-title h2{font-size:1.25rem}.stats-overview{grid-template-columns:1fr}.stat-mastery{grid-column:span 1}.stat-card{text-align:center;flex-direction:column}.modal{padding:24px}}@media (width<=375px){.stats-header{flex-direction:column;align-items:flex-start;gap:12px}.stats-title{order:-1;justify-content:center;width:100%}.stat-mastery{grid-column:span 1}.stat-card{padding:16px}.stat-value{font-size:1.5rem}.chart-card{padding:16px}.retention-cards{grid-template-columns:1fr}}@media (width<=320px){.stats-view{padding:12px}.stats-overview{grid-template-columns:1fr}.stat-card{text-align:center;flex-direction:column;gap:8px}.stat-icon-bg{width:48px;height:48px}.chart-legend{grid-template-columns:1fr}.legend-item{padding:6px 10px}.modal{padding:20px 16px}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}@media (hover:none) and (pointer:coarse){.btn,.rating-btn,.nav-btn,.card-slider,.range-btn{min-width:44px;min-height:44px}.rating-btn{padding:20px 10px}}html,body{background:#0d1117;height:100%;color:#f0f6fc;scrollbar-gutter:stable;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:16px;line-height:1.5}#root{height:100%}.app{background:#000;flex-direction:column;min-height:100vh;display:flex;position:relative}.app-header{background:#161b22;border-bottom:1px solid #30363d;z-index:100;padding:0 24px;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;display:flex}.logo{color:#f0f6fc;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;font-size:1.25rem;font-weight:600;display:flex}.logo-icon{color:#6d28d9;font-size:1.5rem}.nav-btn{border:1px solid #30363d;color:#8b949e;border-radius:8px;cursor:pointer;transition:all 0.2s ease;background:0 0;padding:8px 16px;font-size:.875rem}.nav-btn:hover{background:#21262d;color:#f0f6fc}.nav-btn.active{background:#6d28d9;border-color:#6d28d9;color:#fff}.app-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:16px 24px}.app-footer{background:#161b22;border-top:1px solid #30363d;text-align:center;padding:16px 24px}.app-footer p{color:#6e7681;font-size:.75rem}.app-loading{min-height:100vh;color:#8b949e;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid #21262d;border-top-color:#6d28d9;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn{border-radius:8px;cursor:pointer;transition:all 0.2s ease;border:none;outline:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#6d28d9;color:#fff}.btn-primary:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px)}.btn-secondary{background:#21262d;color:#f0f6fc;border:1px solid #30363d}.btn-secondary:hover:not(:disabled){background:#30363d}.btn-danger{background:#da3633;color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.1)}.btn-success{background:#238636;color:#fff}.btn-again{background:#da3633;color:#fff}.btn-hard{color:#fff;background:#b45309}.btn-good{background:#238636;color:#fff}.btn-easy{background:#6d28d9;color:#fff}.btn-sm{padding:6px 12px;font-size:.75rem}.btn-lg{padding:14px 28px;font-size:1rem}.card{background:#161b22;border:1px solid #30363d;border-radius:12px;transition:all 0.2s ease;padding:24px}.card:hover{border-color:#30363d}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{font-size:1.125rem;font-weight:600}.card-body{color:#8b949e}.input,.textarea{background:#21262d;border:1px solid #30363d;border-radius:8px;width:100%;color:#f0f6fc;transition:all 0.2s ease;padding:12px 16px;font-size:.875rem}.input:focus,.textarea:focus{border-color:#6d28d9;outline:none}.input::placeholder,.textarea::placeholder{color:#6e7681}.textarea{resize:vertical;min-height:120px;font-family:inherit;line-height:1.6}.text-center{text-align:center}.text-success{color:#238636}.text-warning{color:#d29922}.text-danger{color:#da3633}.text-muted{color:#6e7681}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:16px}.gap-3{gap:24px}.animate-fade-in{animation:.3s fadeIn}@keyframes flip{0%{transform:rotateY(0)}to{transform:rotateY(180deg)}}@keyframes flipBack{0%{transform:rotateY(180deg)}to{transform:rotateY(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0d1117}::-webkit-scrollbar-thumb{background:#30363d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6e7681}@media (width<=1024px){.app-main{max-width:100%;padding:20px}}@media (width<=768px){.app-main{padding:16px}.header-content{height:56px}.logo{font-size:1rem}.card{padding:16px}}@media (width<=375px){.app-main{padding:12px}.header-content{height:52px;padding:0 16px}.logo{font-size:.9375rem}.btn{padding:8px 16px;font-size:.8125rem}}@media (width<=320px){html{font-size:14px}.app-main{padding:10px}.header-content{padding:0 12px}.btn-sm{padding:4px 8px;font-size:.6875rem}}:root{--bg-primary:#000;--bg-secondary:#161b22;--bg-tertiary:#21262d;--bg-elevated:#30363d;--text-primary:#f0f6fc;--text-secondary:#8b949e;--text-muted:#6e7681;--accent-primary:#4285f4;--accent-secondary:#1a73e8;--accent-success:#34a853;--accent-warning:#fbbc04;--accent-danger:#ea4335;--border-color:#30363d;--border-light:#21262d;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-xl:0 16px 48px #0009;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--transition:all .2s ease}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#f0f6fc;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background:#000!important}#root{min-height:100vh}::selection{color:#f0f6fc;background:#58a6ff4d}a{color:#8ab8ff;text-decoration:none}a:hover{text-decoration:underline}code{background:#141414;border-radius:4px;padding:2px 6px;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.9em}pre{background:#0a0a0a;border:1px solid #1f1f1f;border-radius:8px;padding:16px;overflow-x:auto}pre code{background:0 0;padding:0}ul,ol{padding-left:20px}li{margin-bottom:4px}table{border-collapse:collapse;width:100%;margin:16px 0}th,td{text-align:left;border-bottom:1px solid #1f1f1f;padding:12px}th{color:#f0f6fc;background:#0a0a0a;font-weight:600}tr:hover{background:#0a0a0a}img{border-radius:8px;max-width:100%;height:auto}:focus-visible{outline-offset:2px;outline:2px solid #8ab8ff}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}}
/*$vite$:1*/