*,*:before,*:after{box-sizing:border-box}:root{--color-bg: #f4f5f7;--color-surface: #ffffff;--color-primary: #c0392b;--color-primary-hover: #a93226;--color-secondary: #2c3e50;--color-accent: #e74c3c;--color-text: #2c2c2c;--color-text-muted: #6b7280;--color-border: #e0e0e0;--color-success-bg: #d4edda;--color-success-text: #155724;--color-error-bg: #fdecea;--color-error-text: #c0392b;--radius: 8px;--shadow: 0 2px 10px rgba(0, 0, 0, .08);--font: "Segoe UI", system-ui, -apple-system, sans-serif;--color-input-bg: #fafafa;--color-input-bg-focus: #ffffff;--color-heading: #2c3e50}:root.dark{--color-bg: #121212;--color-surface: #1e1e1e;--color-secondary: #1a2535;--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-border: #2d3748;--color-success-bg: #1a3a2a;--color-success-text: #6ee7b7;--color-error-bg: #3a1a1a;--color-error-text: #fca5a5;--color-input-bg: #252525;--color-input-bg-focus: #2d2d2d;--color-shadow: 0 2px 10px rgba(0, 0, 0, .4);--color-heading: #f1f5f9}html{font-size:16px}body{margin:0;padding:0;background-color:var(--color-bg);color:var(--color-text);font-family:var(--font);line-height:1.5;min-width:300px}#root{min-height:100vh;display:flex;flex-direction:column}img,svg{max-width:100%}button{cursor:pointer;font-family:inherit}a{color:var(--color-primary)}.app{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;padding:1rem;width:100%;max-width:960px;margin:0 auto}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.1rem;color:var(--color-text-muted)}@media(min-width:600px){.app-main{padding:1.5rem 2rem}}.navbar{background-color:var(--color-secondary);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 6px #0003}.navbar-top{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem}.navbar-top-right{display:flex;align-items:center;gap:.5rem}.navbar-brand{color:#fff;text-decoration:none;font-size:1.15rem;font-weight:700;white-space:nowrap;letter-spacing:.01em}.navbar-burger{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;padding:.35rem;cursor:pointer;width:2rem;height:2rem}.navbar-burger span{display:block;height:2px;background:#ffffffd9;border-radius:2px;transition:transform .2s,opacity .2s;transform-origin:center}.navbar-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar-burger.open span:nth-child(2){opacity:0}.navbar-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar-links{display:none;flex-direction:column;padding:.5rem 1rem .75rem;gap:.25rem}.navbar-links.open{display:flex}.navbar-links a{color:#fffc;text-decoration:none;padding:.5rem .75rem;border-radius:var(--radius);font-size:.9rem;transition:background .15s,color .15s}.navbar-links a:hover,.navbar-links a.active{color:#fff;background:#ffffff26}.navbar-logout{background:transparent;border:none;color:#fffc;padding:.5rem .75rem;border-radius:var(--radius);font-size:.9rem;text-align:left;transition:background .15s,color .15s;margin-top:.25rem}.navbar-logout:hover{background:#ffffff26;color:#fff}.navbar-theme-toggle{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#ffffffd9;padding:.35rem .6rem;border-radius:var(--radius);font-size:.9rem;line-height:1;transition:background .15s}.navbar-theme-toggle:hover{background:#ffffff40}@media(min-width:640px){.navbar{display:flex;align-items:center;padding:.75rem 1.5rem;gap:.5rem}.navbar-top{display:contents}.navbar-burger{display:none}.navbar-links{display:flex!important;flex-direction:row;align-items:center;gap:.25rem;padding:0;flex:1;justify-content:flex-end;order:2}.navbar-top-right{order:3}.navbar-logout{margin-top:0;margin-left:.25rem;padding:.4rem .75rem;text-align:center}.navbar-links a{padding:.4rem .65rem}}.footer{background-color:var(--color-secondary);color:#ffffffbf;display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.75rem 1.5rem;font-size:.85rem;margin-top:auto;text-align:center}.footer-link,.footer-link-btn{color:#ffffffbf;text-decoration:none;background:none;border:none;font-size:.85rem;font-family:inherit;cursor:pointer;padding:0;transition:color .15s}.footer-link:hover,.footer-link-btn:hover{color:#fff;text-decoration:underline}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-box{background:var(--color-surface);border-radius:var(--radius);box-shadow:0 8px 32px #00000040;max-width:600px;width:100%;max-height:85vh;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0;gap:1rem}.modal-header h2{margin:0;font-size:1.2rem;color:var(--color-text)}.modal-close{background:none;border:none;font-size:1.1rem;color:var(--color-text-muted);cursor:pointer;padding:.25rem;line-height:1;transition:color .15s;flex-shrink:0}.modal-close:hover{color:var(--color-text)}.modal-body{padding:1rem 1.5rem 1.5rem;overflow-y:auto;color:var(--color-text);line-height:1.6}.modal-body h3{margin:1rem 0 .4rem;font-size:.95rem;color:var(--color-primary)}.modal-body h3:first-child{margin-top:0}.modal-body p{margin:0 0 .5rem;font-size:.9rem}.modal-body a{color:var(--color-primary)}.modal-body code{background:var(--color-bg);padding:.1em .35em;border-radius:3px;font-size:.85em}.form-success{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid #b8dfc4;border-radius:var(--radius);padding:.6rem .75rem;font-size:.9rem;margin:0 0 .5rem}.auth-page{display:flex;justify-content:center;padding:2rem 0}.auth-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem 1.5rem;width:100%;max-width:420px}.auth-card h1{margin:0 0 1.5rem;font-size:1.6rem;color:var(--color-heading)}.auth-form{display:flex;flex-direction:column;gap:.4rem}.auth-form label{font-weight:600;font-size:.9rem;margin-top:.5rem;color:var(--color-text)}.label-hint{font-weight:400;font-size:.8rem;color:var(--color-text-muted)}.auth-form input{padding:.65rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:1rem;color:var(--color-text);transition:border-color .15s,box-shadow .15s;background:var(--color-input-bg)}.auth-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #c0392b1f;background:var(--color-input-bg-focus)}.btn-primary{margin-top:1.25rem;padding:.75rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.form-error{background:var(--color-error-bg);color:var(--color-error-text);border:1px solid #f5c6c4;border-radius:var(--radius);padding:.6rem .75rem;font-size:.9rem;margin:0 0 .5rem}.auth-footer{margin-top:1.5rem;text-align:center;font-size:.9rem;color:var(--color-text-muted)}.auth-footer a{color:var(--color-primary);text-decoration:none;font-weight:600}.activation-info{background:var(--color-success-bg);border:1px solid #a5d6a7;border-radius:var(--radius);padding:.75rem 1rem;color:var(--color-success-text);font-size:.95rem;line-height:1.5;margin-bottom:1.25rem}@media(min-width:480px){.auth-card{padding:2.5rem 2rem}}.dashboard h1{margin:0 0 1.25rem;font-size:1.6rem;color:var(--color-heading)}.dashboard h2{font-size:1.1rem;color:var(--color-heading);margin:0 0 .75rem}.info-banner{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.info-item{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:.85rem 1.1rem;flex:1 1 100px;display:flex;flex-direction:column;gap:.2rem}.info-label{font-size:.8rem;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.info-value{font-size:1.25rem;font-weight:700;color:var(--color-heading)}.draw-section{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem 1.25rem 1rem;margin-bottom:1.5rem}.btn-draw{padding:.75rem 1.5rem;background:var(--color-secondary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;transition:background .15s}.btn-draw:hover:not(:disabled){background:#1a252f}.btn-draw:disabled{opacity:.6;cursor:not-allowed}.draw-confirm{display:flex;flex-direction:column;gap:.75rem}.draw-confirm p{margin:0;font-size:.95rem;color:var(--color-text)}.draw-confirm-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-confirm-yes{padding:.6rem 1.2rem;background:#dc3545;color:#fff;border:none;border-radius:var(--radius);font-size:.92rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-confirm-yes:hover{opacity:.85}.btn-confirm-no{padding:.6rem 1.2rem;background:var(--color-border);color:var(--color-text);border:none;border-radius:var(--radius);font-size:.92rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-confirm-no:hover{opacity:.8}.draw-hint{margin:.75rem 0 0;font-size:.85rem;color:var(--color-text-muted)}.draw-hint a{color:var(--color-primary);text-decoration:none;font-weight:600}.assignment-section{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem;margin-bottom:1.5rem}.assignment-card{border-radius:var(--radius);padding:1rem 1.1rem;border:2px dashed var(--color-border)}.assignment-card.filled{border:2px solid #e8f4e8;background:#f6fff6}:root.dark .assignment-card.filled{border-color:#1a3a2a;background:#162616}.assignment-label{margin:0 0 .25rem;font-size:.85rem;color:var(--color-text-muted);font-weight:600}.assignment-name{margin:0 0 .75rem;font-size:1.4rem;font-weight:700;color:var(--color-heading)}.assignment-wish{display:flex;flex-wrap:wrap;gap:.4rem;align-items:baseline}.wish-label{font-size:.85rem;font-weight:600;color:var(--color-text-muted)}.wish-text{font-style:italic;color:var(--color-text)}.wish-empty{font-style:italic}.participants-section{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem;margin-bottom:1.5rem}.participant-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.participant-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius);background:var(--color-bg);transition:background .12s}.participant-item:hover{background:#eef0f3}:root.dark .participant-item:hover{background:#ffffff0f}.participant-avatar{width:2rem;height:2rem;border-radius:50%;background:var(--color-secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0}.participant-name{flex:1;font-weight:500}.participant-you{font-size:.75rem;background:var(--color-primary);color:#fff;padding:.15rem .5rem;border-radius:999px;font-weight:600}.muted{color:var(--color-text-muted);font-size:.95rem;margin:0}.page-loading,.page-error{padding:2rem 0;color:var(--color-text-muted);font-size:1rem}.page-error{color:var(--color-error-text)}.form-success{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid #b8dfc4;border-radius:var(--radius);padding:.6rem .75rem;font-size:.9rem;margin:0 0 .75rem}.form-error{background:var(--color-error-bg);color:var(--color-error-text);border:1px solid #f5c6c4;border-radius:var(--radius);padding:.6rem .75rem;font-size:.9rem;margin:0 0 .75rem}@media(min-width:600px){.info-item{flex:1 1 140px}}.draw-confirm{margin-top:1rem;padding:.875rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius)}.draw-confirm p{margin:0 0 .75rem;font-size:.9rem;color:var(--color-text)}.draw-confirm-actions{display:flex;gap:.75rem}.btn-cancel{padding:.5rem 1rem;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-size:.9rem;transition:background .15s,color .15s}.btn-cancel:hover{background:var(--color-bg);color:var(--color-text)}.btn-confirm{padding:.5rem 1rem;background:var(--color-primary);border:none;border-radius:var(--radius);color:#fff;font-size:.9rem;font-weight:600;transition:background .15s}.btn-confirm:hover{background:var(--color-primary-hover)}.settings-page h1{margin:0 0 1.25rem;font-size:1.6rem;color:var(--color-heading)}.info-note{background:#fff8e1;border:1px solid #ffe082;border-radius:var(--radius);padding:.6rem .85rem;font-size:.9rem;color:#7b5800;margin-bottom:1.25rem}:root.dark .info-note{background:#2a2200;border-color:#5a4000;color:#fcd34d}.settings-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem 1.25rem;max-width:480px}.settings-form{display:flex;flex-direction:column;gap:1.1rem}.field-group{display:flex;flex-direction:column;gap:.35rem}.field-group label{font-weight:600;font-size:.9rem;color:var(--color-text)}.field-group input{padding:.65rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:1rem;color:var(--color-text);transition:border-color .15s,box-shadow .15s;background:var(--color-input-bg);font-family:inherit}.field-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #c0392b1f;background:var(--color-input-bg-focus)}.readonly-value{margin:0;font-size:1.1rem;font-weight:600;color:var(--color-heading);padding:.2rem 0}.page-loading{padding:2rem 0;color:var(--color-text-muted)}@media(min-width:600px){.settings-card{padding:2rem 1.75rem}}.user-mgmt{margin-top:1.5rem;max-width:600px}.user-mgmt h2{margin:0 0 1rem;font-size:1.2rem;color:var(--color-heading)}.user-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.user-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:.65rem .75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius)}.user-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.user-name{font-weight:600;font-size:.95rem}.badge{font-size:.75rem;font-weight:600;padding:.15rem .55rem;border-radius:999px}.badge-active{background:#d4edda;color:#155724}.badge-inactive{background:#f8d7da;color:#721c24}.badge-admin{background:#fff3cd;color:#856404}.badge-standard{background:#e9ecef;color:#495057}:root.dark .badge-active{background:#1a3a2a;color:#6ee7b7}:root.dark .badge-inactive{background:#3a1a1a;color:#fca5a5}:root.dark .badge-admin{background:#2a2000;color:#fcd34d}:root.dark .badge-standard{background:#2d3748;color:#94a3b8}.user-actions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}.btn-activate,.btn-deactivate,.btn-role{padding:.3rem .7rem;font-size:.82rem;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:opacity .15s}.btn-activate{background:#28a745;color:#fff}.btn-deactivate{background:#dc3545;color:#fff}.btn-role{background:var(--color-secondary);color:#fff}.btn-delete{background:#6c1f1f;color:#fff;padding:.3rem .7rem;font-size:.82rem;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:opacity .15s}.btn-activate:hover,.btn-deactivate:hover,.btn-role:hover,.btn-delete:hover{opacity:.85}.delete-confirm-label{font-size:.82rem;color:var(--color-text);font-weight:600}.self-label{font-size:.82rem;color:var(--color-text-muted);font-style:italic}.danger-zone{margin-top:1.5rem;max-width:480px}.danger-zone h2{margin:0 0 1rem;font-size:1.2rem;color:var(--color-heading)}.btn-danger{padding:.6rem 1.4rem;background:#dc3545;color:#fff;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-danger:hover:not(:disabled){opacity:.85}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{padding:.6rem 1.4rem;background:var(--color-border);color:var(--color-text);border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-cancel:hover{opacity:.8}.clear-confirm{display:flex;flex-direction:column;gap:.75rem}.clear-confirm p{margin:0;font-size:.95rem;color:var(--color-text)}.clear-confirm-actions{display:flex;gap:.5rem;flex-wrap:wrap}.profile-page h1{margin:0 0 1.25rem;font-size:1.6rem;color:var(--color-heading)}.profile-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem 1.25rem;max-width:480px;margin-bottom:1.25rem}.profile-email{font-size:.9rem;color:var(--color-text-muted);margin:0 0 1.25rem;border-bottom:1px solid var(--color-border);padding-bottom:.75rem}.profile-form{display:flex;flex-direction:column;gap:1rem}.pfield{display:flex;flex-direction:column;gap:.35rem}.pfield label{font-weight:600;font-size:.9rem;color:var(--color-text)}.hint{font-weight:400;font-size:.8rem;color:var(--color-text-muted)}.pfield input,.pfield textarea{padding:.65rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:1rem;font-family:inherit;color:var(--color-text);transition:border-color .15s,box-shadow .15s;background:var(--color-input-bg);resize:vertical}.pfield input:focus,.pfield textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #c0392b1f;background:var(--color-input-bg-focus)}.btn-save{align-self:flex-start;padding:.7rem 1.75rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;transition:background .15s;margin-top:.25rem}.btn-save:hover:not(:disabled){background:var(--color-primary-hover)}.btn-save:disabled{opacity:.6;cursor:not-allowed}.msg-error{background:var(--color-error-bg);color:var(--color-error-text);border:1px solid #f5c6c4;border-radius:var(--radius);padding:.6rem .75rem;font-size:.9rem;margin:0 0 .5rem}.msg-success{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid #b8dfc4;border-radius:var(--radius);padding:.6rem .75rem;font-size:.9rem;margin:0 0 .5rem}.admin-badge{font-size:.9rem;color:var(--color-text-muted);margin:0}@media(min-width:600px){.profile-card{padding:2rem 1.75rem}}
