.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.auth-card{background:white;padding:40px;border-radius:8px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.auth-card h1{text-align:center;color:#667eea;margin-bottom:10px;font-size:32px}.auth-card h2{text-align:center;color:#333;margin-bottom:30px;font-size:24px}.auth-card form{display:flex;flex-direction:column;gap:15px}.auth-card input{padding:12px 15px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .3s}.auth-card input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.auth-card button{padding:12px;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s}.auth-card button:hover{background:#5568d3}.auth-card button:disabled{background:#ccc;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:12px;border-radius:4px;margin-bottom:15px;font-size:14px}.success-message{background:#efe;color:#3c3;padding:12px;border-radius:4px;margin-bottom:15px;font-size:14px}.auth-switch-text{margin-top:16px;text-align:center;color:#555;font-size:14px}.auth-switch-btn{background:none;border:none;color:#667eea;font-weight:700;cursor:pointer;padding:0}.auth-switch-btn:hover{color:#5568d3;text-decoration:underline}.notification-area{background:linear-gradient(135deg,var(--surface) 0%,var(--surface-alt) 100%);border:1px solid var(--border-color);border-radius:12px;padding:16px;margin-bottom:20px;box-shadow:0 2px 8px #00000014}.notification-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.notification-header h3{margin:0;color:var(--text-primary);font-size:16px;font-weight:600}.notification-icon{font-size:20px;line-height:1}.notifications-list{display:flex;flex-wrap:wrap;gap:10px}.notification-item{padding:10px 12px;border-radius:8px;border:1px solid;background:var(--input-bg);display:flex;align-items:center;gap:10px;font-size:13px;min-width:240px;transition:all .2s ease}.notification-item:hover{box-shadow:0 2px 6px #0000001f;transform:translateY(-1px)}.notification-holiday{border-color:#fbbf24;background:rgba(251,191,36,.08)}.notification-birthday{border-color:#ec4899;background:rgba(236,72,153,.08)}.notification-content{display:flex;flex-direction:column;gap:4px;flex:1}.notification-event-name{color:var(--text-primary);font-weight:500;line-height:1.3}.notification-meta{display:flex;align-items:center;gap:8px;font-size:12px}.notification-description{color:var(--text-secondary);font-size:12px;margin-top:6px}.notification-date{color:var(--text-secondary)}.notification-countdown{color:var(--text-secondary);font-weight:500;padding:2px 6px;background:rgba(0,0,0,.05);border-radius:4px}.notification-holiday .notification-countdown{background:rgba(251,191,36,.2);color:#92400e}.notification-birthday .notification-countdown{background:rgba(236,72,153,.2);color:#831843}body[data-theme=dark] .notification-countdown{background:rgba(255,255,255,.08)}body[data-theme=dark] .notification-holiday .notification-countdown{color:#fcd34d}body[data-theme=dark] .notification-birthday .notification-countdown{color:#f472b6}.notification-dismiss{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:16px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.notification-dismiss:hover{background:rgba(0,0,0,.1);color:var(--text-primary)}@media (max-width: 768px){.notification-area{padding:12px}.notification-item{min-width:100%;flex-direction:column}.notification-meta{flex-direction:column;gap:4px}.notifications-list{flex-direction:column}}.gift-list-container{padding:20px;max-width:1400px;margin:0 auto}.gift-list-container h1{color:#333;margin-bottom:30px;text-align:center;font-size:32px}.view-toggle{display:inline-flex;border:1px solid #d6dcff;border-radius:8px;overflow:hidden;margin-bottom:16px;background:#fff}.view-toggle-btn{border:none;background:#fff;color:#5568d3;padding:10px 16px;font-weight:700;cursor:pointer;transition:background .2s,color .2s}.view-toggle-btn:hover{background:#eef1ff}.view-toggle-btn.active{background:#667eea;color:#fff}.filters-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:30px;background:white;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.filter-input,.filter-select{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit}.filter-input:focus,.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.reset-btn{padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s}.reset-btn:hover{background:#5568d3}.gifts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.gifts-table-container{background:white;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.gifts-table thead{background:#f5f7ff}.gifts-table th{text-align:left;color:#2d3748;font-weight:700;font-size:13px;letter-spacing:.02em;text-transform:uppercase;padding:12px;border-bottom:1px solid #e5e7eb;white-space:nowrap}.gifts-table td{padding:12px;border-bottom:1px solid #eef2f7;vertical-align:top}.gifts-table tr:hover{background:#fafbff}.table-gift-title{font-weight:700;color:#2d3748}.table-gift-description{margin-top:4px;color:#718096;font-size:13px}.table-gift-link{margin-top:6px;margin-bottom:0;font-size:13px}.table-action-btn{width:100%;min-width:150px}.table-owner-actions,.table-edit-fields{display:grid;gap:6px}.table-edit-input{width:100%;border:1px solid #c7d2fe;border-radius:6px;padding:8px;font-size:13px;font-family:inherit;box-sizing:border-box}.table-edit-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.owner-actions{display:grid;gap:8px}.card-edit-fields{display:grid;gap:10px;margin:10px 0}.card-edit-row{display:grid;gap:8px;grid-template-columns:1fr 1fr}.card-edit-input{width:100%;border:1px solid #c7d2fe;border-radius:6px;padding:8px;font-size:14px;font-family:inherit;box-sizing:border-box}.card-edit-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.table-muted{color:#718096;font-size:13px;font-weight:600}@media (max-width: 768px){.view-toggle{width:100%;display:flex}.view-toggle-btn{flex:1}.gifts-grid{grid-template-columns:1fr}.gifts-table th,.gifts-table td{font-size:12px;padding:8px}.table-action-btn{min-width:120px}.card-edit-row{grid-template-columns:1fr}}.gift-card{background:white;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;transition:all .3s;border-left:4px solid #667eea}.gift-card:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-2px)}.gift-card.claimed{border-left-color:#48bb78}.gift-card.purchased{border-left-color:#ed8936;opacity:.8}.gift-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:10px}.gift-card h3{margin:0;color:#333;font-size:18px}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge.available{background:#c3fae8;color:#0b7285}.status-badge.claimed{background:#bdf8f2;color:#086e7b}.status-badge.purchased{background:#fbd38d;color:#7c2d12}.gift-owner{color:#666;font-size:14px;margin:5px 0}.gift-description{color:#666;font-size:14px;margin:10px 0;line-height:1.4}.gift-info{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.category-tag,.priority-tag{display:inline-block;padding:4px 12px;border-radius:4px;font-size:12px;font-weight:600}.category-tag{background:#e6e6ff;color:#667eea}.priority-tag{color:#fff}.priority-tag.priority-high{background:#f56565}.priority-tag.priority-medium{background:#ed8936}.priority-tag.priority-low{background:#48bb78}.price{color:#667eea;font-weight:700;font-size:16px}.gift-link{display:inline-block;margin:12px 0;color:#667eea;text-decoration:none;font-weight:600;transition:color .3s}.gift-link:hover{color:#5568d3;text-decoration:underline}.gift-actions{margin-top:12px}.gift-actions .btn{width:100%;margin:0}.buyers-section{margin-top:15px;padding-top:15px;border-top:1px solid #eee}.buyers-label{font-size:12px;font-weight:600;color:#666;margin:0 0 8px;text-transform:uppercase}.buyers-list{list-style:none;padding:0;margin:0}.buyers-list li{padding:4px 0;color:#667eea;font-size:14px;font-weight:500}.loading,.no-gifts{text-align:center;padding:40px;color:#666;font-size:16px}.form-container{background:white;padding:30px;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px}.form-container h2{margin-bottom:20px;color:#333}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.btn{padding:12px 24px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;text-decoration:none;display:inline-block}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3}.btn-secondary{background:#48bb78;color:#fff}.btn-secondary:hover{background:#38a169}.btn-danger{background:#f56565;color:#fff}.btn:disabled,.btn-disabled{background:#ccc;cursor:not-allowed}.admin-panel{padding:20px;max-width:1200px;margin:0 auto}.admin-panel h2{color:#333;margin-bottom:20px}.permission-denied{background:#fee;color:#c33;padding:15px;border-radius:4px;border-left:4px solid #c33}.admin-tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #eee}.tab-btn{padding:12px 20px;background:none;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:600;cursor:pointer;color:#666;transition:all .3s}.tab-btn:hover{color:#667eea}.tab-btn.active{color:#667eea;border-bottom-color:#667eea}.admin-content{background:white;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.admin-content h3{margin-top:0;color:#333}.admin-help-text{margin:0 0 16px;color:#666}.admin-user-form{display:grid;gap:14px;max-width:560px}.admin-form-row{display:grid;gap:6px}.admin-form-row label{font-weight:600;color:#333}.admin-form-row input,.admin-form-row select{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit}.admin-form-row input:focus,.admin-form-row select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:#f5f5f5}.users-table th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #ddd}.users-table td{padding:12px;border-bottom:1px solid #eee}.users-table tr:hover{background:#f9f9f9}.role-select{padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px;cursor:pointer}.role-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.users-table .btn{padding:8px 12px;font-size:12px}.gifts-table-container{overflow-x:auto}.gifts-table{width:100%;border-collapse:collapse}.gifts-table thead{background:#f5f5f5}.gifts-table th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #ddd}.gifts-table td{padding:12px;border-bottom:1px solid #eee}.gifts-table tr:hover{background:#f9f9f9}.edit-input{width:100%;padding:8px;border:1px solid #667eea;border-radius:4px;font-size:14px;font-family:inherit;box-sizing:border-box}.edit-input:focus{outline:none;box-shadow:0 0 0 3px #667eea33}.btn-small{padding:6px 10px;font-size:12px;margin-right:4px}.btn-success{background:#48bb78;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.btn-success:hover{background:#38a169}.btn-edit{background:#4299e1;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.btn-edit:hover{background:#3182ce}.btn-danger{background:#f56565;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.btn-danger:hover{background:#e53e3e}.btn-secondary{background:#718096;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#4a5568}.loading{padding:20px;text-align:center;color:#666}.no-data{padding:20px;text-align:center;color:#999}@media (max-width: 768px){.users-table th,.users-table td{padding:8px;font-size:12px}.gifts-table th,.gifts-table td{padding:8px;font-size:11px}.btn-small{padding:4px 8px;font-size:10px;margin-right:2px}}.settings-container{max-width:900px;margin:0 auto;padding:12px 0}.settings-container h2{font-size:28px;margin-bottom:8px;color:var(--text-primary)}.settings-subtitle{color:var(--text-secondary);margin-bottom:20px}.settings-card{background:var(--surface);border:1px solid var(--border-color);border-radius:10px;padding:18px;box-shadow:var(--surface-shadow);margin-bottom:16px}.settings-card h3{color:var(--text-primary);margin-bottom:12px}.settings-options{display:flex;flex-wrap:wrap;gap:12px}.settings-option{display:flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:8px;padding:10px 12px;background:var(--surface-alt);color:var(--text-primary);min-width:140px}.settings-option input{accent-color:#667eea}.settings-birthday{display:flex;gap:16px;flex-wrap:wrap}.birthday-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:150px}.birthday-field label{color:var(--text-primary);font-size:14px;font-weight:500}.birthday-field select,.birthday-field input{padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:14px}.birthday-field select:focus,.birthday-field input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-change-form{display:flex;flex-direction:column;gap:16px}.password-change-form .form-group{display:flex;flex-direction:column;gap:6px}.password-change-form label{color:var(--text-primary);font-size:14px;font-weight:500}.password-change-form input{padding:10px;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:14px}.password-change-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-change-form button{align-self:flex-start;padding:10px 16px;border:none;border-radius:6px;background:#667eea;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.password-change-form button:hover:not(:disabled){background:#5a67d8}.password-change-form button:disabled{background:var(--text-secondary);cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:12px;border-radius:4px;border-left:4px solid #c33;margin-bottom:16px}.success-message{background:#efe;color:#3c3;padding:12px;border-radius:4px;border-left:4px solid #3c3;margin-bottom:16px}.settings-note{margin-top:8px;color:var(--text-secondary);font-size:14px}.dismissed-notifications-list{list-style:none;padding:0;margin:0}.dismissed-notification-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-color)}.dismissed-notification-item:last-child{border-bottom:none}.dismissed-notification-item span{color:var(--text-primary);font-size:14px}@media (max-width: 768px){.settings-options{flex-direction:column}.settings-option{width:100%}}:root{--bg-color: #f5f5f5;--surface: #ffffff;--surface-alt: #f8fafc;--text-primary: #333333;--text-secondary: #666666;--accent: #667eea;--accent-hover: #5568d3;--border-color: #dfe3eb;--surface-shadow: 0 2px 8px rgba(0, 0, 0, .1)}body[data-theme=dark]{--bg-color: #111827;--surface: #1f2937;--surface-alt: #0f172a;--text-primary: #e5e7eb;--text-secondary: #9ca3af;--accent: #8fa3ff;--accent-hover: #b0beff;--border-color: #374151;--surface-shadow: 0 2px 8px rgba(0, 0, 0, .45)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--bg-color);color:var(--text-primary)}input[type=date]{color:var(--text-primary)}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.2)}body[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1) brightness(1.2)}#root{min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column}.navbar{background:var(--surface);box-shadow:var(--surface-shadow);padding:0 20px;display:flex;justify-content:space-between;align-items:center;height:60px;border-bottom:1px solid var(--border-color)}.navbar-brand{font-size:24px;font-weight:700;color:var(--accent);text-decoration:none}.navbar-links{display:flex;gap:20px;align-items:center;list-style:none}.navbar-links a{text-decoration:none;color:var(--text-secondary);font-weight:600;transition:color .3s}.navbar-links a:hover{color:var(--accent)}.navbar-links .btn{margin:0;padding:8px 16px;font-size:14px}.main-content{flex:1;padding:20px}.page-container{max-width:1400px;margin:0 auto}body[data-theme=dark] .form-container,body[data-theme=dark] .admin-content,body[data-theme=dark] .filters-section,body[data-theme=dark] .gift-card,body[data-theme=dark] .gifts-table-container,body[data-theme=dark] .settings-card,body[data-theme=dark] .users-table thead,body[data-theme=dark] .gifts-table thead,body[data-theme=dark] .auth-card{background:var(--surface);color:var(--text-primary);border-color:var(--border-color)}body[data-theme=dark] .users-table tr:hover,body[data-theme=dark] .gifts-table tr:hover,body[data-theme=dark] .view-toggle-btn:hover{background:#243043}body[data-theme=dark] .filter-input,body[data-theme=dark] .filter-select,body[data-theme=dark] input,body[data-theme=dark] textarea,body[data-theme=dark] select{background:#111827;color:var(--text-primary);border-color:var(--border-color)}body[data-theme=dark] label,body[data-theme=dark] .form-group label,body[data-theme=dark] .admin-form-row label,body[data-theme=dark] .birthday-field label,body[data-theme=dark] .password-change-form label{color:var(--text-primary)}body[data-theme=dark] .gift-description,body[data-theme=dark] .gift-owner,body[data-theme=dark] .table-gift-description,body[data-theme=dark] .buyers-label,body[data-theme=dark] .table-muted{color:var(--text-secondary)}
