.App{min-height:100vh}.App-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;padding:2rem;text-align:center;box-shadow:0 2px 10px #0000001a}.App-header h1{font-size:2.5rem;margin:0}.container{max-width:1200px;margin:0 auto;padding:2rem}.section{background:var(--card-bg);border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.section h2{color:var(--primary-color);margin-bottom:1.5rem;border-bottom:2px solid var(--accent-color);padding-bottom:.5rem}.loading{text-align:center;padding:4rem;font-size:1.5rem;color:var(--primary-color)}.event-selection{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%)}.event-selection h1{color:#fff;font-size:3rem;margin-bottom:1rem;text-align:center}.event-selection .subtitle{color:#ffffffe6;font-size:1.5rem;margin-bottom:3rem;text-align:center}.mode-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;width:100%}.mode-button{background:white;border:none;border-radius:12px;padding:3rem 2rem;cursor:pointer;transition:all .3s ease;text-align:center;box-shadow:0 4px 15px #0000001a}.mode-button:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.mode-button .icon{font-size:4rem;display:block;margin-bottom:1rem}.mode-button h3{color:var(--primary-color);font-size:1.5rem;margin-bottom:.5rem}.mode-button p{color:var(--text-color);font-size:1rem;margin:0}.mode-button.system-admin-button{border:2px solid #ff9800;background:linear-gradient(135deg,#fff 0%,#fff8e1 100%)}.mode-button.system-admin-button .icon,.mode-button.system-admin-button h3{color:#ff9800}.event-selection form{background:white;border-radius:12px;padding:3rem;max-width:500px;width:100%;box-shadow:0 4px 15px #0000001a}.event-selection h2{color:var(--primary-color);text-align:center;margin-bottom:2rem}.event-selection .form-group{margin-bottom:1.5rem}.event-selection .form-group label{display:block;margin-bottom:.5rem;color:var(--text-color);font-weight:500}.event-selection .form-group input,.event-selection .form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.event-selection .form-group input:focus,.event-selection .form-group textarea:focus{outline:none;border-color:var(--primary-color)}.event-selection .help-text{margin-top:.5rem;font-size:.875rem;color:var(--secondary-color)}.event-created{background:white;border-radius:12px;padding:3rem;max-width:600px;width:100%;box-shadow:0 4px 15px #0000001a;text-align:center}.event-created h2{color:var(--primary-color);margin-bottom:2rem}.event-details h3{color:var(--text-color);margin-bottom:1rem}.codes{display:flex;flex-direction:column;gap:2rem;margin:2rem 0}.code-box{background:#f5f5f5;border-radius:8px;padding:1.5rem}.code-box h4{color:var(--text-color);margin-bottom:1rem;font-size:1rem}.code-box code{display:block;background:white;border:2px solid var(--primary-color);border-radius:8px;padding:1rem;font-size:1.5rem;font-weight:700;letter-spacing:.2em;color:var(--primary-color);margin-bottom:.5rem}.code-box.admin-code code{border-color:var(--error-color);color:var(--error-color)}.code-description{font-size:.875rem;color:var(--secondary-color);margin:0}.button-group{display:flex;gap:1rem;margin-top:2rem}.primary-button,.secondary-button{flex:1;padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.primary-button{background:var(--primary-color);color:#fff}.primary-button:hover{background:var(--secondary-color);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.secondary-button{background:#e0e0e0;color:var(--text-color)}.secondary-button:hover{background:#d0d0d0}.error-message{background-color:var(--error-color);color:#fff;padding:1rem;margin:1rem 2rem;border-radius:4px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer}.add-participant-form{display:flex;gap:1rem;margin-bottom:2rem}.add-participant-form input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.add-participant-form button{padding:.75rem 1.5rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .3s}.add-participant-form button:hover{background-color:#1e4620}.participant-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.participant-card{border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;background:#fafafa}.participant-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:.5rem}.participant-header h3{color:#bbb;margin:0;flex:1}.participant-header .email{font-size:.85rem;color:#666;flex:1}.delete-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;opacity:.6;transition:opacity .3s}.delete-btn:hover{opacity:1}.empty-state{text-align:center;color:#999;padding:2rem;font-style:italic}.wishlist-section h4{color:var(--secondary-color);font-size:.95rem;margin-bottom:.5rem}.empty-wishlist{color:#999;font-size:.9rem;font-style:italic}.wishlist{list-style:none;margin-bottom:.75rem}.wishlist li{display:flex;justify-content:space-between;align-items:center;padding:.5rem;margin-bottom:.25rem;background:white;border-radius:4px;font-size:.9rem}.remove-wish-btn{background:none;border:none;color:var(--error-color);cursor:pointer;padding:0 .5rem;font-size:1rem;opacity:.6;transition:opacity .3s}.remove-wish-btn:hover{opacity:1}.add-wish-form{display:flex;gap:.5rem;margin-top:.75rem}.add-wish-form input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem}.add-wish-form button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .3s}.add-wish-form button:first-of-type{background-color:var(--primary-color);color:#fff}.add-wish-form button:first-of-type:hover{background-color:#1e4620}.add-wish-form button:last-of-type{background-color:#ccc;color:#333}.add-wish-form button:last-of-type:hover{background-color:#bbb}.edit-wishlist-btn{background-color:var(--accent-color);color:#333;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;margin-top:.5rem;transition:background-color .3s}.edit-wishlist-btn:hover{background-color:#ffed4e}.draw-section{text-align:center}.draw-section p{font-size:1.1rem;margin-bottom:1.5rem}.draw-btn{background-color:var(--secondary-color);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.2rem;cursor:pointer;transition:background-color .3s;margin-bottom:1rem}.draw-btn:hover:not(:disabled){background-color:#a01829}.draw-btn:disabled{background-color:#ccc;cursor:not-allowed}.error{color:var(--error-color);margin-top:1rem;font-weight:500}.assignments-section{margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border-color)}.assignments-section h3{color:var(--primary-color);margin-bottom:1rem}.toggle-btn,.check-btn{background-color:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;margin:.5rem;transition:background-color .3s}.toggle-btn:hover,.check-btn:hover{background-color:#1e4620}.assignments-list{margin-top:1rem;text-align:left;max-width:500px;margin-left:auto;margin-right:auto}.assignment{padding:.75rem;margin-bottom:.5rem;background:#fafafa;border-left:4px solid var(--secondary-color);border-radius:4px}.my-assignment-section{margin-top:2rem;padding-top:1rem}.my-assignment{background:linear-gradient(135deg,var(--accent-color) 0%,#ffed4e 100%);padding:1.5rem;border-radius:8px;margin-top:1rem;box-shadow:0 4px 6px #0000001a}.my-assignment p{font-size:1.3rem;color:#333;margin:0}.my-assignment strong{color:var(--secondary-color)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%)}.login-card{background:white;padding:3rem;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:400px;width:90%}.login-card h1{text-align:center;color:var(--primary-color);margin-bottom:.5rem;font-size:2rem}.login-card h2{text-align:center;color:var(--text-color);margin-bottom:2rem;font-size:1.2rem;font-weight:400}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:var(--text-color)}.form-group input{padding:.75rem;border:2px solid var(--border-color);border-radius:4px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:var(--primary-color)}.login-btn{padding:1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:background-color .3s;margin-top:.5rem}.login-btn:hover:not(:disabled){background-color:#1e4620}.login-btn:disabled{background-color:#ccc;cursor:not-allowed}.admin-link{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;text-decoration:underline;font-size:.95rem}.link-btn:hover{color:var(--secondary-color)}.participant-view{min-height:100vh;background-color:var(--bg-color)}.participant-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;padding:2rem;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.participant-header h1{margin:0;font-size:2rem}.user-info{display:flex;align-items:center;gap:1.5rem}.logout-btn{padding:.5rem 1.5rem;background-color:#fff3;color:#fff;border:1px solid white;border-radius:4px;cursor:pointer;transition:background-color .3s}.logout-btn:hover{background-color:#ffffff4d}.participant-content{max-width:1000px;margin:0 auto;padding:2rem}.message{padding:1rem;border-radius:4px;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.success-message{background-color:#4caf50;color:#fff}.assignment-section{background:linear-gradient(135deg,#fff8e1 0%,#fff3cd 100%);border:2px solid var(--accent-color)}.assignment-card{background:white;padding:2rem;border-radius:8px;margin-top:1rem}.assignment-text{font-size:1.3rem;text-align:center;margin-bottom:1.5rem}.assigned-name{color:var(--secondary-color);font-size:1.5rem}.assigned-wishlist{margin-top:1.5rem;padding:1.5rem;background:#f9f9f9;border-radius:8px}.assigned-wishlist h3{color:var(--primary-color);margin-bottom:1rem;font-size:1.1rem}.assigned-wishlist ul{list-style:none;padding:0}.assigned-wishlist li{padding:.5rem 0;border-bottom:1px solid #eee}.assigned-wishlist li:last-child{border-bottom:none}.no-wishes{color:#999;font-style:italic;text-align:center;margin-top:1rem}.no-assignment{text-align:center;padding:2rem;color:#666}.no-assignment p{margin:.5rem 0}.wishlist-section{margin-top:1.5rem}.back-btn{padding:.5rem 1.5rem;background-color:#fff3;color:#fff;border:1px solid white;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:1rem}.back-btn:hover{background-color:#ffffff4d}.participant-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.participant-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.participant-actions{display:flex;gap:.5rem}.pin-indicator{font-size:.9rem;opacity:.8}.set-pin-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;opacity:.6;transition:opacity .3s}.set-pin-btn:hover{opacity:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:white;padding:2rem;border-radius:8px;max-width:400px;width:90%;box-shadow:0 4px 20px #0000004d}.modal-content h3{color:var(--primary-color);margin-bottom:1rem}.modal-content p{color:#666;margin-bottom:1.5rem}.modal-content p.hint{color:var(--primary-color);font-size:.9rem;font-weight:500;background-color:#f0f7f1;padding:.5rem 1rem;border-radius:4px;border-left:3px solid var(--primary-color)}.modal-content input{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:4px;font-size:1rem;margin-bottom:1.5rem}.modal-content input:focus{outline:none;border-color:var(--primary-color)}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.save-btn{padding:.75rem 1.5rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.save-btn:hover:not(:disabled){background-color:#1e4620}.save-btn:disabled{background-color:#ccc;cursor:not-allowed}.cancel-btn{padding:.75rem 1.5rem;background-color:#ccc;color:#333;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.cancel-btn:hover{background-color:#bbb}@media (max-width: 768px){.participant-header{flex-direction:column;gap:1rem}.user-info{width:100%;justify-content:space-between}.login-card{padding:2rem}.participant-list{grid-template-columns:1fr}}.exclusion-manager{margin-top:1rem}.info-box{background-color:#e3f2fd;border-left:4px solid #2196f3;padding:1rem;margin-bottom:1.5rem;border-radius:4px}.info-box p{margin:0;color:#1565c0;font-size:.95rem}.info-message{color:#666;font-style:italic;text-align:center;padding:1rem}.add-exclusion-form{display:flex;gap:1rem;align-items:center;margin-bottom:2rem}.add-exclusion-form select{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;background:white;cursor:pointer}.add-exclusion-form select:focus{outline:none;border-color:var(--primary-color)}.exclusion-separator{font-size:1.5rem;color:var(--text-color);font-weight:700}.add-exclusion-btn{padding:.75rem 1.5rem;background-color:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;white-space:nowrap;transition:background-color .3s}.add-exclusion-btn:hover:not(:disabled){background-color:#a01829}.add-exclusion-btn:disabled{background-color:#ccc;cursor:not-allowed}.exclusions-list{margin-top:1.5rem}.exclusions-list h4{color:var(--text-color);margin-bottom:1rem;font-size:1rem}.exclusion-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;margin-bottom:.5rem;background:#f9f9f9;border-left:4px solid var(--secondary-color);border-radius:4px;transition:background-color .2s}.exclusion-item:hover{background:#f0f0f0}.exclusion-names{font-size:1rem;color:var(--text-color)}.delete-exclusion-btn{background:none;border:none;color:var(--error-color);cursor:pointer;padding:.25rem .5rem;font-size:1.2rem;opacity:.6;transition:opacity .3s}.delete-exclusion-btn:hover{opacity:1}@media (max-width: 768px){.add-exclusion-form{flex-direction:column}.add-exclusion-form select,.add-exclusion-btn{width:100%}.exclusion-separator{transform:rotate(90deg)}}.login-link-modal{max-width:600px}.link-display{background:#f9f9f9;padding:1rem;border-radius:4px;margin:1rem 0;border:2px solid var(--border-color)}.link-input{width:100%;padding:.75rem;border:none;background:white;border-radius:4px;font-family:monospace;font-size:.9rem;cursor:pointer;margin:0!important}.link-input:focus{outline:2px solid var(--primary-color)}.system-admin-link{margin-top:3rem;text-align:center;padding-top:2rem;border-top:1px solid #e0e0e0}.link-button{background:transparent;border:none;color:#666;font-size:.9rem;cursor:pointer;text-decoration:underline;padding:.5rem 1rem;transition:color .2s}.link-button:hover{color:var(--primary-color)}:root{--primary-color: #2c5f2d;--secondary-color: #c41e3a;--accent-color: #ffd700;--bg-color: #f5f5f5;--card-bg: #ffffff;--text-color: #333;--border-color: #ddd;--error-color: #dc3545}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
