:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{min-width:320px;min-height:100vh;margin:0}#root{width:100%;min-height:100vh}.flashcard{perspective:1000px;cursor:pointer;touch-action:manipulation;width:100%;max-width:550px;height:clamp(280px,52vw,360px);margin:clamp(20px,3.5vw,25px) auto;position:relative}.flashcard-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.4,0,.2,1);position:relative}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{backface-visibility:hidden;box-sizing:border-box;border:1px solid #ffffff26;border-radius:clamp(14px,2.5vw,18px);flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:clamp(24px,4.5vw,35px);transition:all .3s;display:flex;position:absolute;overflow:hidden;box-shadow:0 10px 35px #0003,0 2px 8px #0000001a,inset 0 1px #fff3}.flashcard-front:before,.flashcard-back:before{content:"";pointer-events:none;opacity:.5;background:repeating-linear-gradient(0deg,#fff0 0,#ffffff05 1px,#fff0 2px);position:absolute;inset:0}.flashcard:hover .flashcard-front,.flashcard:hover .flashcard-back{box-shadow:0 15px 50px #00000040,0 5px 15px #00000026,inset 0 1px #ffffff4d}.flashcard-front{color:#fff;z-index:2;background:linear-gradient(145deg,#4a7ba7 0%,#5a8fc4 50%,#6ea8d4 100%)}.flashcard-back{color:#2c3e50;z-index:1;background:linear-gradient(145deg,#f39c12 0%,#f7b731 50%,#feca57 100%);transform:rotateY(180deg)}.flashcard.learned .flashcard-front{background:linear-gradient(145deg,#27ae60 0%,#2ecc71 50%,#58d68d 100%)}.flashcard.learned .flashcard-back{color:#0e3b20;background:linear-gradient(145deg,#2ecc71 0%,#58d68d 50%,#82e0aa 100%)}.flashcard h3{text-transform:uppercase;letter-spacing:clamp(1.5px,.4vw,2.5px);text-align:center;margin:0 0 clamp(12px,2.5vw,18px);padding-bottom:10px;font-size:clamp(1.05rem,2.5vw,1.4rem);font-weight:700;position:relative}.flashcard h3:after{content:"";background:#ffffff4d;border-radius:2px;width:60px;height:3px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.flashcard-back h3:after{background:#00000026}.flashcard p{text-align:center;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;flex-grow:1;justify-content:center;align-items:center;width:100%;max-height:68%;padding:0 clamp(8px,1.5vw,14px);font-size:clamp(1rem,2.3vw,1.2rem);font-weight:400;line-height:1.7;display:flex;overflow-y:auto}.flashcard p::-webkit-scrollbar{width:10px}.flashcard p::-webkit-scrollbar-track{background:#0000000d;border-radius:10px}.flashcard-front p::-webkit-scrollbar-thumb{background:#ffffff4d padding-box padding-box;border:2px solid #0000;border-radius:10px}.flashcard-front p::-webkit-scrollbar-thumb:hover{background:#fff6 padding-box padding-box}.flashcard-back p::-webkit-scrollbar-thumb{background:#00000026 padding-box padding-box;border:2px solid #0000;border-radius:10px}.flashcard-back p::-webkit-scrollbar-thumb:hover{background:#00000040 padding-box padding-box}@supports (scrollbar-color:auto){.flashcard-front p{scrollbar-width:thin;scrollbar-color:#ffffff4d #0000000d}.flashcard-back p{scrollbar-width:thin;scrollbar-color:#00000026 #0000000d}}.flip-hint{opacity:.85;background:#0000001a;border-radius:20px;margin-top:clamp(12px,2.5vw,16px);padding:6px 14px;font-size:clamp(.8rem,1.9vw,.95rem);font-style:italic;font-weight:500;animation:2.5s ease-in-out infinite pulse}.flashcard-back .flip-hint{background:#fff3}@keyframes pulse{0%,to{opacity:.85;transform:scale(1)}50%{opacity:.6;transform:scale(.98)}}.flashcard.flipped:active .flashcard-inner{transform:rotateY(180deg)}.flashcard:focus{outline:none}.flashcard:focus-visible{outline-offset:4px;border-radius:clamp(14px,2.5vw,18px);outline:3px solid #5a8fc4}@media (min-width:768px) and (max-width:1024px){.flashcard{max-width:600px;height:320px}}@media (max-width:768px){.flashcard{height:clamp(260px,58vw,300px);margin:18px auto}.flashcard-front,.flashcard-back{padding:22px 18px}.flashcard p{max-height:64%;font-size:1.05rem}.flip-hint{margin-top:12px;padding:5px 12px;font-size:.85rem}}@media (max-width:480px){.flashcard{max-width:100%;height:280px}.flashcard-front,.flashcard-back{border-radius:14px;padding:20px 15px}.flashcard h3{margin-bottom:14px;font-size:1.05rem}.flashcard p{font-size:1rem;line-height:1.6}.flip-hint{font-size:.8rem}}@media (max-height:500px) and (orientation:landscape){.flashcard{height:200px}.flashcard-front,.flashcard-back{padding:18px 22px}.flashcard h3{margin-bottom:10px;font-size:.95rem}.flashcard p{max-height:58%;font-size:.9rem}.flip-hint{margin-top:10px;padding:4px 10px;font-size:.75rem}}@media (min-width:1400px){.flashcard{max-width:650px;height:400px}}@media (prefers-reduced-motion:reduce){.flashcard-inner{transition:none}.flip-hint{opacity:.85;animation:none}.flashcard:active .flashcard-inner{transform:none}}@media (prefers-contrast:high){.flashcard-front,.flashcard-back{border:2px solid}.flashcard h3:after{background:currentColor}}@media (prefers-color-scheme:dark){.flashcard-front,.flashcard-back{box-shadow:0 10px 35px #00000080,0 2px 8px #0000004d,inset 0 1px #ffffff26}}.progress-counter{text-align:center;background:linear-gradient(145deg,#2c3e50 0%,#34495e 100%);border:2px solid #3498db;border-radius:clamp(12px,2vw,16px);min-width:clamp(220px,52vw,300px);margin:clamp(24px,4.5vw,35px) auto;padding:clamp(18px,3.5vw,24px);display:inline-block;position:relative;overflow:hidden;box-shadow:0 6px 20px #00000040,inset 0 1px #ffffff1a,0 1px 3px #00000026}.progress-counter:before{content:"";pointer-events:none;background:radial-gradient(circle,#3498db08 0%,#0000 70%);width:200%;height:200%;animation:20s linear infinite rotate;position:absolute;top:-50%;left:-50%}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.counter-label{color:#3498db;text-transform:uppercase;letter-spacing:clamp(2.5px,.6vw,3.5px);text-shadow:0 0 15px #3498db66;z-index:1;margin-bottom:clamp(10px,2vw,14px);font-size:clamp(.8rem,1.9vw,.95rem);font-weight:700;position:relative}.counter-display{color:#3498db;text-shadow:0 0 12px #3498db99,0 0 25px #3498db66,0 2px 4px #0003;letter-spacing:clamp(4px,1.2vw,6px);z-index:1;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(8px,2vw,14px);font-family:SF Mono,Monaco,Courier New,monospace;font-size:clamp(2.2rem,8.5vw,3.4rem);display:flex;position:relative}.digit-display{background:linear-gradient(145deg,#1a252f 0%,#0f1419 100%);border:2px solid #3498db4d;border-radius:clamp(8px,1.5vw,10px);min-width:clamp(50px,11vw,70px);padding:clamp(10px,2.5vw,14px) clamp(16px,3.5vw,24px);animation:3s ease-in-out infinite glow;display:inline-block;position:relative;box-shadow:inset 0 0 15px #3498db26,0 0 25px #3498db40,0 4px 8px #0000004d}.digit-display:before{content:"";pointer-events:none;background:linear-gradient(#3498db1a,#0000);border-radius:6px 6px 0 0;height:40%;position:absolute;top:2px;left:2px;right:2px}.separator{color:#3498db;text-shadow:0 0 12px #3498db99,0 2px 4px #0003;opacity:.9;margin:0 clamp(6px,1.5vw,12px);font-weight:700}@keyframes glow{0%,to{border-color:#3498db4d;box-shadow:inset 0 0 15px #3498db26,0 0 25px #3498db40,0 4px 8px #0000004d}50%{border-color:#3498db80;box-shadow:inset 0 0 20px #3498db40,0 0 35px #3498db59,0 4px 12px #0006}}.progress-percentage{color:#2ecc71;letter-spacing:1.5px;text-shadow:0 0 8px #2ecc7166;z-index:1;background:#2ecc711a;border:1px solid #2ecc7133;border-radius:20px;margin-top:clamp(12px,2.5vw,16px);padding:6px 16px;font-size:clamp(.75rem,1.8vw,.9rem);font-weight:700;display:inline-block;position:relative}@media (min-width:768px) and (max-width:1024px){.progress-counter{min-width:280px}.counter-display{font-size:2.8rem}}@media (max-width:768px){.progress-counter{width:92%;min-width:auto;max-width:320px;padding:18px}.counter-display{gap:10px;font-size:clamp(2rem,11vw,2.8rem)}.digit-display{min-width:52px;padding:10px 14px}.separator{margin:0 6px}}@media (max-width:480px){.progress-counter{width:88%;min-width:auto;padding:15px}.counter-label{letter-spacing:2.5px;margin-bottom:10px;font-size:.8rem}.counter-display{gap:8px;font-size:2.2rem}.digit-display{min-width:48px;padding:8px 12px;font-size:2rem}.separator{margin:0 5px}.progress-percentage{margin-top:10px;padding:5px 14px;font-size:.75rem}}@media (max-height:500px) and (orientation:landscape){.progress-counter{margin:18px auto;padding:12px}.counter-label{margin-bottom:8px;font-size:.75rem}.counter-display{font-size:2rem}.digit-display{padding:8px 14px}}@media (min-width:1400px){.progress-counter{min-width:340px;padding:28px}.counter-display{font-size:3.8rem}.digit-display{min-width:80px}}@media (prefers-reduced-motion:reduce){.digit-display,.progress-counter:before{animation:none}}@media (prefers-contrast:high){.progress-counter{background:#000;border:3px solid #3498db}.counter-label,.counter-display{text-shadow:none}.digit-display{background:#000;border-width:3px}.progress-percentage{background:#2ecc7133;border-width:2px}}@media (prefers-color-scheme:dark){.progress-counter{box-shadow:0 8px 25px #0006,inset 0 1px #ffffff14,0 1px 3px #0003}}*{box-sizing:border-box;margin:0;padding:0}body{color:#2c3e50;background:linear-gradient(135deg,#1e3a5f 0%,#2d5f7a 50%,#3a7ca5 100%);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(#5a7fa3 0%,#7ea5c6 100%) padding-box padding-box;border:2px solid #0000;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(#4a6f93 0%,#6e95b6 100%) padding-box padding-box}::-webkit-scrollbar-thumb:active{background:linear-gradient(#3a5f83 0%,#5e85a6 100%) padding-box padding-box}@supports (scrollbar-color:auto){*{scrollbar-width:thin;scrollbar-color:#7ea5c6 #ffffff0d}}.app{max-width:1200px;min-height:100vh;margin:0 auto;padding:clamp(15px,3vw,30px)}header{text-align:center;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:1px solid #ffffff1a;border-radius:20px;margin-bottom:clamp(25px,4vw,40px);padding:clamp(20px,4vw,30px);box-shadow:0 8px 32px #0000001a}header h1{text-shadow:2px 2px 8px #0000004d;letter-spacing:-.5px;background:linear-gradient(135deg,#fff 0%,#e0f2ff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:clamp(2rem,6vw,3.8rem);font-weight:700}header p{opacity:.95;color:#d4e6f1;letter-spacing:.3px;font-size:clamp(.9rem,2.5vw,1.25rem);font-weight:400}.api-banner{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid;border-radius:12px;max-width:800px;margin:0 auto clamp(16px,3vw,20px);padding:14px 20px;font-size:clamp(.85rem,2vw,.95rem);font-weight:500;box-shadow:0 4px 12px #0000001a}.api-banner.error{color:#c62828;background:#ffececf2;border-color:#c628284d}.api-banner.success{color:#2e7d32;background:#e8f5e9f2;border-color:#2e7d324d}.input-section{background:linear-gradient(145deg,#fff 0%,#f8fbff 100%);border:1px solid #fff9;border-radius:clamp(16px,2vw,20px);max-width:850px;margin:0 auto;padding:clamp(25px,5vw,45px);position:relative;overflow:hidden;box-shadow:0 10px 40px #00000026,0 1px 3px #0000001a,inset 0 1px #ffffffe6}.input-section:before{content:"";background:linear-gradient(90deg,#5a8fc4 0%,#7eb8d9 50%,#5a8fc4 100%);border-radius:20px 20px 0 0;height:4px;position:absolute;top:0;left:0;right:0}textarea{resize:vertical;color:#2c3e50;background:#fff;border:2px solid #d1e3f0;border-radius:clamp(10px,1.5vw,14px);width:100%;min-height:clamp(160px,32vh,220px);max-height:450px;margin-bottom:22px;padding:clamp(14px,2.5vw,18px);font-family:inherit;font-size:clamp(.95rem,2vw,1.05rem);line-height:1.6;transition:all .3s}textarea:focus{background:#fcfdff;border-color:#5a8fc4;outline:none;box-shadow:0 0 0 4px #5a8fc41a,0 2px 8px #5a8fc426}textarea::placeholder{color:#95a5a6;font-style:italic}.file-upload{text-align:center;margin:clamp(18px,3vw,24px) 0}.file-label{cursor:pointer;color:#34495e;background:linear-gradient(135deg,#f0f7ff 0%,#e3f2fd 100%);border:2px dashed #7ea5c6;border-radius:clamp(10px,1.5vw,12px);padding:clamp(12px,2vw,14px) clamp(24px,4vw,30px);font-size:clamp(.9rem,2vw,1.05rem);font-weight:500;transition:all .3s;display:inline-block;position:relative;overflow:hidden}.file-label:before{content:"";background:linear-gradient(90deg,#0000,#fff9,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.file-label:hover{background:linear-gradient(135deg,#e3f2fd 0%,#d1e9ff 100%);border-color:#5a8fc4;transform:translateY(-2px);box-shadow:0 4px 12px #5a8fc433}.file-label:hover:before{left:100%}.file-label:active{transform:translateY(0)}.file-name{color:#5a8fc4;margin-top:12px;font-size:clamp(.85rem,1.8vw,.95rem);font-style:italic;font-weight:500}.generate-btn{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#5a8fc4 0%,#7eb8d9 100%);border:none;border-radius:clamp(10px,1.5vw,14px);width:100%;padding:clamp(16px,3vw,20px);font-size:clamp(1.05rem,2.5vw,1.25rem);font-weight:600;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 4px 12px #5a8fc44d,0 1px 3px #0000001a}.generate-btn:before{content:"";background:#fff3;border-radius:50%;width:0;height:0;transition:width .6s,height .6s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.generate-btn:hover:not(:disabled):before{width:300px;height:300px}.generate-btn:hover:not(:disabled){background:linear-gradient(135deg,#4a7fb4 0%,#6ea8c9 100%);transform:translateY(-2px);box-shadow:0 6px 20px #5a8fc466,0 2px 6px #00000026}.generate-btn:active:not(:disabled){transform:translateY(0)}.generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner{vertical-align:middle;border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;margin-right:10px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.flashcard-section{text-align:center;max-width:700px;margin:0 auto;padding:0 clamp(10px,2vw,20px)}.controls{flex-wrap:wrap;justify-content:center;gap:clamp(10px,2vw,14px);margin:clamp(25px,4vw,35px) 0;display:flex}.controls button{cursor:pointer;color:#34495e;background:linear-gradient(135deg,#fff 0%,#f8fbff 100%);border:1px solid #5a8fc433;border-radius:clamp(10px,1.5vw,12px);flex:auto;min-width:clamp(110px,28vw,140px);max-width:220px;padding:clamp(12px,2vw,15px) clamp(20px,3vw,28px);font-size:clamp(.9rem,2vw,1.05rem);font-weight:600;transition:all .3s;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6}.controls button:hover:not(:disabled){background:linear-gradient(135deg,#f8fbff 0%,#e8f4ff 100%);transform:translateY(-2px);box-shadow:0 4px 16px #5a8fc440,inset 0 1px #ffffffe6}.controls button:active:not(:disabled){transform:translateY(0)}.controls button:disabled{opacity:.4;cursor:not-allowed;transform:none}.learned-btn{color:#fff!important;background:linear-gradient(135deg,#4caf50 0%,#66bb6a 100%)!important;border-color:#4caf504d!important}.learned-btn:hover:not(:disabled){background:linear-gradient(135deg,#43a047 0%,#5cb860 100%)!important;box-shadow:0 4px 16px #4caf5059,inset 0 1px #fff3!important}.card-indicator{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1f;border:1px solid #ffffff26;border-radius:30px;margin:clamp(18px,3vw,24px) 0;padding:12px 24px;font-size:clamp(.95rem,2vw,1.15rem);font-weight:500;display:inline-block}.reset-btn,.download-btn{cursor:pointer;border:1px solid #fff3;border-radius:clamp(10px,1.5vw,12px);min-width:clamp(140px,32vw,170px);margin-top:clamp(12px,2vw,16px);margin-left:clamp(6px,1vw,10px);margin-right:clamp(6px,1vw,10px);padding:clamp(12px,2vw,15px) clamp(28px,4vw,36px);font-size:clamp(.95rem,2vw,1.05rem);font-weight:600;transition:all .3s;display:inline-block;box-shadow:0 3px 10px #00000026}.reset-btn{color:#fff;background:linear-gradient(135deg,#e74c3c 0%,#f06a5a 100%)}.reset-btn:hover{background:linear-gradient(135deg,#d73c2c 0%,#e05a4a 100%);transform:translateY(-2px);box-shadow:0 5px 18px #e74c3c59}.download-btn{color:#fff;background:linear-gradient(135deg,#4caf50 0%,#66bb6a 100%)}.download-btn:hover{background:linear-gradient(135deg,#43a047 0%,#5cb860 100%);transform:translateY(-2px);box-shadow:0 5px 18px #4caf5059}.error-message{color:#c62828;background:linear-gradient(135deg,#ffebee 0%,#ffcdd2 100%);border:1px solid #ef9a9a;border-radius:12px;margin:16px 0;padding:16px 20px;font-size:clamp(.9rem,2vw,1rem);font-weight:500;box-shadow:0 2px 8px #c628281a}.success-message{color:#2e7d32;background:linear-gradient(135deg,#e8f5e9 0%,#c8e6c9 100%);border:1px solid #81c784;border-radius:12px;margin:16px 0;padding:16px 20px;font-size:clamp(.9rem,2vw,1rem);font-weight:500;box-shadow:0 2px 8px #2e7d321a}@media (min-width:768px) and (max-width:1024px){.controls{max-width:90%;margin-left:auto;margin-right:auto}.controls button{flex:calc(33.333% - 10px);max-width:none}}@media (max-width:768px){.app{padding:15px}header{margin-bottom:25px;padding:20px}.input-section{padding:22px 18px}.controls{flex-direction:column;gap:12px}.controls button{width:100%;min-width:auto;max-width:none}.reset-btn,.download-btn{width:calc(100% - 24px);max-width:none;margin:12px auto;display:block}textarea{font-size:16px}}@media (max-width:480px){.input-section{border-radius:14px;padding:18px 15px}}@media (max-height:500px) and (orientation:landscape){header h1{margin-bottom:6px}.input-section{padding:18px}textarea{min-height:140px}}@media (min-width:1400px){.app{max-width:1400px}.input-section{max-width:950px}.flashcard-section{max-width:750px}}:focus-visible{outline-offset:2px;border-radius:4px;outline:3px solid #5a8fc4}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (prefers-contrast:high){.input-section{border:2px solid #2c3e50}.generate-btn,.controls button{border:2px solid}}@media print{body{background:#fff}.generate-btn,.controls,.reset-btn,.download-btn,.file-upload{display:none}.input-section,.flashcard-section{box-shadow:none;border:1px solid #ddd}}
