.home{overflow-x:hidden}.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(145deg,#120400,#3d1515 45%,#1a0800);overflow:hidden;padding:2rem 1.5rem 5rem}.hero-orbs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.18;animation:float 8s ease-in-out infinite}.orb--1{width:380px;height:380px;background:#c9a227;top:-10%;left:-8%;animation-delay:0s}.orb--2{width:300px;height:300px;background:#7b2328;bottom:5%;right:-5%;animation-delay:2s}.orb--3{width:200px;height:200px;background:#c9a227;top:55%;left:60%;animation-delay:4s}.orb--4{width:150px;height:150px;background:#9b3b40;top:20%;right:25%;animation-delay:6s}.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;animation:fadeInUp 1s ease both}.hero-logo-ring{position:relative;width:110px;height:110px;margin-bottom:1.5rem;animation:float 6s ease-in-out infinite;display:flex;align-items:center;justify-content:center}.hero-logo-ring:before{content:"";position:absolute;top:-24px;right:-24px;bottom:-24px;left:-24px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,39,.45) 0%,rgba(201,162,39,.12) 50%,transparent 72%);animation:logoGlow 3s ease-in-out infinite;pointer-events:none}@keyframes logoGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.12)}}.hero-logo{width:110px;height:110px;object-fit:contain;position:relative;z-index:1;filter:drop-shadow(0 0 18px rgba(201,162,39,.5))}.hero-title{font-family:var(--font-serif);font-size:clamp(2.8rem,8vw,5.5rem);font-weight:700;color:#fff;letter-spacing:.08em;line-height:1;margin-bottom:1rem;text-shadow:0 2px 30px rgba(0,0,0,.5)}.hero-ornament{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.orn-line{flex:1;max-width:80px;height:1px;background:#c9a22799}.orn-glyph{color:var(--clr-accent);font-size:1rem}.hero-dept{font-family:var(--font-serif);font-size:clamp(.85rem,2.5vw,1.1rem);color:#ffffffbf;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.4rem}.hero-batch{font-size:.9rem;color:#c9a227d9;letter-spacing:.06em;margin-bottom:2.5rem}.hero-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2.5rem;background:linear-gradient(135deg,var(--clr-accent) 0%,#A87E1A 100%);color:#1a0800;font-family:var(--font-sans);font-size:.95rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:40px;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),filter var(--transition);box-shadow:0 6px 24px #c9a22759}.hero-btn:hover{transform:translateY(-2px);box-shadow:0 10px 32px #c9a22780;filter:brightness(1.08)}.hero-btn:active{transform:translateY(0)}.hero-scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center}.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,rgba(201,162,39,.6),transparent);animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.15)}}.stats-strip{display:flex;justify-content:center;flex-wrap:wrap;gap:0;background:var(--clr-dark);padding:1.75rem 2rem}.stat-item{display:flex;flex-direction:column;align-items:center;padding:.5rem 2.5rem;border-right:1px solid rgba(255,255,255,.1);animation:fadeInUp .7s ease both}.stat-item:last-child{border-right:none}.stat-num{font-family:var(--font-serif);font-size:2rem;font-weight:700;color:var(--clr-accent);line-height:1}.stat-lbl{font-size:.72rem;color:#ffffff80;letter-spacing:.1em;text-transform:uppercase;margin-top:.3rem}.about-section{background:var(--clr-bg);padding:5rem 1.5rem}.about-inner{max-width:740px;margin:0 auto;text-align:center}.section-heading{display:flex;align-items:center;justify-content:center;gap:.85rem;margin-bottom:2rem}.sh-ornament{color:var(--clr-accent);font-size:.75rem}.sh-title{font-family:var(--font-serif);font-size:clamp(1.5rem,4vw,2.2rem);font-weight:600;color:var(--clr-primary-dark);letter-spacing:.02em}.about-text{font-size:1rem;line-height:1.8;color:var(--clr-muted);margin-bottom:1.2rem}.about-text em{color:var(--clr-primary);font-style:italic;font-family:var(--font-serif)}.about-btn{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.5rem;padding:.8rem 2rem;background:transparent;color:var(--clr-primary);border:1.5px solid var(--clr-primary);border-radius:40px;font-size:.9rem;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:background var(--transition),color var(--transition),transform var(--transition)}.about-btn:hover{background:var(--clr-primary);color:#fff;transform:translateY(-1px)}.btn-arrow{transition:transform var(--transition)}.about-btn:hover .btn-arrow{transform:translate(4px)}.features-section{background:var(--clr-surface);padding:5rem 1.5rem;border-top:1px solid var(--clr-border);border-bottom:1px solid var(--clr-border)}.features-inner{max-width:960px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2.5rem}.feature-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem;border-radius:var(--radius);border:1px solid var(--clr-border);background:var(--clr-bg);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);animation:fadeInUp .6s ease both}.feature-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px var(--clr-shadow);border-color:#c9a22766}.feature-icon{font-size:2rem;margin-bottom:.85rem}.feature-title{font-family:var(--font-serif);font-size:1.05rem;font-weight:600;color:var(--clr-primary-dark);margin-bottom:.5rem}.feature-desc{font-size:.875rem;line-height:1.65;color:var(--clr-muted)}.cta-banner{background:linear-gradient(135deg,#5c1a1e,#7b2328 60%,#3d1515);padding:5rem 1.5rem;text-align:center}.cta-inner{max-width:600px;margin:0 auto}.cta-title{font-family:var(--font-serif);font-size:clamp(1.6rem,4vw,2.4rem);color:#fff;font-weight:600;margin-bottom:.75rem}.cta-sub{font-size:1rem;color:#ffffffb3;margin-bottom:2rem;line-height:1.6}.cta-btn{margin-top:0}.home-footer{background:var(--clr-dark);padding:2.5rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.6rem}.footer-logo{width:36px;height:36px;border-radius:50%;opacity:.6;filter:grayscale(.3)}.footer-text{font-size:.8rem;color:#ffffff73;letter-spacing:.06em}.footer-copy{font-size:.72rem;color:#ffffff40}@media(max-width:480px){.stats-strip{gap:0}.stat-item{padding:.5rem 1.25rem;border-right:none;border-bottom:1px solid rgba(255,255,255,.1);width:50%}.stat-item:nth-child(odd){border-right:1px solid rgba(255,255,255,.1)}.stat-item:nth-last-child(-n+2){border-bottom:none}.features-grid{grid-template-columns:1fr}}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#120400,#3d1515,#1a0800);position:relative;overflow:hidden;padding:2rem 1rem}.login-bg:before,.login-bg:after{content:"";position:absolute;border-radius:50%;filter:blur(90px);opacity:.15;pointer-events:none}.login-bg:before{width:400px;height:400px;background:var(--clr-accent);top:-10%;left:-10%;animation:float 10s ease-in-out infinite}.login-bg:after{width:300px;height:300px;background:var(--clr-primary);bottom:-5%;right:-5%;animation:float 8s ease-in-out infinite reverse}.login-card{position:relative;z-index:2;width:100%;max-width:400px;background:#fffffff7;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px #00000080,0 0 0 1px #c9a22726;animation:fadeInUp .6s ease both}.login-header{background:linear-gradient(135deg,#5c1a1e,#7b2328);padding:2rem 2rem 1.75rem;text-align:center}.login-logo-wrap{width:64px;height:64px;border-radius:50%;border:2px solid rgba(201,162,39,.5);padding:4px;margin:0 auto 1rem;animation:float 6s ease-in-out infinite}.login-logo{width:100%;height:100%;border-radius:50%;object-fit:cover}.login-header h1{font-family:var(--font-serif);font-size:1.8rem;font-weight:700;color:#fff;letter-spacing:.08em;margin-bottom:.3rem}.login-header p{font-size:.78rem;color:#c9a227d9;letter-spacing:.1em;text-transform:uppercase}.login-form{padding:2rem;display:flex;flex-direction:column;gap:1.1rem}.login-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:8px;padding:.65rem .9rem;font-size:.85rem;animation:fadeInUp .3s ease}.field{display:flex;flex-direction:column;gap:.4rem}.field label{font-size:.72rem;font-weight:600;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.08em}.field input{padding:.75rem 1rem;border:1.5px solid var(--clr-border);border-radius:8px;font-size:.95rem;font-family:var(--font-sans);color:var(--clr-text);background:var(--clr-bg);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.field input:focus{border-color:var(--clr-primary);box-shadow:0 0 0 3px #7b23281a;background:#fff}.login-btn{padding:.85rem;background:linear-gradient(135deg,var(--clr-primary) 0%,var(--clr-primary-dark) 100%);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:opacity var(--transition),transform var(--transition),box-shadow var(--transition);box-shadow:0 4px 14px #7b232859;margin-top:.25rem}.login-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #7b232873}.login-btn:disabled{opacity:.55;cursor:not-allowed}.login-back{text-align:center;padding-bottom:1.25rem}.login-back-btn{background:none;border:none;color:var(--clr-muted);font-size:.82rem;cursor:pointer;transition:color var(--transition)}.login-back-btn:hover{color:var(--clr-primary)}.navbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:58px;background:var(--clr-dark);border-bottom:1px solid rgba(201,162,39,.2);box-shadow:0 2px 16px #0000004d;animation:fadeIn .4s ease}.navbar-brand{display:flex;align-items:center;gap:.6rem;background:none;border:none;cursor:pointer;padding:0}.nav-logo{width:28px;height:28px;border-radius:50%;border:1px solid rgba(201,162,39,.5);object-fit:cover}.nav-brand-text{font-family:var(--font-serif);font-size:1.15rem;font-weight:600;color:var(--clr-accent);letter-spacing:.06em;white-space:nowrap}.navbar-right{display:flex;align-items:center;gap:.25rem}.navbar-link{padding:.4rem .75rem;background:none;border:none;color:#ffffffa6;font-size:.875rem;font-weight:500;cursor:pointer;border-radius:6px;transition:color var(--transition),background var(--transition);white-space:nowrap}.navbar-link:hover{color:#fff;background:#ffffff12}.navbar-link--active{color:var(--clr-accent)!important}.navbar-logout{padding:.4rem .9rem;background:#7b232866;border:1px solid rgba(123,35,40,.8);color:#fffc;font-size:.8rem;font-weight:500;border-radius:6px;cursor:pointer;transition:background var(--transition),color var(--transition);margin-left:.25rem;white-space:nowrap}.navbar-logout:hover{background:var(--clr-primary);color:#fff}@media(max-width:480px){.nav-brand-text{display:none}.navbar-link{padding:.4rem .5rem;font-size:.8rem}.navbar-logout{padding:.4rem .6rem}}.member-card{position:relative;background:var(--clr-surface);border-radius:var(--radius);border:1px solid var(--clr-border);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 2px 12px var(--clr-shadow);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;animation:fadeInUp .5s ease both}.member-card:hover{transform:translateY(-5px);box-shadow:0 14px 36px #1c0a0024;border-color:#c9a22766}.member-card--birthday{border-color:#c9a22780;box-shadow:0 2px 12px #c9a22726}.member-card--birthday:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);background:linear-gradient(135deg,rgba(201,162,39,.06) 0%,transparent 60%);pointer-events:none}.card-birthday-ribbon{background:linear-gradient(90deg,#c9a227,#e8c84a);color:#1a0800;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-align:center;padding:.3rem .75rem;text-transform:uppercase}.card-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.25rem 0}.card-photo-wrap{flex-shrink:0;width:68px;height:68px;border-radius:50%;border:2px solid var(--clr-border);padding:2px;transition:border-color .3s ease;background:var(--clr-bg)}.member-card:hover .card-photo-wrap{border-color:#c9a22780}.card-photo-wrap--birthday{border-color:var(--clr-accent)!important}.card-photo{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.card-identity{flex:1;min-width:0}.card-name{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--clr-primary-dark);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-role{font-size:.78rem;color:var(--clr-muted);margin-top:.2rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-divider{height:1px;background:linear-gradient(to right,transparent,var(--clr-border),transparent);margin:1rem 1.25rem 0}.card-info{padding:.85rem 1.25rem;display:flex;flex-direction:column;gap:.45rem;flex:1}.info-row{display:flex;align-items:flex-start;gap:.5rem;font-size:.82rem;line-height:1.4}.info-icon{flex-shrink:0;font-size:.75rem;margin-top:.1rem;opacity:.7}.info-val{color:var(--clr-text)}.info-link{color:var(--clr-primary);transition:color var(--transition)}.info-link:hover{color:var(--clr-primary-light)}.info-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.card-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-top:1px solid var(--clr-border);background:var(--clr-bg);gap:.5rem}.card-social{display:flex;gap:.4rem}.social-pill{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1px solid var(--clr-border);color:var(--clr-muted);background:var(--clr-surface);transition:background var(--transition),border-color var(--transition),color var(--transition)}.social-pill:hover{border-color:transparent}.social-pill--fb:hover{background:#1877f2;color:#fff;border-color:#1877f2}.social-pill--tw:hover{background:#000;color:#fff;border-color:#000}.social-pill--li:hover{background:#0a66c2;color:#fff;border-color:#0a66c2}.card-edit-btn{padding:.3rem .8rem;font-size:.75rem;font-weight:600;color:var(--clr-primary);background:transparent;border:1.5px solid var(--clr-primary);border-radius:20px;cursor:pointer;letter-spacing:.04em;transition:background var(--transition),color var(--transition);margin-left:auto}.card-edit-btn:hover{background:var(--clr-primary);color:#fff}.directory-page{min-height:100vh;background:var(--clr-bg)}.directory-body{max-width:1200px;margin:0 auto;padding:1.75rem 1.25rem 3rem}.birthday-banner{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#fff8e8,#fef3cd);border:1px solid rgba(201,162,39,.4);border-left:4px solid var(--clr-accent);border-radius:var(--radius-sm);padding:.85rem 1.1rem;margin-bottom:1.5rem;font-size:.9rem;color:#7a5800;animation:fadeInUp .4s ease}.bday-icon{font-size:1.2rem}.birthday-banner strong{font-weight:600}.directory-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem;animation:fadeInUp .5s ease}.dir-title{font-family:var(--font-serif);font-size:1.65rem;font-weight:600;color:var(--clr-primary-dark);letter-spacing:.01em}.dir-sub{font-size:.8rem;color:var(--clr-muted);margin-top:.2rem;letter-spacing:.04em}.dir-toolbar{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}.search-wrap{position:relative}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--clr-muted);pointer-events:none}.search-input{padding:.6rem .9rem .6rem 2.25rem;border:1.5px solid var(--clr-border);border-radius:24px;font-size:.875rem;font-family:var(--font-sans);color:var(--clr-text);background:var(--clr-surface);outline:none;width:260px;transition:border-color var(--transition),box-shadow var(--transition)}.search-input:focus{border-color:var(--clr-primary);box-shadow:0 0 0 3px #7b232814}.search-input::placeholder{color:var(--clr-muted)}.member-count{font-size:.8rem;color:var(--clr-muted);white-space:nowrap;padding:.4rem .75rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:20px}.card-grid{display:grid;grid-template-columns:1fr;gap:1.1rem}@media(min-width:540px){.card-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){.card-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1200px){.card-grid{grid-template-columns:repeat(4,1fr)}}.directory-error{display:flex;align-items:center;gap:.5rem;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:var(--radius-sm);padding:1rem 1.25rem;font-size:.9rem}.no-results{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 1rem;color:var(--clr-muted);text-align:center}.no-results-icon{font-size:2.5rem}.no-results p{font-size:.95rem}.no-results em{font-style:italic;color:var(--clr-text)}.gallery-page{min-height:100vh;background:var(--clr-bg)}.gallery-body{max-width:1200px;margin:0 auto;padding:1.75rem 1.25rem 3rem}.gallery-header{margin-bottom:1.5rem;animation:fadeInUp .4s ease}.gallery-title{font-family:var(--font-serif);font-size:1.65rem;font-weight:600;color:var(--clr-primary-dark)}.gallery-sub{font-size:.82rem;color:var(--clr-muted);margin-top:.2rem}.upload-panel{background:var(--clr-surface);border:2px dashed var(--clr-border);border-radius:var(--radius);margin-bottom:2rem;transition:border-color var(--transition);animation:fadeInUp .5s ease}.upload-panel:hover{border-color:#c9a22780}.upload-panel--has-preview{border-style:solid;border-color:var(--clr-border)}.upload-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1.5rem;cursor:pointer;gap:.5rem}.upload-icon{font-size:2.5rem}.upload-hint{font-size:.9rem;color:var(--clr-muted)}.upload-link{color:var(--clr-primary);font-weight:500;cursor:pointer}.upload-hint-sub{font-size:.75rem;color:var(--clr-muted);opacity:.7}.upload-preview-row{display:flex;gap:1.25rem;padding:1.25rem;align-items:flex-start;flex-wrap:wrap}.upload-preview-img{width:140px;height:140px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;border:1px solid var(--clr-border)}.upload-meta{flex:1;min-width:200px;display:flex;flex-direction:column;gap:.75rem;justify-content:center}.upload-caption-input{width:100%;padding:.7rem .9rem;border:1.5px solid var(--clr-border);border-radius:8px;font-size:.9rem;font-family:var(--font-sans);outline:none;transition:border-color var(--transition)}.upload-caption-input:focus{border-color:var(--clr-primary)}.upload-error{font-size:.82rem;color:#b91c1c}.upload-actions{display:flex;gap:.75rem;flex-wrap:wrap}.upload-btn{padding:.65rem 1.5rem;background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark));color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity var(--transition),transform var(--transition);box-shadow:0 3px 10px #7b23284d}.upload-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.upload-cancel{padding:.65rem 1.1rem;background:transparent;border:1.5px solid var(--clr-border);border-radius:8px;font-size:.875rem;color:var(--clr-muted);cursor:pointer;transition:border-color var(--transition),color var(--transition)}.upload-cancel:hover{border-color:var(--clr-primary);color:var(--clr-primary)}.gallery-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:8px;padding:.65rem .9rem;font-size:.85rem;margin-bottom:1rem}.gallery-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:5rem 1rem;color:var(--clr-muted);font-size:.95rem}.gallery-empty span{font-size:3rem}.photo-grid{columns:1;column-gap:1.1rem}@media(min-width:520px){.photo-grid{columns:2}}@media(min-width:800px){.photo-grid{columns:3}}@media(min-width:1100px){.photo-grid{columns:4}}.photo-card{position:relative;background:var(--clr-surface);border-radius:var(--radius);border:1px solid var(--clr-border);overflow:hidden;break-inside:avoid;margin-bottom:1.1rem;box-shadow:0 2px 8px var(--clr-shadow);transition:transform .3s ease,box-shadow .3s ease;animation:fadeInUp .5s ease both}.photo-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px #1c0a0021}.photo-img-wrap{position:relative;cursor:pointer;overflow:hidden}.photo-img{width:100%;display:block;transition:transform .4s ease}.photo-card:hover .photo-img{transform:scale(1.04)}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#1a08004d;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.photo-card:hover .photo-overlay{opacity:1}.photo-zoom{font-size:1.5rem}.photo-meta{padding:.65rem .85rem .75rem}.photo-info{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.photo-uploader{font-size:.8rem;font-weight:600;color:var(--clr-primary-dark);font-family:var(--font-serif)}.photo-date{font-size:.72rem;color:var(--clr-muted);white-space:nowrap}.photo-caption{font-size:.8rem;color:var(--clr-muted);margin-top:.3rem;line-height:1.4}.photo-delete{position:absolute;top:.5rem;right:.5rem;width:26px;height:26px;border-radius:50%;background:#0009;border:none;color:#fff;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition),background var(--transition)}.photo-card:hover .photo-delete{opacity:1}.photo-delete:hover{background:var(--clr-primary)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .2s ease}.lightbox-inner{position:relative;max-width:900px;width:100%;animation:fadeInUp .25s ease}.lightbox-img{width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius);display:block}.lightbox-info{padding:.85rem .25rem 0;display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.lightbox-uploader{font-family:var(--font-serif);font-size:.95rem;font-weight:600;color:var(--clr-accent)}.lightbox-caption{font-size:.875rem;color:#ffffffbf;flex:1}.lightbox-date{font-size:.75rem;color:#fff6;margin-left:auto}.lightbox-close{position:absolute;top:-.75rem;right:-.75rem;width:32px;height:32px;border-radius:50%;background:var(--clr-primary);border:none;color:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}.lightbox-close:hover{background:var(--clr-primary-dark)}.profile-page{min-height:100vh;background:#f4f4f8}.profile-body{max-width:720px;margin:0 auto;padding:1rem}.profile-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.back-btn{background:none;border:none;color:#e63946;font-size:.9rem;cursor:pointer;padding:0;white-space:nowrap}.profile-header h1{font-size:1.2rem;font-weight:700;color:#1a1a2e}.profile-form{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000012;padding:1.25rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:1.25rem}.password-form{margin-top:0}.form-section h2{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#888;margin-bottom:.85rem;padding-bottom:.4rem;border-bottom:1px solid #f0f0f0}.photo-row{display:flex;align-items:flex-start;gap:1.25rem}.photo-preview{width:80px;height:80px;border-radius:50%;object-fit:cover;flex-shrink:0;background:#f0f0f0}.photo-controls{display:flex;flex-direction:column;gap:.5rem}.file-input{display:none}.file-label{display:inline-block;padding:.4rem .85rem;background:#f4f4f8;border:1.5px solid #ddd;border-radius:6px;font-size:.85rem;cursor:pointer;transition:border-color .2s}.file-label:hover{border-color:#e63946}.upload-btn{padding:.4rem .85rem;background:#e63946;color:#fff;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:background .2s,opacity .2s}.upload-btn:hover:not(:disabled){background:#c0303a}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.photo-hint{font-size:.75rem;color:#aaa}.field input,.field textarea{padding:.65rem .8rem;border:1.5px solid #ddd;border-radius:7px;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s;resize:vertical}.field input:focus,.field textarea:focus{border-color:#e63946}.save-btn--secondary{background:#1a1a2e}.save-btn--secondary:hover:not(:disabled){background:#2e2e4a}.wishes-panel{margin-bottom:0}.wish-composer{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.wish-textarea{width:100%;padding:.75rem;border:1px solid var(--clr-border, #e0d8cc);border-radius:8px;font-size:.95rem;font-family:inherit;resize:vertical;background:#fff;color:#1a1a2e}.wish-textarea:focus{outline:none;border-color:#c9a227;box-shadow:0 0 0 2px #c9a22726}.wishes-empty{color:#aaa;font-size:.9rem;margin-top:.5rem}.wishes-list{display:flex;flex-direction:column;gap:.85rem;margin-top:.5rem}.wish-card{background:#fffdf7;border:1px solid #f0e8cc;border-radius:10px;padding:1rem 1.1rem;position:relative}.wish-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}.wish-from{font-weight:600;font-size:.9rem;color:#7b2328}.wish-time{font-size:.78rem;color:#aaa;margin-left:auto}.wish-delete{background:none;border:none;color:#ccc;cursor:pointer;font-size:.85rem;padding:0 .2rem;line-height:1;transition:color .15s}.wish-delete:hover{color:#e63946}.wish-message{font-size:.92rem;color:#444;line-height:1.6;margin:0}.admin-page{min-height:100vh;background:#f4f4f8}.admin-body{max-width:1100px;margin:0 auto;padding:1rem}.admin-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.admin-header h1{font-size:1.2rem;font-weight:700;color:#1a1a2e}.back-btn{background:none;border:none;color:#e63946;font-size:.9rem;cursor:pointer;padding:0}.back-btn:hover{text-decoration:underline}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.25rem}@media(min-width:600px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000012;padding:1rem;text-align:center}.stat-card--accent{border-top:3px solid #e63946}.stat-value{font-size:2rem;font-weight:700;color:#1a1a2e;line-height:1}.stat-label{font-size:.75rem;color:#888;margin-top:.3rem;text-transform:uppercase;letter-spacing:.5px}.tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.tab{padding:.5rem 1rem;background:#fff;border:1.5px solid #ddd;border-radius:7px;font-size:.85rem;cursor:pointer;transition:all .15s}.tab--active{background:#1a1a2e;border-color:#1a1a2e;color:#fff}.table-wrap{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000012;overflow-x:auto}.member-table{width:100%;border-collapse:collapse;font-size:.875rem}.member-table th{text-align:left;padding:.75rem 1rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:#888;border-bottom:1px solid #f0f0f0;white-space:nowrap}.member-table td{padding:.7rem 1rem;border-bottom:1px solid #f9f9f9;vertical-align:middle}.member-table tr:last-child td{border-bottom:none}.row--inactive td{opacity:.5}.row--warn td{background:#fff8e1}.td-email{color:#666;font-size:.8rem}.td-time{white-space:nowrap;color:#666;font-size:.8rem}.td-mono{font-family:monospace;font-size:.8rem;color:#666}.td-ua{font-size:.75rem;color:#999;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-muted{color:#ccc}.td-empty{text-align:center;color:#aaa;padding:2rem}.pill{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.72rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s}.pill:disabled{cursor:default;opacity:.6}.pill--green{background:#d4edda;color:#155724}.pill--grey{background:#e9ecef;color:#666}.pill--red{background:#fde8e9;color:#c0392b}.pill--blue{background:#dbeafe;color:#1d4ed8}.pill--event{cursor:default}.pill--login{background:#d4edda;color:#155724}.pill--logout{background:#e9ecef;color:#555}.pill--login_failed{background:#fde8e9;color:#c0392b}.pill--pending{background:#fff3cd;color:#856404}.pill--accepted{background:#d4edda;color:#155724}.pill--cancelled{background:#e9ecef;color:#666}.pill--expired,.pill--birthday{background:#fde8e9;color:#c0392b}.pill--invite{background:#dbeafe;color:#1d4ed8}.pill--password_reset{background:#f3e8ff;color:#7c3aed}.td-actions{display:flex;gap:.4rem;flex-wrap:wrap}.action-btn{padding:.25rem .6rem;font-size:.75rem;border:1px solid #ddd;border-radius:5px;background:#fff;cursor:pointer;transition:border-color .15s,color .15s}.action-btn:hover{border-color:#e63946;color:#e63946}.action-btn:disabled{opacity:.4;cursor:default}.action-btn--danger:hover{border-color:#c0392b;color:#c0392b}.reset-row td{background:#fafafa;padding:.5rem 1rem}.reset-inline{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.reset-inline input{padding:.35rem .65rem;border:1.5px solid #ddd;border-radius:6px;font-size:.85rem;outline:none}.reset-inline input:focus{border-color:#e63946}.reset-msg{font-size:.8rem;color:#155724}.add-form{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000012;padding:1.25rem;display:flex;flex-direction:column;gap:1.1rem}.field-grid{display:grid;grid-template-columns:1fr;gap:.9rem}@media(min-width:520px){.field-grid{grid-template-columns:repeat(2,1fr)}}.field{display:flex;flex-direction:column;gap:.35rem}.field label{font-size:.78rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.4px}.field input{padding:.65rem .8rem;border:1.5px solid #ddd;border-radius:7px;font-size:.95rem;outline:none;transition:border-color .2s}.field input:focus{border-color:#e63946}.msg-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724;border-radius:6px;padding:.6rem .9rem;font-size:.875rem}.msg-error{background:#fff0f0;border:1px solid #f5c6cb;color:#c0392b;border-radius:6px;padding:.6rem .9rem;font-size:.875rem}.save-btn{align-self:flex-start;padding:.75rem 1.75rem;background:#e63946;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s,opacity .2s}.save-btn:hover:not(:disabled){background:#c0303a}.save-btn:disabled{opacity:.55;cursor:not-allowed}.birthday-panel{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000012;padding:1.25rem}.birthday-intro{font-size:.875rem;color:#555;margin-bottom:1.1rem;line-height:1.5}.no-birthdays{text-align:center;color:#888;padding:2.5rem 1rem;font-size:.95rem}.birthday-list{display:flex;flex-direction:column;gap:.6rem}.birthday-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;background:#f9f9fb;border-radius:8px;border:1px solid #f0f0f0;flex-wrap:wrap}.birthday-info{display:flex;flex-direction:column;gap:.15rem}.birthday-name{font-weight:600;font-size:.95rem;color:#1a1a2e}.birthday-date{font-size:.78rem;color:#888}.birthday-actions{display:flex;align-items:center;gap:.75rem}.send-done{font-size:.85rem;color:#155724;font-weight:600}.send-error{font-size:.8rem;color:#c0392b}.settings-panel{display:flex;flex-direction:column;gap:1rem}.settings-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000012;padding:1.25rem}.settings-heading{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#888;margin-bottom:1rem;padding-bottom:.4rem;border-bottom:1px solid #f0f0f0}.settings-hint{font-size:.82rem;color:#888;margin-bottom:.9rem;line-height:1.5}.field textarea{padding:.65rem .8rem;border:1.5px solid #ddd;border-radius:7px;font-size:.95rem;font-family:inherit;outline:none;resize:vertical;transition:border-color .2s}.field textarea:focus{border-color:#e63946}.news-fields{display:flex;flex-direction:column;gap:.65rem}.log-toolbar{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:.85rem;align-items:center}.log-search{flex:1;min-width:180px;padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.88rem;background:#fff}.log-search:focus{outline:none;border-color:#c9a227}.log-filter{padding:.5rem .65rem;border:1px solid #ddd;border-radius:6px;font-size:.88rem;background:#fff;cursor:pointer}.log-search-btn{padding:.5rem 1.1rem;background:#1a1a2e;color:#fff;border:none;border-radius:6px;font-size:.88rem;cursor:pointer;transition:background .2s}.log-search-btn:hover{background:#2e2e4a}.pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:.85rem .25rem}.pagination-info{font-size:.82rem;color:#888}.pagination-controls{display:flex;gap:.25rem}.pagination-controls button{min-width:32px;height:32px;padding:0 .5rem;border:1px solid #ddd;border-radius:5px;background:#fff;font-size:.85rem;cursor:pointer;transition:background .15s,border-color .15s}.pagination-controls button:hover:not(:disabled){background:#f0e8cc;border-color:#c9a227}.pagination-controls button:disabled{opacity:.4;cursor:not-allowed}.pagination-controls button.page-active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}.nl-member-picker{margin-top:.75rem;border:1px solid #e0d8cc;border-radius:8px;padding:.75rem;background:#fffdf7}.nl-member-list{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.nl-member-row{display:flex;align-items:center;gap:.6rem;padding:.35rem .5rem;border-radius:5px;cursor:pointer;font-size:.88rem;transition:background .12s}.nl-member-row:hover{background:#f0e8cc}.nl-member-row input[type=checkbox]{cursor:pointer;accent-color:#7B2328}.nl-member-row .td-email{margin-left:auto;font-size:.78rem;color:#aaa}.invite-greeting{background:#f4f4f8;border-radius:8px;padding:.85rem 1rem;font-size:.95rem;color:#1a1a2e;line-height:1.6}.invite-greeting span{font-size:.85rem;color:#666}.invite-success{padding:2rem 1.5rem;text-align:center;display:flex;flex-direction:column;gap:.75rem;align-items:center}.invite-success-icon{font-size:3rem}.invite-success h2{font-size:1.2rem;color:#1a1a2e}.invite-success p{font-size:.875rem;color:#666;line-height:1.5}.invite-error-state{padding:2rem 1.5rem;text-align:center;color:#c0392b;font-size:.9rem;line-height:1.5}.invite-error-icon{font-size:2.5rem;margin-bottom:.75rem}.invite-loading{padding:2rem;text-align:center;color:#888;font-size:.9rem}:root{--clr-primary: #7B2328;--clr-primary-dark: #5C1A1E;--clr-primary-light: #9B3B40;--clr-accent: #C9A227;--clr-accent-light: #E8C84A;--clr-dark: #1A0800;--clr-bg: #FAF7F2;--clr-surface: #FFFFFF;--clr-border: #E8DFD0;--clr-text: #2C1A10;--clr-muted: #8C7B6B;--clr-shadow: rgba(28, 10, 0, .12);--font-serif: "Playfair Display", Georgia, serif;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius: 12px;--radius-sm: 8px;--transition: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--clr-bg);color:var(--clr-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit}img{display:block}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--clr-muted);font-family:var(--font-serif);font-size:1rem;letter-spacing:.5px}.loading-screen:before{content:"";width:36px;height:36px;border:2px solid var(--clr-border);border-top-color:var(--clr-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}
