*,:before,:after{box-sizing:border-box}:root{--sans:"Noto Sans", system-ui, sans-serif;--sinhala:"Noto Sans Sinhala", "Noto Sans", sans-serif;font-family:var(--sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}body{background:linear-gradient(160deg,#0a0010 0%,#0f0520 40%,#160830 70%,#1a0a18 100%) fixed;min-height:100dvh;margin:0;padding:0}#root{min-height:100svh}.emoji-bg{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.float-emoji{opacity:.12;-webkit-user-select:none;user-select:none;will-change:transform, opacity;animation:linear infinite floatUp;position:absolute;bottom:-2em}@keyframes floatUp{0%{opacity:0;transform:translateY(0)rotate(0)}10%{opacity:.35}90%{opacity:.35}to{opacity:0;transform:translateY(-105dvh)rotate(360deg)}}.app{box-sizing:border-box;justify-content:center;align-items:center;min-height:100svh;padding:24px 16px;display:flex;position:relative}.container{z-index:1;-webkit-backdrop-filter:blur(18px);text-align:center;background:#ffffff12;border:1px solid #ffffff26;border-radius:28px;flex-direction:column;align-items:center;gap:28px;width:100%;max-width:520px;padding:40px 36px 44px;display:flex;position:relative;box-shadow:0 24px 60px #0000008c}header{flex-direction:column;align-items:center;gap:8px;display:flex}h1{letter-spacing:-1px;margin:0;font-size:clamp(2.4rem,8vw,3.8rem);font-weight:900;line-height:1.1}.title-sinhala{background:linear-gradient(90deg,#c084c8,#a06ab0);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Noto Sans Sinhala,Noto Sans,sans-serif}.title-latin{background:linear-gradient(90deg,#e0d0f0,#b0c4de);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.subtitle{color:#ffffffa6;margin:0;font-size:1rem}.toggle-row{flex-direction:column;align-items:center;gap:12px;display:flex}.toggle{cursor:pointer;flex-shrink:0;width:52px;height:28px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.slider{background:#fff3;border-radius:28px;transition:background .3s;position:absolute;inset:0}.slider:before{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .3s;position:absolute;top:4px;left:4px}.toggle input:checked+.slider{background:linear-gradient(90deg,#7b2fa0,#5a1a80)}.toggle input:checked+.slider:before{transform:translate(24px)}.toggle-label{color:#ffffffd9;font-size:1rem;font-weight:600}.roll-btn{color:#f0eaf8;cursor:pointer;letter-spacing:.5px;background:linear-gradient(135deg,#3d1a6e,#6b2fa0,#8b3a8a);border:1px solid #c8a0ff33;border-radius:50px;align-items:center;gap:10px;padding:14px 36px;font-family:Noto Sans,sans-serif;font-size:1.15rem;font-weight:800;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 6px 28px #6428a073}.roll-btn:hover:not(:disabled){transform:translateY(-3px)scale(1.04);box-shadow:0 10px 36px #7832b48c}.roll-btn:active:not(:disabled){transform:translateY(0)scale(.97)}.roll-btn:disabled{opacity:.55;cursor:not-allowed}.roll-btn.rolling .dice-icon{animation:.4s linear infinite spinDice;display:inline-block}@keyframes spinDice{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.result-card{background:linear-gradient(135deg,#ff69b42e,#5000c840);border:1px solid #fff3;border-radius:20px;flex-direction:column;align-items:center;gap:12px;width:100%;padding:28px 24px;animation:.35s cubic-bezier(.34,1.56,.64,1) popIn;display:flex}@keyframes popIn{0%{opacity:0;transform:scale(.75)}to{opacity:1;transform:scale(1)}}.result-label{color:#ffffffa6;margin:0;font-family:Noto Sans Sinhala,Noto Sans,sans-serif;font-size:.9rem}.result-sinhala{background:linear-gradient(90deg,#d4a8f0,#e8c8ff,#b8a0d8);-webkit-text-fill-color:transparent;letter-spacing:1px;word-spacing:-8px;-webkit-background-clip:text;background-clip:text;font-family:Noto Sans Sinhala,Noto Sans,sans-serif;font-size:clamp(2rem,7vw,3rem);font-weight:900}.result-english{color:#ffffffb3;letter-spacing:.5px;font-family:Noto Sans,sans-serif;font-size:1.1rem;font-style:italic}.result-example{border-top:1px solid #ffffff1a;flex-direction:column;gap:4px;width:100%;margin-top:8px;padding-top:14px;display:flex}.result-example-si{color:#dcc8ffd9;font-family:Noto Sans Sinhala,Noto Sans,sans-serif;font-size:1rem;line-height:1.5}.result-example-en{color:#fff6;font-family:Noto Sans,sans-serif;font-size:.85rem;font-style:italic}.result-row{justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.copy-btn{color:#fff6;cursor:pointer;background:#ffffff12;border:1px solid #ffffff1f;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:.85rem;line-height:1;transition:background .15s,color .15s,border-color .15s;display:flex}.copy-btn:hover{color:#fffc;background:#ffffff21;border-color:#ffffff38}.copy-btn.copied{color:#86efac;background:#86efac26;border-color:#86efac4d}.placeholder{color:#fff6;padding:16px 0 4px;font-size:.95rem}@media (width<=460px){.container{border-radius:20px;gap:22px;padding:28px 20px 32px}.roll-btn{padding:12px 28px;font-size:1rem}}.contribute-btn{color:#ffffff8c;cursor:pointer;letter-spacing:.3px;background:#ffffff12;border:1px solid #ffffff26;border-radius:20px;align-self:flex-end;padding:5px 12px;font-family:Noto Sans,sans-serif;font-size:.78rem;font-weight:600;transition:background .2s,color .2s,border-color .2s}.contribute-btn:hover{color:#ffffffd9;background:#ffffff1f;border-color:#ffffff40}.wtf-footer{justify-content:center;margin-top:28px;display:flex}.wtf-btn{color:#ffffff80;cursor:pointer;letter-spacing:.3px;background:0 0;border:none;padding:4px 8px;font-family:Noto Sans,sans-serif;font-size:.8rem;transition:color .2s}.wtf-btn:hover{color:#ffffff8c}.wtf-modal{text-align:center;padding:36px 28px 28px}.wtf-line{color:#fff9;margin:0 0 14px;font-size:.88rem;line-height:1.6}.wtf-heading{color:#fff;font-size:1rem;line-height:1.6}.wtf-line:last-child{margin-bottom:0}.wtf-line a{color:#b48cffe6;border-bottom:1px solid #b48cff59;text-decoration:none;transition:color .2s,border-color .2s}.wtf-line a:hover{color:#d2b4ff;border-color:#d2b4ff99}.modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:100;background:#000000b8;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:#130826;border:1px solid #ffffff1f;border-radius:24px;flex-direction:column;gap:16px;width:100%;max-width:460px;padding:36px 32px 40px;animation:.25s cubic-bezier(.34,1.56,.64,1) popIn;display:flex;position:relative;box-shadow:0 32px 80px #000000b3}.modal-close{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:1rem;transition:color .15s,background .15s;position:absolute;top:14px;right:16px}.modal-close:hover{color:#ffffffd9;background:#ffffff14}.modal-title{color:#e0d0f0;margin:0;font-family:Noto Sans,sans-serif;font-size:1.4rem;font-weight:800}.modal-subtitle{color:#ffffff73;margin:-8px 0 0;font-size:.88rem}.modal-tabs{background:#ffffff0d;border-radius:12px;gap:6px;padding:4px;display:flex}.modal-tab{cursor:pointer;color:#ffffff73;background:0 0;border:none;border-radius:9px;flex:1;padding:8px 12px;font-family:Noto Sans,sans-serif;font-size:.85rem;font-weight:600;transition:background .2s,color .2s}.modal-tab.active{color:#e8d8f8;background:#a06ab059}.modal-form{flex-direction:column;gap:14px;display:flex}.modal-row{gap:12px;display:flex}.modal-row .modal-field{flex:1}.modal-field{flex-direction:column;gap:6px;display:flex}.modal-field label{color:#ffffff80;text-transform:uppercase;letter-spacing:.6px;font-size:.78rem;font-weight:700}.modal-field input{color:#f0eaf8;box-sizing:border-box;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-family:Noto Sans,sans-serif;font-size:.95rem;transition:border-color .2s}.modal-field input.sinhala-input{font-family:Noto Sans Sinhala,Noto Sans,sans-serif}.modal-field input::placeholder{color:#ffffff40}.modal-field input:focus{border-color:#a06ab099}.modal-hint{color:#ffffff4d;font-size:.75rem}.modal-hint code{color:#c8a0ffb3;background:#ffffff14;border-radius:4px;padding:1px 5px;font-family:monospace}.suggestions{background:#1c0d32;border:1px solid #ffffff1a;border-radius:10px;margin:2px 0 0;padding:4px 0;list-style:none;overflow:hidden}.suggestions li{color:#ffffff73;border-bottom:1px solid #ffffff0d;align-items:center;gap:6px;padding:7px 12px;font-size:.8rem;display:flex}.suggestions li:last-child{border-bottom:none}.suggestions li strong{color:#dcbeffcc;font-weight:600}.suggestions-si{color:#c8a0ff80;margin-left:auto;font-family:Noto Sans Sinhala,Noto Sans,sans-serif;font-size:.78rem}.seg-control{background:#ffffff0d;border-radius:8px;gap:3px;padding:3px;display:flex}.seg-control button{cursor:pointer;color:#fff6;background:0 0;border:none;border-radius:6px;flex:1;padding:6px 8px;font-family:Noto Sans,sans-serif;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.seg-control button.active{color:#f0eaf8;background:#a06ab066}.modal-submit{color:#f0eaf8;cursor:pointer;background:linear-gradient(135deg,#3d1a6e,#6b2fa0,#8b3a8a);border:1px solid #c8a0ff33;border-radius:12px;margin-top:4px;padding:12px;font-family:Noto Sans,sans-serif;font-size:.95rem;font-weight:700;transition:opacity .2s,transform .15s}.modal-submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.modal-submit:disabled{opacity:.45;cursor:not-allowed}.modal-warning{color:#f0b83a;background:#f0b83a1a;border:1px solid #f0b83a33;border-radius:8px;padding:8px 12px;font-size:.82rem}.modal-error{color:#f87171;background:#f871711a;border:1px solid #f8717133;border-radius:8px;padding:8px 12px;font-size:.82rem}.modal-success{color:#86efac;text-align:center;background:#86efac1a;border:1px solid #86efac33;border-radius:12px;padding:20px 16px;font-size:.95rem;font-weight:600}@media (width<=460px){.modal{border-radius:18px;padding:28px 20px 32px}.modal-row{flex-direction:column}}
