body{font-family:'Inter',sans-serif;margin:0;background-color:#F0FFF0;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-x:hidden;box-sizing:border-box}.page-layout{display:grid;grid-template-columns:200px 1fr 300px;gap:20px;width:100%;max-width:1400px;flex-grow:1;overflow:hidden}.ad-space-left{background-color:#fff;border-radius:16px;padding:15px;display:flex;align-items:center;justify-content:center;font-size:.9rem;text-align:center;min-height:400px;box-shadow:0 10px 25px rgb(0 0 0 / .1)}.main-typing-area{background-color:#fff;border-radius:16px;box-shadow:0 10px 25px rgb(0 0 0 / .1);padding:20px;text-align:center;display:flex;flex-direction:column;gap:10px;width:100%;height:100%;overflow-y:auto}.test-controls-panel{background-color:#fff;border-radius:16px;box-shadow:0 10px 25px rgb(0 0 0 / .1);padding:25px;display:flex;flex-direction:column;gap:25px;align-items:stretch;justify-content:flex-start}.test-controls .control-group{display:flex;flex-direction:column;gap:18px}.test-controls label{text-align:left;font-weight:600;color:#334155}.test-controls select{width:100%;padding:10px;border:1px solid #D1D5DB;border-radius:8px;font-size:1rem;background-color:#f9fafb}#time-display-wrapper{background-color:#28a745;color:#fff;padding:12px 20px;border-radius:8px;font-size:1.2rem;font-weight:700;text-align:center;box-shadow:0 2px 5px rgb(0 0 0 / .2);margin:20px 0}.text-display{max-height:150px;font-family:'Noto Nastaliq Urdu',sans-serif;font-size:1.7rem;line-height:2;padding:15px;border:1px solid #e0e0e0;border-radius:12px;background-color:#f9f9f9;text-align:right;direction:rtl;min-height:150px;overflow-y:auto;overflow-x:hidden;flex-shrink:1;user-select:none}.text-display span{transition:background-color 0.1s ease}.correct{color:#10B981}.incorrect{color:#EF4444;background-color:#FEF2F2;border-radius:4px;padding:0 2px}.current{background-color:#DBEAFE;border-radius:40px;padding:0 8px}.input-field{resize:none;width:100%;height:20%;overflow-y:auto;padding:25px;font-size:1.5rem;border:2px solid #D1D5DB;border-radius:12px;outline:none;transition:border-color 0.2s ease-in-out,box-shadow 0.2s ease-in-out;text-align:right;direction:rtl;font-family:'Noto Nastaliq Urdu',sans-serif}.input-field:focus{border-color:#28a745;box-shadow:0 0 0 3px rgb(40 167 69 / .3)}.button{background-color:#28a745;color:#fff;padding:18px 35px;font-size:1.4rem;font-weight:700;border:none;border-radius:12px;margin-bottom:15px;cursor:pointer;transition:background-color 0.2s ease-in-out,transform 0.1s ease-in-out,box-shadow 0.2s ease-in-out;box-shadow:0 4px 10px rgb(40 167 69 / .2);width:100%}.button:hover{background-color:#218838;transform:translateY(-2px);box-shadow:0 6px 15px rgb(40 167 69 / .3)}.button:active{transform:translateY(0);box-shadow:0 2px 5px rgb(40 167 69 / .2)}.message-box{background-color:#fff;padding:30px;border-radius:16px;box-shadow:0 10px 30px rgb(0 0 0 / .2);z-index:1000;text-align:center;font-size:1.2rem;color:#333;max-width:90%;width:400px;position:fixed;top:40%;left:45% !important;transform:translate(-50%,-50%)}dialog::backdrop{background-color:rgb(0 0 0 / .7)}#results-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgb(0 0 0 / .7);z-index:1000;display:none;justify-content:center;align-items:center}#results-modal{background-color:#fff;border-radius:16px;box-shadow:0 15px 40px rgb(0 0 0 / .3);padding:40px;max-width:500px;width:90%;text-align:center;transform:scale(.9);opacity:0;transition:all 0.3s ease-out;display:flex;flex-direction:column;gap:25px}#results-modal.show{transform:scale(1);opacity:1}#results-modal h3{font-size:2.2rem;font-weight:700;color:#28a745;margin-bottom:15px}#results-modal .results-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;margin-top:10px;margin-bottom:20px}#results-modal .results-stat-item{background-color:#e6ffe6;padding:15px;border-radius:10px;font-size:1.1rem;font-weight:600;color:#28a745;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}#results-modal .results-stat-item span{font-size:2rem;font-weight:700;color:#218838}#results-modal-close{background-color:#28a745;color:#fff;padding:15px 30px;font-size:1.25rem;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:background-color 0.2s ease,transform 0.1s ease;width:100%}#results-modal-close:hover{background-color:#218838;transform:translateY(-2px)}#print-results-button{background-color:#28a745;color:#fff;padding:15px 30px;font-size:1.25rem;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:background-color 0.2s ease,transform 0.1s ease;margin-top:10px;width:100%}#print-results-button:hover{background-color:#218838;transform:translateY(-2px)}.keyboard-container{background-color:#1a1a1a;padding:6px;border-radius:10px;box-shadow:0 5px 15px rgb(255 255 255 / .1);display:flex;flex-direction:column;gap:2px;width:100%;flex-shrink:0}.keyboard-row{display:flex;justify-content:center;gap:2px;flex-wrap:nowrap}.key{background-color:#000;border:1px solid #333;border-radius:5px;padding:0;font-weight:600;color:#fff;min-width:38px;height:48px;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:default;user-select:none;box-shadow:inset 0 1px 2px rgb(255 255 255 / .05),0 1px 3px rgb(0 0 0 / .3);transition:all 0.1s ease-in-out;position:relative;flex-shrink:0;flex-basis:auto}.key-wide{flex-grow:1.5}.key-wide-lg{flex-grow:2}.key-space{flex-grow:5}.key-ctrl{flex-grow:1}#key-backspace{flex-grow:2.5}#key-tab{flex-grow:1.7}#key-capslock{flex-grow:2.2}#key-enter{flex-grow:2.8}#key-left-shift,#key-right-shift{flex-grow:2.5}.key.active{background-color:#28a745;color:#fff;box-shadow:0 0 0 2px rgb(40 167 69 / .5),0 2px 8px rgb(40 167 69 / .4);transform:translateY(-1px)}.key.active::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:6px;height:6px;background-color:#10B981;border-radius:50%;border:1px solid #fff;box-shadow:0 0 0 1px rgb(16 185 129 / .5)}.key-content{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;line-height:1}.key-english-char,.key-urdu-normal-char,.key-urdu-shift-char{position:absolute;font-size:.7rem;color:#fff;font-family:'Noto Nastaliq Urdu','Inter',sans-serif}.key-english-char{bottom:4px;left:4px;font-size:.6rem;opacity:.8}.key-urdu-normal-char{top:4px;right:4px;font-size:1.1rem}.key-urdu-shift-char{bottom:4px;right:4px;font-size:.9rem;opacity:.9}.key-single-char .key-content span{position:static;font-size:.8rem;opacity:1}.has-dotted-circle{position:relative}.has-dotted-circle::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border:1px dotted rgb(255 255 255 / .7);border-radius:50%;pointer-events:none;z-index:-1}@media print{body *{visibility:hidden}#results-modal-overlay,#results-modal-overlay *{visibility:visible}#results-modal-overlay{position:static;display:block;background-color:#fff0;box-shadow:none}#results-modal{position:static;transform:none;opacity:1;box-shadow:none;margin:0 auto;padding:20px;border:1px solid #ccc}#results-modal-close,#print-results-button{display:none}#results-modal h3{font-size:18pt;color:#000}#results-modal .results-stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}#results-modal .results-stat-item{font-size:10pt;background-color:#f0f0f0;color:#333;border:1px solid #ddd;padding:8px}#results-modal .results-stat-item span{font-size:16pt;color:#000}#results-modal p.print-info{font-size:10pt;color:#555;margin-top:10px;visibility:visible}}@media (max-width:1024px){.page-layout{grid-template-columns:1fr;grid-template-rows:auto auto 1fr}.test-controls-panel{order:-1;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:15px;background:#fff0;box-shadow:none;padding:0;margin-bottom:15px}.ad-space-left{order:0;width:100%;max-width:600px;margin:0 auto 15px auto}.main-typing-area{order:1}.test-controls .control-group{flex-direction:row;align-items:center}.test-controls .button{width:100%}#time-display-wrapper{padding:8px 15px}}@media (max-width:768px){.text-display{height:50%}.input-field{height:50%}body{padding:10px;flex-direction:column}.page-layout{gap:10px}.ad-space-left{min-height:100px}.keyboard-container{display:none}}