:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #d4a574;--secondary-color: #f5f5f5;--accent-color: #8b4513;--text-primary: #333333;--text-secondary: #666666;--text-light: #ffffff;--background: #ffffff;--background-light: #fafafa;--border: #e0e0e0;--error: #dc3545;--success: #28a745;--warning: #ffc107;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--sidebar-width: 280px;--header-height: 64px}*{box-sizing:border-box}html{width:100%;height:100%;margin:0;padding:0}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--text-primary);background-color:var(--background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;margin:0;padding:0}.app{min-height:100vh;width:100%}#root{width:100%;min-height:100vh}.app-header{background:var(--background);border-bottom:1px solid var(--border);box-shadow:0 2px 4px #0000000d;position:sticky;top:0;z-index:100}.header-container{width:100%;padding:var(--spacing-md) var(--spacing-xl);display:flex;justify-content:space-between;align-items:center;box-sizing:border-box}.header-left .header-title{color:var(--primary-color);font-size:var(--font-size-xl);font-weight:700;margin:0}.header-right{display:flex;align-items:center;gap:var(--spacing-lg)}.user-info{display:flex;align-items:center;gap:var(--spacing-md)}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-color);color:var(--text-light);display:flex;align-items:center;justify-content:center}.user-details{display:flex;flex-direction:column}.user-name{font-weight:600;color:var(--text-primary);font-size:var(--font-size-sm)}.user-role{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.logout-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s ease-in-out;font-size:var(--font-size-sm);min-height:36px}.logout-btn:hover{background:var(--background-light);color:var(--text-primary);border-color:var(--primary-color)}.app-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:var(--spacing-xl)}h1,h2,h3,h4,h5,h6{margin-bottom:var(--spacing-md);font-weight:600;line-height:1.2}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:500;text-decoration:none;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease-in-out;min-height:44px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:500;text-decoration:none;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease-in-out;min-height:44px;background-color:var(--primary-color);color:var(--text-light);border-color:var(--primary-color)}.btn-primary:hover:not(:disabled){background-color:var(--accent-color);border-color:var(--accent-color)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:500;text-decoration:none;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease-in-out;min-height:44px;background-color:transparent;color:var(--primary-color);border-color:var(--primary-color)}.btn-secondary:hover:not(:disabled){background-color:var(--primary-color);color:var(--text-light)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);border:1px solid var(--border);border-radius:6px;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out;min-height:44px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #d4a5741a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--background-light);cursor:not-allowed}.error-message{background-color:#fee;color:var(--error);padding:var(--spacing-sm) var(--spacing-md);border:1px solid #fcc;border-radius:6px;margin-bottom:var(--spacing-lg)}.success-message{background-color:#efe;color:var(--success);padding:var(--spacing-sm) var(--spacing-md);border:1px solid #cfc;border-radius:6px;margin-bottom:var(--spacing-lg)}.loading-container{display:flex;align-items:center;justify-content:center;min-height:50vh}.loading-spinner{padding:var(--spacing-xl);font-size:var(--font-size-lg);color:var(--text-secondary)}.login-page,.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--background-light) 0%,var(--secondary-color) 100%)}.login-container,.register-container{width:100%;max-width:400px;padding:var(--spacing-xl)}.login-form,.register-form{background:var(--background);padding:var(--spacing-2xl);border-radius:12px;box-shadow:0 4px 6px #0000001a}.login-form h1,.register-form h1{text-align:center;color:var(--primary-color);margin-bottom:var(--spacing-sm)}.login-form h2,.register-form h2{text-align:center;margin-bottom:var(--spacing-xl);color:var(--text-primary)}.auth-links{text-align:center;margin-top:var(--spacing-xl)}.auth-links a{color:var(--primary-color);text-decoration:none}.auth-links a:hover{text-decoration:underline}.admin-dashboard,.couple-dashboard{padding:var(--spacing-xl);max-width:1200px;margin:0 auto}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin:var(--spacing-xl) 0}.dashboard-card{background:var(--background);padding:var(--spacing-xl);border-radius:12px;box-shadow:0 2px 4px #0000001a;border:1px solid var(--border)}.dashboard-card h3{margin-bottom:var(--spacing-md);color:var(--text-primary)}.metric{font-size:var(--font-size-3xl);font-weight:700;color:var(--primary-color);margin:0}.admin-actions,.couple-actions{margin-top:var(--spacing-2xl)}.action-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.guest-invitation{max-width:800px;margin:0 auto;padding:var(--spacing-xl)}.hero-section{text-align:center;margin-bottom:var(--spacing-2xl);padding:var(--spacing-2xl);background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:var(--text-light);border-radius:12px}.wedding-date{font-size:var(--font-size-xl);font-weight:600;margin:var(--spacing-lg) 0}.quote{font-style:italic;font-size:var(--font-size-lg);margin-top:var(--spacing-xl)}.ceremony-details,.reception-details,.rsvp-section{background:var(--background);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);border-radius:12px;box-shadow:0 2px 4px #0000001a}.rsvp-form{margin-top:var(--spacing-lg)}.unauthorized-page,.not-found-page{min-height:100vh;display:flex;align-items:center;justify-content:center}.error-container{text-align:center;padding:var(--spacing-2xl);max-width:500px}.error-container h1{color:var(--error);margin-bottom:var(--spacing-lg)}.error-actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-xl)}@media (max-width: 768px){.login-container,.register-container{padding:var(--spacing-md)}.login-form,.register-form{padding:var(--spacing-xl)}.dashboard-grid{grid-template-columns:1fr}.action-buttons,.error-actions{flex-direction:column}.guest-invitation{padding:var(--spacing-md)}.hero-section{padding:var(--spacing-xl)}.header-container{padding:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.header-left .header-title{font-size:var(--font-size-lg)}.user-details,.logout-btn span{display:none}.main-content{padding:var(--spacing-md)}}.app-sidebar{width:var(--sidebar-width);height:100vh;background:#fff;border-right:1px solid var(--border);transition:transform .3s ease}.app-header{height:var(--header-height);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);position:sticky;top:0;z-index:100}@media (max-width: var(--breakpoint-lg)){.app-sidebar{position:fixed;top:0;left:-var(--sidebar-width);z-index:1000}.app-sidebar.open{transform:translate(var(--sidebar-width))}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}
