:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--rsvp-center-color: #ff3b30}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:linear-gradient(135deg,#0d0d1a,#1a1a2e,#0f0f23);color:#ffffffe6}#app{max-width:1200px;margin:0 auto;padding:2rem;text-align:center;width:100%}.container{display:flex;flex-direction:column;align-items:center;gap:2rem;background:linear-gradient(145deg,#28283c99,#191928cc);padding:2.5rem;border-radius:24px;box-shadow:0 25px 80px #0006,inset 0 1px #ffffff0d;width:95%;max-width:900px;box-sizing:border-box;border:1px solid rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}h1{font-size:2.5rem;line-height:1.1;margin:0;background:linear-gradient(135deg,#fff,#a0a0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.nav-link{color:#646cff;text-decoration:none;font-size:1.1rem;margin-bottom:1rem;display:inline-block;padding:.5rem 1rem;border:1px solid #646cff;border-radius:8px;transition:all .3s}.nav-link:hover{background-color:#646cff;color:#fff}.shape-box{width:90%;height:60vh;background-color:#fff;display:flex;align-items:center;justify-content:center;border-radius:1rem;overflow:hidden}#shape-canvas{max-width:100%;max-height:100%}.controls{display:flex;align-items:center;gap:1rem;font-size:1.2rem;width:100%;justify-content:center}.controls input[type=range]{cursor:pointer;width:300px;max-width:100%}.hint{color:#888;font-size:.9rem;margin-top:-1rem;margin-bottom:.5rem}.color-box{width:90%;height:60vh;background-color:#fff;border-radius:1rem;box-shadow:0 4px 15px #0003;transition:background-color .3s ease;border:4px solid rgba(255,255,255,.1);outline:none}.color-box:focus,.shape-box:focus{outline:none;border-color:#ffffff80;box-shadow:0 0 15px #ffffff4d}.main-buttons{display:flex;gap:1rem}.session-wrapper{width:100%;display:flex;justify-content:center;align-items:flex-start;margin-top:1rem;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.session-controls{padding:.5rem 1rem;background:#ffffff1a;border-radius:12px;width:auto;min-width:180px;box-sizing:border-box;font-size:.9rem;display:flex;flex-direction:column;gap:.5rem;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1)}.session-controls button{padding:.4em .8em;font-size:.9em;width:100%}.session-stats{display:flex;justify-content:space-between;margin-top:0;font-size:.9rem;font-weight:400;color:#eee}.session-history{font-size:.8rem;color:#aaa;max-height:80px;overflow-y:auto;width:200px}.history-item{margin-bottom:.2rem;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:.1rem}.instructions{margin-top:1.5rem;text-align:left;width:100%;background:#ffffff0d;padding:1rem;border-radius:.5rem;box-sizing:border-box}.instructions h3{margin-top:0;margin-bottom:.5rem;font-size:1.1rem;color:#aaa}.instructions ul{margin:0;padding-left:1.2rem;font-size:.95rem;line-height:1.6}.settings{margin-top:2rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1);width:100%;text-align:left}.settings h3{font-size:1.2rem;margin-bottom:1rem}.config-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.color-config-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.color-config-item{display:flex;align-items:center;gap:.5rem;background:#ffffff0d;padding:.5rem;border-radius:.5rem}.color-config-item input[type=color]{width:40px;height:40px;border:none;border-radius:4px;cursor:pointer;background:none}.color-config-item input[type=text]{background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.3rem .5rem;border-radius:4px;width:100%}.radio-group{display:flex;flex-direction:column;gap:.8rem}.radio-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.radio-group input[type=radio]{accent-color:#646cff;width:1.2em;height:1.2em}.color-code{display:flex;align-items:center;gap:1rem;background:#1a1a1a;padding:.5rem 1rem;border-radius:.5rem;font-family:monospace;font-size:1.5rem}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#646cff;color:#fff;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff;background-color:#535bf2}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}#copy-btn{padding:.4em;background-color:transparent;font-size:1.2rem}#copy-btn:hover{background-color:#ffffff1a;border-color:transparent}.stroop-grid{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;width:100%;margin-top:2rem;max-width:1200px}.stroop-word{font-weight:700;-webkit-user-select:none;user-select:none;padding:.5rem;white-space:nowrap}.stroop-settings{margin:1rem 0;text-align:center;width:100%}.checkbox-group{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;padding:1rem;background:#ffffff0d;border-radius:8px;margin-top:.5rem}.checkbox-group label{display:flex;align-items:center;gap:.3rem;cursor:pointer;-webkit-user-select:none;user-select:none}.stroop-container{max-width:90%;display:flex;flex-direction:column;align-items:center}.reader-display{position:relative;font-size:clamp(3rem,8vw,6rem);font-weight:700;height:45vh;min-height:280px;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#1a1a2e,#16213e,#0f0f23);border-radius:20px;margin-bottom:2rem;overflow:hidden;box-shadow:0 20px 60px #00000080,inset 0 1px #ffffff0d,inset 0 -1px #0000004d;border:1px solid rgba(255,255,255,.05);transition:all .3s ease}.reader-display:fullscreen{border-radius:0;height:100vh;font-size:clamp(4rem,12vw,10rem)}.reader-fs-btn{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:10px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:#fff9;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.reader-fs-btn:hover{background:#ffffff26;color:#fff;transform:scale(1.05)}.reader-controls{display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%;margin-top:1rem}.control-group,.speed-control{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:400px}.settings-panel{position:fixed;bottom:2rem;right:2rem;left:auto;width:auto;min-width:220px;max-width:280px;background:linear-gradient(135deg,#191923fa,#0f0f19fa);padding:0;border-radius:16px;display:flex;flex-direction:column;gap:0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 32px #0006,inset 0 1px #ffffff0d;z-index:1000;overflow:hidden;cursor:default}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.05);cursor:grab;-webkit-user-select:none;user-select:none}.panel-header:active{cursor:grabbing}.panel-header h3{margin:0;font-size:.9rem;font-weight:600;color:#fff;letter-spacing:.5px}.drag-hint{font-size:.65rem;color:#ffffff4d;text-transform:uppercase;letter-spacing:1px}.settings-panel .setting-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;border-bottom:1px solid rgba(255,255,255,.03)}.settings-panel .setting-row:last-child{border-bottom:none}.settings-panel .setting-row label{font-size:.85rem;color:#ffffffb3;font-weight:400}.panel-divider{border:none;border-top:1px solid rgba(255,255,255,.08);margin:.3rem 0}input[type=color]{border:none;width:32px;height:32px;border-radius:50%;overflow:hidden;cursor:pointer;background:none;padding:0;transition:transform .2s ease}input[type=color]:hover{transform:scale(1.1)}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:2px solid rgba(255,255,255,.15);border-radius:50%}input[type=number]{background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;padding:.3rem .5rem;font-size:.85rem;text-align:center}input[type=number]:focus{outline:none;border-color:#646cff80;box-shadow:0 0 0 2px #646cff33}input[type=checkbox]{width:18px;height:18px;accent-color:#646cff;cursor:pointer}.hint-text{font-size:.8rem;color:#666;margin-left:.5rem}.theme-toggles label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.reader-display.theme-dark{background:#1a1a1a;color:#ffffffde}.reader-display.theme-light{background:#fff;color:#000}.reader-display.theme-grey{background:#d3d3d3;color:#1a1a1a}.reader-actions{display:flex;gap:1rem}.textarea-label{display:block;text-align:left;font-size:.9rem;color:#fff9;margin-bottom:.5rem;font-weight:400}#text-input{width:100%;max-width:800px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;padding:1rem;font-family:inherit;resize:vertical}.progress-container{width:100%;max-width:600px;margin-top:1rem;text-align:center}.progress-bar-bg{width:100%;height:6px;background:#ffffff1a;border-radius:3px;margin-top:.5rem;overflow:hidden}.progress-bar-fill{height:100%;background:#646cff;transition:width .1s linear}#progress-text{font-size:.9rem;color:#888}#word-display{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.rsvp-left{flex:1 1 0%;text-align:right;white-space:nowrap}.rsvp-center{color:var(--rsvp-center-color);flex:0 0 auto;text-align:center}.rsvp-right{flex:1 1 0%;text-align:left;white-space:nowrap}.multi-word-display{display:flex;align-items:center;justify-content:center;gap:.3em;width:100%;height:100%;flex-wrap:nowrap}.word-group{display:inline;white-space:nowrap}.rsvp-text{color:inherit}.rsvp-center-inline{color:var(--rsvp-center-color)}@media (max-width: 768px){body{place-items:start}#app{padding:1rem}.container{padding:1.5rem 1rem;border-radius:16px;gap:1rem}h1{font-size:1.8rem}.nav-links{flex-direction:column;gap:.5rem}.reader-display{height:35vh;min-height:200px;font-size:2.5rem;border-radius:12px}.reader-fs-btn{width:36px;height:36px;font-size:1rem}.reader-actions{display:flex;flex-direction:row;gap:.5rem;width:100%;margin-bottom:1rem}.reader-actions button{flex:1;padding:.8rem .5rem;font-size:.9rem}#fullscreen-btn{display:none}.reader-controls{gap:1rem;width:100%}#text-input{font-size:16px;width:100%;margin-bottom:1rem}.controls{flex-direction:column;padding-bottom:80px;width:100%}.settings-panel{position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;min-width:100%;border-radius:16px 16px 0 0;padding-bottom:env(safe-area-inset-bottom,0);max-height:60px;overflow:hidden;transition:max-height .3s ease-out}.settings-panel.expanded{max-height:50vh;overflow-y:auto}.panel-header{position:sticky;top:0;background:linear-gradient(135deg,#191923fa,#0f0f19fa);cursor:pointer;justify-content:center;padding:1rem}.panel-header h3{font-size:1.1rem;text-align:center}.panel-header:after{content:"▲";font-size:.8rem;color:#fff9;margin-left:.5rem;transition:transform .3s ease}.settings-panel.expanded .panel-header:after{transform:rotate(180deg)}.drag-hint{display:none}.settings-panel .setting-row{padding:.8rem 1rem}}.header-text{margin-bottom:2rem}.header-text h1{font-size:3rem;margin-bottom:.2rem;line-height:1.2;background:linear-gradient(135deg,#fff,#a0a0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{font-size:1.5rem;color:#a0a0ff;margin:.5rem 0 .2rem;font-weight:600}.tagline-sub{font-size:1.1rem;color:#ffffffb3;margin:0;font-weight:300}@media (max-width: 768px){.header-text{margin-bottom:1.5rem}.header-text h1{font-size:2rem}.tagline{font-size:1.1rem}.tagline-sub{font-size:.95rem}}.menu-btn{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-weight:500;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all .3s ease;z-index:100}.menu-btn:hover{background:#fff3;transform:translateY(-2px)}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:2000;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.modal-overlay.active{display:flex;opacity:1}.modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.1);padding:2rem;border-radius:20px;width:90%;max-width:500px;position:relative;box-shadow:0 25px 50px -12px #00000080;transform:scale(.9);transition:transform .3s ease;max-height:80vh;overflow-y:auto}.modal-overlay.active .modal-content{transform:scale(1)}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#ffffff80;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#fff}.donate-message{line-height:1.6;margin-bottom:1.5rem;color:#ffffffe6}.secondary-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);width:100%;margin-bottom:1rem}.secondary-btn:hover{background:#fff3}.bank-details{background:#0000004d;padding:1rem;border-radius:10px;margin-top:1rem;border:1px solid rgba(255,255,255,.1)}.detail-row{display:flex;justify-content:space-between;margin-bottom:.8rem;font-size:.9rem;flex-wrap:wrap;gap:.5rem}.detail-row:last-child{margin-bottom:0}.detail-label{color:#fff9}.detail-value{color:#fff;font-family:monospace;text-align:right;word-break:break-all}
