.home-page{background:var(--gradient-bg);color:var(--text-primary);min-height:100vh;padding:clamp(1.5rem,3vw,3rem)}.home-inner{display:flex;flex-direction:column;gap:2rem;margin:0 auto;width:min(1200px,100%)}.home-hero{grid-gap:2rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:28px;box-shadow:var(--shadow-card);display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));overflow:hidden;padding:clamp(1.8rem,3vw,3rem);position:relative}.home-hero:after{background:radial-gradient(circle,#4dd0e173 0,#4dd0e100 70%);border-radius:50%;content:"";height:320px;inset:auto -80px -140px auto;pointer-events:none;position:absolute;width:320px}.home-hero.compact:after{display:none}.hero-content,.hero-panel{position:relative;z-index:1}.hero-chip{align-items:center;background:#4dd0e126;border:1px solid #4dd0e180;border-radius:999px;color:#9de2ff;display:inline-flex;font-size:.85rem;gap:.4rem;letter-spacing:.08em;padding:.35rem 1rem;text-transform:uppercase}.home-hero h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:.6rem;margin-top:1rem}.hero-subtitle{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.button-group{gap:.8rem}.home-page .button.button-primary{background:linear-gradient(135deg,#4dd0e1,#7c4dff);border:1px solid #ffffff1f;box-shadow:0 10px 30px #4c5aff59;color:#060a1d;font-weight:600}.home-page .button.button-secondary{background:var(--border-color);border:1px solid var(--border-color-hover);color:var(--text-primary);font-weight:500}.button-large{border-radius:999px;font-size:1rem;padding:.95rem 2.8rem}.hero-stats{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem}.stat-card{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:16px;flex:1 1;min-width:140px;padding:1rem 1.2rem}.stat-card span{color:var(--text-tertiary);display:block;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}.stat-card strong{display:block;font-size:1.2rem;margin-top:.4rem}.hero-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:1.5rem}.hero-panel h3{margin-bottom:.8rem}.hero-list{color:var(--text-secondary);display:flex;flex-direction:column;gap:.8rem;list-style:none}.hero-list li:before{color:var(--accent-primary);content:"·";margin-right:.5rem}.chapters-section,.home-section,.info-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;box-shadow:var(--shadow-card);padding:clamp(1.5rem,3vw,2.5rem)}.section-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.section-label{color:var(--text-tertiary);font-size:.8rem;letter-spacing:.08em;margin-bottom:.35rem;text-transform:uppercase}.chapters-grid,.features-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:18px;padding:1.5rem}.feature-card h3{margin-bottom:.6rem}.feature-card p{color:var(--text-secondary);line-height:1.5}.info-card p{color:var(--text-secondary);line-height:1.7;margin-bottom:.8rem}.chapters-grid{grid-template-columns:repeat(auto-fill,minmax(260px,320px));justify-content:flex-start}.chapter-card{background:var(--gradient-card);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:.8rem;padding:1.8rem}.chapter-card:hover{transform:translateY(-4px);transition:transform .3s ease}.chapter-pill{align-self:flex-start;background:#4dd0e126;border:1px solid #4dd0e166;border-radius:999px;font-size:.8rem;letter-spacing:.08em;padding:.3rem .9rem;text-transform:uppercase}.chapter-card p{color:var(--text-secondary);line-height:1.5}.chapter-meta{color:var(--text-tertiary);display:flex;font-size:.85rem;gap:.75rem}.chapter-card .button{border-radius:12px;margin-top:auto}.error-card,.loading-panel,.no-chapters{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--shadow-card);padding:2rem;text-align:center}.loading-panel p,.no-chapters p{color:var(--text-secondary);margin-top:1rem}.spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color);border:4px solid var(--border-color);border-radius:999px;border-top-color:var(--accent-primary);height:50px;margin:0 auto;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.chapters-page{background:var(--gradient-bg);color:var(--text-primary);min-height:100vh;padding:clamp(1.5rem,3vw,3rem)}.chapters-page>*{margin:0 auto;width:min(1200px,100%)}.chapters-header{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;box-shadow:var(--shadow-card);display:flex;gap:1.5rem;justify-content:space-between;padding:1.5rem 2rem}.chapters-header h1{margin:0}.subtitle{color:var(--text-tertiary);margin-top:.35rem}.header-buttons{display:flex;flex-wrap:wrap;gap:.8rem}.header-buttons .button{border-radius:999px;padding:.6rem 1.3rem}.chapters-page .chapters-grid{margin-top:2rem}.error-container{margin-top:1.5rem}.small-text{color:var(--text-tertiary);margin-top:.5rem}@media (max-width:768px){.chapters-header,.home-hero{grid-template-columns:1fr;padding:1.5rem}.header-buttons{justify-content:space-between;width:100%}.chapter-card,.feature-card{padding:1.2rem}.button-group{flex-direction:column}}.main-page{background:linear-gradient(180deg,#fbfbfe,#fff);padding:36px 20px}.main-page-header{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.main-title{color:#11101a;font-size:2rem;font-weight:700;margin-bottom:0}.main-page-actions{align-items:center;display:flex;gap:12px}@media (max-width:520px){.main-page-header{align-items:flex-start;flex-direction:column}.main-page-actions{justify-content:flex-end;width:100%}}.courses-scroll{-webkit-overflow-scrolling:touch;display:flex;flex-direction:row;gap:20px;overflow-x:auto;padding-bottom:12px;scrollbar-width:thin}.course-tile{align-items:flex-start;background:linear-gradient(180deg,#fff,#fbfbff);border:1px solid #22225a0f;border-radius:14px;box-shadow:0 8px 30px #2222501f;display:flex;flex-direction:column;max-width:340px;min-width:260px;padding:20px 18px;transition:transform .18s ease,box-shadow .18s ease;will-change:transform}.course-tile:hover{box-shadow:0 18px 44px #2222502e;transform:translateY(-6px) scale(1.02)}.course-tile.active{border:1px solid #1f2b6b38;box-shadow:0 18px 44px #22225038}.course-tile:focus-within{outline:3px solid #3a3a7a14}.course-level{color:#1f2b6b;font-size:1.15rem;font-weight:800;margin-bottom:8px}.course-title{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#111217;display:-webkit-box;font-size:.98rem;font-weight:500;line-height:1.3;overflow:hidden;text-overflow:ellipsis}.courses-scroll::-webkit-scrollbar{height:10px}.courses-scroll::-webkit-scrollbar-track{background:#0000}.courses-scroll::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#22225033,#22225052);border-radius:999px}.courses-scroll{scrollbar-color:#22225047 #0000}@media (max-width:520px){.courses-scroll{gap:12px;padding-bottom:8px}.course-tile{min-width:200px;padding:16px}.main-title{font-size:1.4rem}}.chapters-section{margin-top:28px}.chapters-header{color:#11101a;font-size:1.2rem;margin-bottom:12px}.chapters-row{display:flex;gap:14px;overflow-x:auto;padding-bottom:10px}.chapter-tile{background:linear-gradient(180deg,#fff,#fbfcff);border:1px solid #141e500a;border-radius:12px;box-shadow:0 8px 26px #12184614;display:flex;flex-direction:column;gap:8px;max-width:360px;min-width:260px;padding:18px}.chapter-title{color:#14204f;font-size:.98rem;font-weight:800;text-transform:uppercase}.chapter-desc{color:#3b3b45;font-size:.92rem;opacity:.95;text-transform:none;text-transform:lowercase}@media (max-width:520px){.chapter-tile{min-width:200px;padding:14px}}.auth-shell{align-items:center;background:var(--gradient-bg);display:flex;justify-content:center;min-height:100vh;padding:clamp(1.5rem,4vw,4rem)}.auth-grid{grid-gap:clamp(1.5rem,3vw,3rem);align-items:stretch;display:grid;gap:clamp(1.5rem,3vw,3rem);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));width:min(1100px,100%)}.auth-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:26px;box-shadow:var(--shadow-card);padding:clamp(1.5rem,3vw,3rem)}.auth-panel h1{color:var(--text-primary);font-size:clamp(2rem,3.5vw,2.7rem);margin:1rem 0 .6rem}.auth-panel-text{color:var(--text-secondary);line-height:1.6;margin-bottom:1.4rem}.auth-list{color:var(--text-secondary);display:flex;flex-direction:column;gap:.75rem;list-style:none;margin:0;padding:0}.auth-list li:before{color:var(--accent-primary);content:"•";margin-right:.6rem}.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:26px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;padding:clamp(1.5rem,3vw,2.75rem)}.auth-card h2{color:var(--text-primary);margin-bottom:.5rem}.auth-subtitle{color:var(--text-tertiary);margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:.9rem}.auth-label{color:var(--text-secondary);font-size:.9rem}.auth-form input{background:var(--input-bg);border:1px solid var(--input-border);border-radius:14px;color:var(--text-primary);font-size:1rem;padding:.85rem 1rem}.auth-form input::placeholder{color:var(--text-muted)}.auth-form input:focus{border-color:var(--accent-secondary);box-shadow:0 0 0 3px #7c4dff40;outline:none}.auth-card .button{border-radius:14px;margin-top:.5rem;width:100%}.auth-divider{color:var(--text-tertiary);margin:1.5rem 0;position:relative;text-align:center}.auth-divider:after,.auth-divider:before{background:var(--border-color);content:"";height:1px;position:absolute;top:50%;width:40%}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-divider span{background:#0000;padding:0 .5rem}.auth-google{background:var(--bg-card-hover);border:1px solid var(--border-color);color:var(--text-primary)}.auth-link{color:var(--text-secondary);margin-top:1.5rem;text-align:center}.auth-link a{color:var(--accent-primary);font-weight:600;text-decoration:none}.auth-link a:hover{text-decoration:underline}.auth-error{margin-top:.25rem}@media (max-width:768px){.auth-shell{padding:1.5rem}.auth-grid{grid-template-columns:1fr}.auth-card,.auth-panel{padding:1.5rem}}.lesson-page{margin:0 auto;max-width:1200px;padding:20px}.lesson-header{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;padding:20px}.lesson-header h1{color:#333;margin:0 0 10px}.course-level{color:#666;font-size:14px}.sections-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.section-card{cursor:pointer;transition:transform .2s,box-shadow .2s}.section-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-4px)}.grammar-topic{color:#007bff;margin:10px 0}.section-content{background:#fff;border-radius:8px;padding:20px}.grammar-box{background:#f0f7ff;border-left:4px solid #007bff;margin-bottom:20px}.grammar-box h3{color:#007bff;margin-top:0}.exercises-section,.vocabulary-section{margin-bottom:20px}.vocab-list{grid-gap:15px;display:grid;gap:15px}.vocab-item{background:#f9f9f9;border-left:3px solid #28a745;border-radius:4px;padding:15px}.vocab-german{color:#333;font-size:16px;font-weight:700}.vocab-translation{color:#666;font-size:14px;margin:5px 0}.vocab-context{color:#999;font-size:13px;margin-top:8px}.exercises-list{grid-gap:15px;display:grid;gap:15px}.exercise-item{background:#f9f9f9;border-left:3px solid #ffc107;border-radius:4px;padding:15px}.exercise-number{color:#333;font-weight:700;margin-bottom:5px}.exercise-type{background:#ffc107;border-radius:3px;color:#fff;display:inline-block;font-size:12px;margin-bottom:10px;padding:2px 8px}.exercise-instruction{color:#555;margin:10px 0}.exercise-difficulty{color:#999;font-size:12px}.modules-page{margin:0 auto;padding:2rem;width:min(1100px,100%)}.modules-container{width:100%}.modules-header{margin-bottom:3rem;text-align:center}.modules-header h1{color:#2c3e50;font-size:2.5rem}.modules-header .subtitle{color:#fff;font-size:1.1rem}.modules-grid{grid-gap:2rem;align-items:stretch;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:2rem}.module-card{--accent-color:#4dd0e1;background:linear-gradient(160deg,#0c1021,#1b2140 60%,#253158);border:1px solid #ffffff14;border-radius:16px;box-shadow:0 18px 50px #050a1973;color:#f5f7ff;cursor:pointer;display:flex;flex-direction:column;min-height:320px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.module-card:hover{box-shadow:0 35px 80px #050a1999;transform:translateY(-6px)}.module-hero{aspect-ratio:16/9;background-color:#0c1225;background-position:50%;background-size:cover;min-height:140px;position:relative}.module-hero:after{background:linear-gradient(180deg,#0508140d 20%,#070d2199);content:"";inset:0;position:absolute}.module-type-chip{align-items:center;background:#080d21cc;border:1px solid #ffffff59;border-radius:999px;color:#f5f7ff;display:inline-flex;font-size:.85rem;font-weight:600;gap:.4rem;left:1rem;letter-spacing:.05em;padding:.35rem .9rem;position:absolute;top:1rem}.module-body{display:flex;flex-direction:column;gap:.75rem;padding:1.4rem 1.8rem 1.6rem}.module-body h3{font-size:1.25rem;margin:0}.module-summary{color:#ffffffe0;font-size:.95rem;line-height:1.45;min-height:3.5rem}.module-keywords{display:flex;flex-wrap:wrap;gap:.4rem}.module-keywords span{background:#ffffff26;border:1px solid #ffffff1a;border-radius:999px;font-size:.8rem;padding:.2rem .7rem}.module-actions{align-items:center;display:flex;gap:.75rem;justify-content:space-between;margin-top:auto}.module-tutor-chip{border:1px solid #ffffff59;border-radius:999px;font-size:.8rem;letter-spacing:.04em;padding:.35rem .85rem}.module-actions .button.ghost{background:#0000;border:1px solid var(--accent-color);color:#f5f7ff;min-width:110px}.module-actions .button.ghost:hover{background:var(--accent-color)}.module-info{align-items:center;color:#3498db;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:.5rem}.module-card .button{align-self:stretch;margin-top:auto}.modules-info{background:#f8f9fa;border-left:4px solid #3498db;border-radius:12px;padding:2rem}.modules-info h2{color:#2c3e50;margin-bottom:1rem}.modules-info p{color:#555;font-size:.95rem;line-height:1.8}.modules-info ul{color:#555;list-style:disc;margin:0;padding-left:1.2rem}.modules-info li{line-height:1.6;margin-bottom:.35rem}.loading{color:#7f8c8d;font-size:1.2rem;min-height:50vh}.error{background:#fee;border-radius:8px;color:#c33;margin:2rem 0;padding:2rem}@media (max-width:768px){.modules-page{padding:1rem}.modules-grid{gap:1rem;grid-template-columns:1fr}.modules-header h1{font-size:2rem}}@media (min-width:1200px){.modules-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.module-player-page{background:var(--gradient-bg);box-sizing:border-box;color:var(--text-primary);display:flex;flex-direction:column;height:100vh;max-height:100vh;overflow:hidden;padding:clamp(.8rem,1.5vw,1.5rem)}.module-player-page.start-mode{align-items:center;display:flex;justify-content:center}.module-start-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:32px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:1.3rem;padding:clamp(1.8rem,3vw,2.6rem);text-align:left;width:min(520px,100%)}.module-start-chip{align-self:flex-start;background:#4dd0e126;border:1px solid #4dd0e180;border-radius:999px;color:var(--accent-primary);font-size:.85rem;letter-spacing:.08em;padding:.35rem 1rem;text-transform:uppercase}.module-start-subtitle{color:var(--text-secondary);line-height:1.6;margin:0}.module-start-detail{background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:20px;padding:1.2rem 1.4rem}.module-start-detail strong{color:var(--text-tertiary);display:block;font-size:.8rem;letter-spacing:.08em;margin-bottom:.35rem;text-transform:uppercase}.module-start-detail p{color:var(--text-secondary);line-height:1.55;margin:0}.module-start-button{border-radius:16px;font-size:1.05rem;padding:.9rem;width:100%}.player-header{align-items:flex-start;background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--shadow-card);display:flex;flex-shrink:0;gap:1rem;margin:0 auto 1rem;padding:1rem 1.5rem;width:min(1200px,100%)}.player-header .button{border-radius:999px}.header-grammar-card{background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:16px;color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin-top:.8rem;padding:1rem 1.2rem}.player-container{display:flex;flex:1 1;gap:1rem;margin:0 auto;min-height:0;overflow:hidden;width:min(1200px,100%)}.chat-panel,.info-panel>*{background:var(--bg-card);border:1px solid var(--border-color);border-radius:22px;box-shadow:var(--shadow-card)}.chat-panel{overflow:hidden}.chat-messages,.chat-panel{display:flex;flex:1 1;flex-direction:column;min-height:0}.chat-messages{background:var(--bg-card-hover);border-bottom:1px solid var(--border-color);border-top:1px solid var(--border-color);gap:.6rem;overflow-y:auto;padding:.75rem 1rem;scroll-behavior:smooth}.chat-messages::-webkit-scrollbar,.info-panel::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-thumb,.info-panel::-webkit-scrollbar-thumb{background:var(--border-color-hover);border-radius:999px}.chat-message{animation:slideIn .25s ease;display:flex;gap:.6rem}.chat-message.user{justify-content:flex-end}.chat-message.user .message-avatar{order:2}.chat-message.user .message-content{align-items:flex-end;order:1}.message-avatar{font-size:1.2rem;line-height:1;min-width:32px;text-align:center}.message-content{display:flex;flex-direction:column;gap:.25rem;max-width:80%}.message-content p{border-radius:12px;font-size:.9rem;line-height:1.5;margin:0;padding:.6rem .85rem;word-break:break-word}.chat-message.user .message-content p{background:linear-gradient(135deg,var(--accent-secondary) 0,var(--accent-primary) 100%);border-radius:16px 0 16px 16px;color:#fff}.chat-message.ai .message-content p{background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:0 16px 16px 16px;color:var(--text-primary)}.message-translation{background:var(--bg-card-hover)!important;border-radius:8px;color:var(--text-secondary);font-size:.8rem;font-style:italic;margin-top:.2rem!important;padding:.4rem .65rem!important}.message-time{color:var(--text-muted);font-size:.7rem;margin-top:.15rem}.message-actions{display:flex;gap:4px;position:absolute;right:-8px;top:-8px;z-index:5}.message-action-btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:999px;cursor:pointer;font-size:.95rem;line-height:1;opacity:.9;padding:3px 5px}.message-action-btn:hover{opacity:1}.message-action-btn:disabled{cursor:not-allowed;opacity:.35}.chat-input-form{background:var(--bg-card);border-top:1px solid var(--border-color);padding:.85rem 1rem}.input-group{align-items:stretch;display:flex;gap:.75rem}.chat-input{background:var(--input-bg);border:1px solid var(--input-border);border-radius:14px;color:var(--text-primary);flex:1 1;font-size:1rem;line-height:1.45;max-height:180px;min-height:48px;overflow-y:hidden;padding:.85rem 1rem;resize:none}.chat-input::placeholder{color:var(--text-muted)}.chat-input:focus{border-color:var(--accent-secondary);box-shadow:0 0 0 3px #7c4dff40;outline:none}.chat-input:disabled{opacity:.5}.info-panel{max-height:100%;overflow-y:auto;width:320px}.info-panel,.module-info-card{display:flex;flex-direction:column;gap:1rem}.module-info-card{padding:1.5rem}.module-info-card h3{margin:0}.vocab-list{max-height:calc(100vh - 320px);overflow-y:auto;padding-right:.4rem}.vocab-list::-webkit-scrollbar{width:6px}.vocab-list::-webkit-scrollbar-thumb{background:var(--border-color-hover);border-radius:999px}.playing-indicator{animation:pulse 1.4s infinite;background:linear-gradient(120deg,var(--accent-primary),var(--accent-secondary));border-radius:12px;color:#050714;font-weight:600;margin-top:.75rem;padding:.65rem 1rem;text-align:center}.voice-button{background:#29b6f6;border:none;border-radius:14px;color:#050714;cursor:pointer;font-size:1.2rem;font-weight:600;min-width:60px;padding:.75rem 1.2rem;transition:transform .2s ease,box-shadow .2s ease}.voice-button:hover{box-shadow:0 10px 25px #29b6f666;transform:translateY(-1px)}.voice-button.listening{background:#ff7675;box-shadow:0 0 0 8px #ff767526}.audio-toggle-button{background:var(--bg-card-hover);border:none;border-radius:14px;color:var(--text-primary);cursor:pointer;font-size:1.2rem;font-weight:700;min-width:60px;padding:.75rem 1.2rem;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.audio-toggle-button:hover{box-shadow:0 10px 25px #7c4dff2e;transform:translateY(-1px)}.playing-indicator,.voice-button.listening{animation:pulse 1.5s infinite}.error,.loading{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary);margin:5rem auto;padding:2rem;text-align:center;width:min(500px,100%)}.error{color:#ff9ba7}@media (max-width:1200px){.player-container{flex-direction:column}.info-panel{flex-direction:row;overflow-x:auto;width:100%}.module-info-card{min-width:260px}}@media (max-width:768px){.player-header{flex-direction:column;padding:1.5rem}.player-container{gap:1rem}.info-panel{display:none}.message-content{max-width:90%}.input-group{flex-direction:column}.voice-button{width:100%}}.pdf-upload-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.pdf-upload-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:600px;padding:40px;width:100%}.pdf-upload-card h2{color:#333;font-size:24px;margin:0 0 10px}.subtitle{color:#666;font-size:14px;margin:0 0 30px}.upload-form{display:flex;flex-direction:column;gap:20px}.form-group label{color:#333;margin-bottom:8px}.form-group input[type=file],.form-group select{border:2px solid #e0e0e0;border-radius:8px;font-size:14px;padding:12px;transition:border-color .3s}.form-group input[type=file]:focus,.form-group select:focus{border-color:#667eea;outline:none}.form-group input[type=file]:disabled,.form-group select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.file-input-wrapper{display:block;position:relative}.file-input{height:0;opacity:0;position:absolute;width:0}.file-label{background:#f9f9f9;border:2px dashed #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:block;font-weight:500;padding:12px;text-align:center;transition:all .3s}.file-input:disabled~.file-label{background:#f5f5f5;color:#999;cursor:not-allowed}.file-label:hover:not(:disabled){background:#f0f4ff;border-color:#764ba2;color:#764ba2}.upload-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:transform .2s,box-shadow .2s}.upload-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.upload-button:disabled{cursor:not-allowed;opacity:.6}.upload-button.loading{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.progress-message{animation:slideIn .3s ease-out;background:#e3f2fd;border-left:4px solid #1976d2;border-radius:8px;color:#1976d2;font-size:14px;padding:12px;text-align:center}.progress-message.success{background:#e8f5e9;border-left-color:#388e3c;color:#388e3c}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-message{background:#ffebee;border-left:4px solid #c62828;color:#c62828}.error-message,.success-message{border-radius:8px;font-size:14px;padding:12px}.success-message{background:#e8f5e9;border-left:4px solid #388e3c;color:#388e3c}.info-box{background:#f5f5f5;border-left:4px solid #667eea;border-radius:8px;margin-top:20px;padding:16px}.info-box h4{color:#333;font-size:14px;margin:0 0 12px}.info-box ol,.info-box ul{color:#666;font-size:13px;margin:0;padding-left:20px}.info-box li{margin-bottom:8px}.info-box ul{margin-top:4px}.example-box{background:#1e1e1e;border-radius:8px;color:#d4d4d4;margin-top:20px;overflow-x:auto;padding:16px}.example-box h4{color:#4ec9b0;font-size:13px;margin:0 0 12px}.example-box pre{color:#ce9178;font-family:Courier New,monospace;font-size:11px;line-height:1.4;margin:0}@media (max-width:600px){.pdf-upload-card{padding:20px}.pdf-upload-card h2{font-size:20px}.upload-button{font-size:14px;padding:12px 20px}}.admin-page{background:#f5f5f5;min-height:100vh}.admin-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:30px 20px}.header-left h1{font-size:28px;margin:0 0 5px}.header-left p{font-size:14px;margin:0;opacity:.9}.header-right{align-items:center;display:flex;gap:15px}.admin-badge{border-radius:20px;padding:8px 16px}.admin-badge,.logout-button{background:#fff3;font-size:14px;font-weight:500}.logout-button{border:2px solid #fff;border-radius:6px;color:#fff;cursor:pointer;padding:10px 20px;transition:all .3s}.logout-button:hover{background:#ffffff4d;transform:translateY(-2px)}.admin-tabs{background:#fff;border-bottom:2px solid #e0e0e0;display:flex;gap:0;overflow-x:auto;padding:0 20px}.tab-button{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:15px;font-weight:500;padding:16px 24px;transition:all .3s;white-space:nowrap}.tab-button:hover{background:#f9f9f9;color:#333}.tab-button.active{border-bottom-color:#667eea;color:#667eea}.admin-content{margin:0 auto;max-width:1200px;padding:40px 20px}.tab-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;padding:20px}.manage-box,.stats-box{color:#999;padding:40px;text-align:center}.manage-box h3,.stats-box h3{color:#333;margin-top:0}.admin-footer{border-top:1px solid #e0e0e0;color:#999;font-size:14px;margin-top:40px;padding:20px;text-align:center}.admin-error{align-items:center;background:#f5f5f5;display:flex;flex-direction:column;justify-content:center;min-height:100vh;text-align:center}.admin-error h2{color:#d32f2f;margin-top:0}.admin-error button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;margin-top:20px;padding:12px 24px;transition:all .3s}.admin-error button:hover{background:#764ba2}@media (max-width:768px){.admin-header{flex-direction:column;gap:15px;text-align:center}.header-right{flex-direction:column;width:100%}.logout-button{width:100%}.admin-tabs{padding:0}.tab-button{font-size:13px;padding:12px 16px}.admin-content{padding:20px}}.voice-settings{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-card,linear-gradient(135deg,#667eea 0,#764ba2 100%));border-radius:12px;box-shadow:0 8px 24px #00000026;box-shadow:var(--shadow-card,0 8px 24px #00000026);color:#fff;color:var(--text-primary,#fff);margin:20px auto;max-width:500px;padding:24px}.voice-settings-header{border-bottom:2px solid #ffffff4d;margin-bottom:24px;padding-bottom:12px}.voice-settings-header h2{font-size:1.8rem;font-weight:600;margin:0}.voice-settings-form{gap:16px;margin-bottom:24px}.form-group,.voice-settings-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#fffffff2;font-size:.95rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.form-group select{background:#ffffff14;background:var(--input-bg,#ffffff14);border:2px solid #ffffff26;border:2px solid var(--input-border,#ffffff26);border-radius:8px;color:#fff;color:var(--text-primary,#fff);cursor:pointer;font-size:.95rem;font-weight:500;padding:12px 14px;transition:all .3s ease}.form-group select:hover:not(:disabled){background:#ffffff26;border-color:#ffffff80}.form-group select:focus:not(:disabled){background:#ffffff0a;border-color:#ffffff26;border-color:var(--input-border,#ffffff26);box-shadow:0 0 0 3px #00000012;outline:none}.form-group select:disabled{background:#ffffff0d;cursor:not-allowed;opacity:.6}.form-group select option{background:#333;background:var(--input-bg,#333);color:#fff;color:var(--text-primary,#fff);padding:8px}.btn-test{background:#fff;border:none;border-radius:8px;box-shadow:0 4px 15px #0003;color:#667eea;cursor:pointer;font-size:1rem;font-weight:700;letter-spacing:1px;padding:14px 24px;text-transform:uppercase;transition:all .3s ease}.btn-test:hover:not(:disabled){box-shadow:0 6px 20px #0000004d;transform:translateY(-2px)}.btn-test:active:not(:disabled){transform:translateY(0)}.btn-test:disabled{cursor:not-allowed;opacity:.6}.status-message{animation:fadeIn .3s ease;background:#ffffff26;border-left:4px solid #ffffff80;border-radius:8px;font-weight:500;padding:12px 16px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.voice-settings-info{background:#ffffff1a;border:2px solid #fff3;border-radius:8px;padding:16px}.voice-settings-info h3{font-size:1rem;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.voice-settings-info ul{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.voice-settings-info li{border-bottom:1px solid #ffffff1a;display:flex;font-size:.9rem;justify-content:space-between;padding:6px 0}.voice-settings-info li:last-child{border-bottom:none}.voice-settings-info strong{color:#ffffffe6;font-weight:600}@media (max-width:600px){.voice-settings{margin:16px;padding:16px}.voice-settings-header h2{font-size:1.4rem}.btn-test{font-size:.9rem;padding:12px 20px}}.settings-page{align-items:flex-start;background:var(--gradient-bg);color:var(--text-primary);display:flex;justify-content:center;min-height:100vh;padding:3rem 1.5rem 4rem}.settings-loading{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;font-size:1.1rem;letter-spacing:.03em;padding:2rem 3rem}.settings-content{grid-gap:2rem;display:grid;gap:2rem;width:min(1100px,95%)}.settings-hero-card{background:var(--gradient-hero);border:1px solid var(--border-color);border-radius:22px;box-shadow:var(--shadow-card);padding:2.5rem}.settings-eyebrow{color:var(--text-tertiary);font-size:.75rem;letter-spacing:.2em;margin:0 0 .75rem;text-transform:uppercase}.settings-hero-card h1{font-size:clamp(2rem,4vw,2.8rem);margin:0 0 1rem}.settings-hero-text{color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem;max-width:640px}.settings-hero-tags{display:flex;flex-wrap:wrap;gap:.6rem}.settings-hero-tags span{background:var(--border-color);border:1px solid var(--border-color-hover);border-radius:999px;font-size:.85rem;letter-spacing:.04em;padding:.35rem 1rem}.settings-card{background:var(--gradient-card);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--shadow-card);padding:2.2rem}.settings-form-header{display:flex;flex-wrap:wrap;gap:1.25rem;justify-content:space-between;margin-bottom:2rem}.settings-form-header h2{font-size:1.8rem;margin:.3rem 0}.settings-subtext{color:var(--text-tertiary);margin:0}.settings-alert{background:#ff6b6b1f;border:1px solid #ff6b6b59;border-radius:12px;color:#ffb5b5;font-size:.9rem;max-width:260px;padding:.85rem 1rem}.settings-group-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.settings-group{display:flex;flex-direction:column;gap:.55rem}.settings-group label{color:var(--text-secondary);font-size:.95rem;font-weight:600;letter-spacing:.04em}.settings-group input,.settings-group select{background:var(--input-bg);border:1px solid var(--input-border);border-radius:12px;color:var(--text-primary);font-size:1rem;padding:.95rem 1rem;width:100%}.settings-group select option{color:#050817}.input-disabled{cursor:not-allowed;opacity:.7}.settings-group small{color:var(--text-muted);font-size:.85rem}.settings-card-divider{background:linear-gradient(90deg,#0000,var(--border-color),#0000);height:1px;margin:2rem 0}.settings-group :is(input,select):focus{border-color:#6f95ffcc;box-shadow:0 0 0 3px #6f95ff26;outline:none}.button-group{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.button-group button{flex:1 1;min-width:150px}.message{border-radius:12px;font-weight:600;margin-top:1.5rem;padding:.9rem 1rem;text-align:center}.message.success{background:#4caf5026;border:1px solid #4caf5066;color:#b1ffb5}.message.error,.message.warning{background:#ff6b6b26;border:1px solid #ff6b6b66;color:#ffc4c4}@media (max-width:768px){.settings-page{padding:2rem 1rem 3rem}.settings-card,.settings-hero-card{padding:1.75rem}.settings-form-header{flex-direction:column}.settings-alert{max-width:100%}}body,html{height:100%;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--gradient-bg);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root,body{min-height:100vh}#root{display:flex;flex-direction:column;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{padding:0 20px}.text-center{text-align:center}.mt-1{margin-top:10px}.mt-2{margin-top:20px}.mt-3{margin-top:30px}.mb-1{margin-bottom:10px}.mb-2{margin-bottom:20px}.mb-3{margin-bottom:30px}.p-1{padding:10px}.p-2{padding:20px}.p-3{padding:30px}.loading{align-items:center;display:flex;justify-content:center;min-height:200px}.error{background:#ffebee;border-left:4px solid #d32f2f;color:#d32f2f}.error,.success{border-radius:4px;margin:10px 0;padding:15px}.success{background:#e8f5e9;border-left:4px solid #388e3c;color:#388e3c}@media (max-width:768px){body{font-size:14px}.container{padding:0 15px}}:root{--bg-primary:#050817;--bg-secondary:#070b1c;--bg-tertiary:#1f2e63;--bg-card:#070b1ceb;--bg-card-hover:#ffffff0a;--bg-card-solid:#0c1021;--text-primary:#f5f7ff;--text-secondary:#ffffffc7;--text-tertiary:#ffffffa6;--text-muted:#ffffff8c;--border-color:#ffffff14;--border-color-hover:#ffffff26;--accent-primary:#4dd0e1;--accent-secondary:#7c4dff;--gradient-bg:radial-gradient(circle at 20% -10%,#1f2e63 0%,#070b1c 55%,#03040c 100%);--gradient-card:linear-gradient(160deg,#0c1021,#151d3d 55%,#1f2c56);--gradient-hero:linear-gradient(135deg,#1d2a5dd9,#0a0e28f2);--input-bg:#04071280;--input-border:#ffffff26;--shadow-card:0 35px 95px #020718a6}[data-theme=light]{--bg-primary:#f0f4f8;--bg-secondary:#fff;--bg-tertiary:#e2e8f0;--bg-card:#fffffff2;--bg-card-hover:#f8fafc;--bg-card-solid:#fff;--text-primary:#1a202c;--text-secondary:#4a5568;--text-tertiary:#718096;--text-muted:#a0aec0;--border-color:#00000014;--border-color-hover:#00000026;--accent-primary:#0077b6;--accent-secondary:#6200ea;--gradient-bg:linear-gradient(135deg,#f5f7fa,#c3cfe2);--gradient-card:linear-gradient(160deg,#fff,#f0f4f8);--gradient-hero:linear-gradient(135deg,#e0c3fc,#8ec5fc);--input-bg:#fff;--input-border:#cbd5e0;--shadow-card:0 10px 25px #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;color:#333;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.container{margin:0 auto;max-width:1200px;padding:20px}.button{border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:10px 20px;transition:background-color .3s ease}.button-primary{background-color:#007bff;color:#fff}.button-primary:hover{background-color:#0056b3}.button-secondary{background-color:#6c757d;color:#fff}.button-secondary:hover{background-color:#545b62}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.form-group{margin-bottom:15px}.form-group label{display:block;font-weight:500;margin-bottom:5px}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 12px;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.error{color:#dc3545}.error,.success{font-size:14px;margin-top:5px}.success{color:#28a745}.loading{color:#666;font-size:18px;padding:40px;text-align:center}.grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
/*# sourceMappingURL=main.82cee964.css.map*/