:root{--ff-display: "Cormorant Garamond", Georgia, serif;--ff-body: "Outfit", system-ui, -apple-system, sans-serif;--gold: #C8891A;--gold-light: #E8B44A;--gold-dark: #A06D10;--accent: #C4847A;--bg: #FDFBF7;--bg2: #F6F2EB;--surface: #FFFFFF;--surface-hover: #FAF7F2;--ink: #1A1714;--ink2: #5A554D;--ink3: #8A857D;--border: #E8E2D8;--border-focus: #C8891A;--danger: #D94545;--success: #3A8A5A;--radius: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(26,23,20,.06);--shadow-md: 0 4px 16px rgba(26,23,20,.08);--shadow-lg: 0 8px 32px rgba(26,23,20,.12);--shadow-glow: 0 0 0 3px rgba(200,137,26,.18)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--ff-body);background:var(--bg);color:var(--ink);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:600}a{color:var(--gold);text-decoration:none;transition:color .15s}a:hover{color:var(--gold-dark)}img{max-width:100%;display:block}.app-shell{display:flex;flex-direction:column;min-height:100vh}.container{max-width:1100px;margin:0 auto;padding:0 20px;width:100%}.container-sm{max-width:560px;margin:0 auto;padding:0 20px;width:100%}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--ink3)}.mt-2{margin-top:8px}@media(max-width:640px){.hide-mobile{display:none!important}}.navbar{position:sticky;top:0;z-index:100;background:#fdfbf7d9;-webkit-backdrop-filter:blur(16px) saturate(1.5);backdrop-filter:blur(16px) saturate(1.5);border-bottom:1px solid var(--border);padding:12px 0}.navbar-brand{display:flex;align-items:center;gap:8px;font-family:var(--ff-display);font-size:1.3rem;font-weight:600;color:var(--ink);text-decoration:none}.navbar-brand:hover{color:var(--gold)}.brand-icon{font-size:1.4rem}.brand-text{letter-spacing:-.02em}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius);font-family:var(--ff-body);font-size:.9375rem;font-weight:500;border:1.5px solid transparent;cursor:pointer;transition:all .2s ease;text-decoration:none;line-height:1.4}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#fff;border-color:var(--gold);box-shadow:var(--shadow-sm)}.btn-gold:hover{background:linear-gradient(135deg,var(--gold-dark),var(--gold));box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-gold:active{transform:translateY(0)}.btn-gold:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-outline{background:var(--surface);color:var(--ink);border-color:var(--border)}.btn-outline:hover{border-color:var(--gold);color:var(--gold);background:var(--surface-hover)}.btn-ghost{background:transparent;color:var(--ink2);border:none}.btn-ghost:hover{color:var(--gold);background:#c8891a0f}.btn-danger{background:transparent;color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-primary{background:var(--gold);color:#fff;border-color:var(--gold)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.8125rem;font-weight:500;color:var(--ink2);letter-spacing:.02em}.form-input,.form-select{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--ff-body);font-size:.9375rem;background:var(--surface);color:var(--ink);transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus,.form-select:focus{outline:none;border-color:var(--gold);box-shadow:var(--shadow-glow)}.form-input::placeholder{color:var(--ink3)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%238A857D' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.card:hover{box-shadow:var(--shadow-md)}.card-body{padding:20px 24px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.6875rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase}.badge-gray{background:var(--bg2);color:var(--ink3)}.badge-gold{background:#c8891a1f;color:var(--gold-dark)}.badge-green{background:#3a8a5a1a;color:var(--success)}.alert{padding:12px 16px;border-radius:var(--radius);font-size:.875rem;font-weight:500}.alert-error{background:#d9454514;color:var(--danger);border:1px solid rgba(217,69,69,.15)}.alert-success{background:#3a8a5a14;color:var(--success);border:1px solid rgba(58,138,90,.15)}.tabs{display:flex;gap:0;border-bottom:1.5px solid var(--border);margin-bottom:28px;overflow-x:auto}.tab-btn{padding:10px 18px;background:none;border:none;cursor:pointer;font-family:var(--ff-body);font-size:.875rem;font-weight:500;color:var(--ink3);border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;margin-bottom:-1.5px}.tab-btn:hover{color:var(--ink)}.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.photo-thumb{position:relative;aspect-ratio:1;overflow:hidden;border-radius:var(--radius);background:var(--bg2);cursor:pointer}.photo-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.photo-thumb:hover img{transform:scale(1.05)}.photo-thumb-actions{position:absolute;bottom:0;left:0;right:0;display:flex;gap:4px;padding:6px;background:linear-gradient(transparent,#0009);opacity:0;transition:opacity .2s}.photo-thumb:hover .photo-thumb-actions{opacity:1}.photo-thumb-actions button{flex:1;padding:6px;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .15s}.action-approve{background:#3a8a5ad9;color:#fff}.action-approve:hover{background:var(--success)}.action-reject{background:#d94545d9;color:#fff}.action-reject:hover{background:var(--danger)}.action-delete{background:#00000080;color:#fff}.action-delete:hover{background:#000c}.event-types{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.event-type-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--surface);font-size:.8125rem;font-weight:500;transition:all .15s}.event-type-card:hover{border-color:var(--gold);background:var(--surface-hover)}.event-type-card.selected{border-color:var(--gold);background:#c8891a0f;box-shadow:var(--shadow-glow)}.event-type-icon{font-size:1.5rem}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--gold);background:#c8891a0a}.upload-icon{font-size:2.5rem;margin-bottom:8px}.upload-progress{height:6px;background:var(--bg2);border-radius:3px;overflow:hidden}.upload-progress-bar{height:100%;border-radius:3px;transition:width .3s ease}.qr-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px 32px;text-align:center;box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;gap:12px}.guest-page{min-height:100vh;padding:0 16px 48px;display:flex;flex-direction:column;align-items:center;background:var(--guest-bg, var(--bg))}.guest-header{text-align:center;padding:48px 0 28px;max-width:480px}.guest-upload-card{width:100%;max-width:480px;background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.guest-gallery{width:100%;max-width:640px;margin-top:40px}.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;gap:10px;padding:80px 0;color:var(--ink3);font-size:.9375rem}.hero{text-align:center;padding:80px 20px 60px;background:linear-gradient(180deg,var(--bg) 0%,rgba(200,137,26,.04) 100%)}.hero h1{font-family:var(--ff-display);font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.1;margin-bottom:16px}.hero h1 .gold{color:var(--gold)}.hero p{font-size:1.15rem;color:var(--ink2);max-width:520px;margin:0 auto 32px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;padding:0 20px;max-width:960px;margin:0 auto 80px}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;text-align:center;transition:all .25s}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon{font-size:2.2rem;margin-bottom:12px}.feature-card h3{font-family:var(--ff-display);font-size:1.25rem;margin-bottom:8px}.feature-card p{font-size:.875rem;color:var(--ink2)}.steps-section{padding:60px 20px 80px;text-align:center;background:var(--bg2)}.steps-section h2{font-family:var(--ff-display);font-size:2rem;margin-bottom:48px}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px;max-width:800px;margin:0 auto}.step-item{display:flex;flex-direction:column;align-items:center;gap:12px}.step-number{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700}.step-item h3{font-size:1rem;font-weight:600}.step-item p{font-size:.875rem;color:var(--ink2);max-width:240px}.cta-section{text-align:center;padding:60px 20px;background:linear-gradient(135deg,#c8891a0f,#c4847a0f)}.cta-section h2{font-family:var(--ff-display);font-size:1.8rem;margin-bottom:12px}.cta-section p{color:var(--ink2);margin-bottom:24px}.landing-footer{text-align:center;padding:32px 20px;font-size:.75rem;color:var(--ink3);border-top:1px solid var(--border)}.auth-page{flex:1;display:flex;align-items:center;justify-content:center;padding:48px 20px}.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px 36px;box-shadow:var(--shadow-lg)}.auth-card h1{font-family:var(--ff-display);font-size:1.8rem;text-align:center;margin-bottom:28px}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.event-card{display:flex;flex-direction:column;gap:10px;padding:22px 24px;text-decoration:none;color:var(--ink)}.event-card:hover{transform:translateY(-2px)}.event-card h3{font-family:var(--ff-display);font-size:1.2rem}.empty-state{text-align:center;padding:80px 20px;color:var(--ink3)}.empty-state .empty-icon{font-size:3rem;margin-bottom:16px}.empty-state h3{font-family:var(--ff-display);font-size:1.4rem;color:var(--ink);margin-bottom:8px}.empty-state p{margin-bottom:24px}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease-out both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.hero{padding:48px 16px 40px}.hero h1{font-size:2rem}.auth-card{padding:28px 24px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.event-types{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}
