@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Lora:ital,wght@0,400;0,500;1,400&display=swap');

:root {
  --dark: #4A3728;
  --med: #8B7355;
  --light: #B8A48C;
  --accent: #C8956C;
  --bg: #F5EDE3;
  --bgW: #EDE2D4;
  --white: #FFFAF5;
  --fMain: 'Cormorant Garamond', serif;
  --fBody: 'Lora', serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: var(--fBody); color: var(--dark); background: linear-gradient(170deg, var(--bg) 0%, var(--bgW) 60%, #D8CAB8 100%); min-height: 100vh; }
button { cursor: pointer; }
input, textarea, select { font-family: var(--fBody); }

@keyframes flicker { 0%{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}100%{opacity:.8;transform:scale(.97)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)} }
@keyframes gentlePulse { 0%,100%{opacity:.65}50%{opacity:1} }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-thumb { background: rgba(139,115,85,0.15); border-radius: 3px; }

/* Login */
.login-wrap { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px; }
.login-card { text-align: center; padding: 32px 36px; border-radius: 20px; max-width: 380px; width: 100%; background: rgba(255,255,255,0.5); backdrop-filter: blur(20px); box-shadow: 0 10px 40px rgba(74,55,40,0.08); border: 1px solid rgba(139,115,85,0.07); animation: fadeUp 0.8s ease-out; }
.login-card h1 { font-family: var(--fMain); font-size: 2rem; font-weight: 300; color: var(--dark); letter-spacing: 0.05em; margin-top: 16px; }
.login-card .name { font-family: var(--fMain); font-size: 1.25rem; font-weight: 500; color: var(--dark); margin: 4px 0; }
.login-card .subtitle { font-family: var(--fBody); font-size: 0.875rem; font-style: italic; color: var(--med); opacity: 0.7; }
.login-card .dates { font-size: 0.75rem; color: var(--med); opacity: 0.45; font-family: var(--fBody); margin: 4px 0; }
.login-card .private-msg { font-size: 0.75rem; color: var(--med); opacity: 0.35; font-family: var(--fBody); margin: 20px 0; }

.divider { width: 50px; height: 1px; margin: 16px auto; background: linear-gradient(to right, transparent, var(--light), transparent); }
.divider-sm { width: 32px; height: 1px; margin: 10px auto; background: linear-gradient(to right, transparent, var(--light), transparent); }

.input { width: 100%; padding: 12px 16px; font-size: 0.875rem; border-radius: 10px; border: 1px solid rgba(139,115,85,0.12); background: rgba(255,255,255,0.65); color: var(--dark); outline: none; text-align: center; }
.input:focus { border-color: rgba(139,115,85,0.3); }
.input-left { text-align: left; }
textarea.input { resize: none; text-align: left; }

.btn { width: 100%; padding: 12px; font-size: 0.875rem; font-family: var(--fMain); font-weight: 500; letter-spacing: 0.1em; border: none; border-radius: 10px; background: linear-gradient(135deg, var(--med), var(--accent)); color: var(--white); transition: opacity 0.2s, box-shadow 0.2s; }
.btn:hover { opacity: 0.92; box-shadow: 0 4px 16px rgba(139,115,85,0.2); }

.error { font-size: 0.75rem; color: #C07060; margin-top: 8px; }

/* Candle */
.candle { display: flex; flex-direction: column; align-items: center; width: 20px; }
.candle-flame { width: 7px; height: 14px; border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%; background: radial-gradient(ellipse at 50% 60%, #FFF5CC, #FFD54F 30%, #F5A623 60%, transparent 100%); box-shadow: 0 0 8px 4px rgba(245,166,35,0.3), 0 0 18px 8px rgba(245,166,35,0.1); }
.candle-wick { width: 1px; height: 5px; background: #555; margin-top: -1px; }
.candle-body { width: 16px; height: 32px; border-radius: 2px 2px 3px 3px; background: linear-gradient(to bottom, #FFF8ED, #F0E2CC, #E8D5B8); box-shadow: inset -1px 0 3px rgba(0,0,0,0.04), 0 2px 6px rgba(0,0,0,0.06); }

/* Lang toggle */
.lang-toggle { display: flex; gap: 4px; padding: 2px; border-radius: 20px; background: rgba(139,115,85,0.08); }
.lang-btn { padding: 4px 12px; border-radius: 16px; font-size: 0.75rem; font-family: var(--fMain); border: none; background: transparent; color: var(--light); letter-spacing: 0.04em; transition: all 0.2s; }
.lang-btn.active { background: var(--white); color: var(--dark); font-weight: 600; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }

/* Header */
.site-header { text-align: center; padding: 20px 16px 10px; }
.site-header h1 { font-family: var(--fMain); font-size: 1.25rem; font-weight: 300; color: var(--dark); letter-spacing: 0.05em; }
.site-header .name { font-family: var(--fMain); font-size: 1rem; font-weight: 500; color: var(--dark); }
.site-header .subtitle { font-family: var(--fBody); font-size: 0.75rem; font-style: italic; color: var(--med); opacity: 0.5; }

/* Nav */
.site-nav { position: sticky; top: 0; z-index: 40; padding: 6px 8px; background: rgba(245,237,227,0.88); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(139,115,85,0.06); }
.nav-inner { display: flex; justify-content: center; gap: 2px; max-width: 640px; margin: 0 auto; overflow-x: auto; }
.nav-btn { display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 6px 8px; border-radius: 8px; border: none; background: transparent; color: var(--light); font-family: var(--fMain); font-size: 10px; font-weight: 400; letter-spacing: 0.04em; transition: all 0.2s; white-space: nowrap; }
.nav-btn .icon { font-size: 16px; }
.nav-btn.active { background: rgba(139,115,85,0.1); color: var(--dark); font-weight: 600; }

/* Content */
.content { padding: 24px 16px; max-width: 720px; margin: 0 auto; }
.section-title { text-align: center; margin-bottom: 28px; }
.section-title h2 { font-family: var(--fMain); font-size: 1.5rem; font-weight: 300; color: var(--dark); letter-spacing: 0.04em; }
.section-title p { font-family: var(--fBody); font-size: 0.875rem; font-style: italic; color: var(--med); opacity: 0.55; }

/* Cards */
.card { padding: 20px; border-radius: 16px; background: rgba(255,255,255,0.48); border: 1px solid rgba(139,115,85,0.07); }
.card + .card { margin-top: 12px; }

/* Gallery */
.gallery-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; max-width: 560px; margin: 0 auto; }
@media (min-width: 640px) { .gallery-grid { grid-template-columns: repeat(3, 1fr); } }
.gallery-item { border-radius: 12px; overflow: hidden; cursor: pointer; border: 2px solid rgba(139,115,85,0.06); aspect-ratio: 4/3; transition: transform 0.2s, box-shadow 0.2s; }
.gallery-item:hover { transform: scale(1.02); box-shadow: 0 4px 20px rgba(0,0,0,0.08); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; filter: sepia(0.06); }

/* Home grid */
.home-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 20px 0; }
.home-grid-item { border-radius: 12px; overflow: hidden; cursor: pointer; aspect-ratio: 1; border: 2px solid rgba(139,115,85,0.06); }
.home-grid-item img { width: 100%; height: 100%; object-fit: cover; filter: sepia(0.08); transition: transform 0.3s; }
.home-grid-item:hover img { transform: scale(1.05); }

/* Hero image */
.hero-img { border-radius: 16px; overflow: hidden; margin-bottom: 24px; box-shadow: 0 4px 24px rgba(0,0,0,0.08); border: 3px solid rgba(139,115,85,0.08); }
.hero-img img { width: 100%; height: 240px; object-fit: cover; filter: sepia(0.12) brightness(0.95); }
@media (min-width: 640px) { .hero-img img { height: 300px; } }

/* Candles display */
.hearts-wrap { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; padding: 24px; border-radius: 16px; background: rgba(74,55,40,0.03); min-height: 100px; margin-bottom: 24px; }
.heart-item { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 8px; min-width: 65px; animation: fadeUp 0.5s ease-out; }
.heart-item .h-name { font-size: 0.75rem; font-family: var(--fMain); color: var(--med); font-weight: 500; text-align: center; }
.heart-item .h-msg { font-size: 0.7rem; font-family: var(--fBody); color: var(--med); opacity: 0.4; font-style: italic; text-align: center; max-width: 80px; }

/* Info cards */
.info-card { display: flex; gap: 16px; }
.info-card .icon { font-size: 1.5rem; margin-top: 2px; flex-shrink: 0; }
.info-card h3 { font-family: var(--fMain); font-size: 1rem; font-weight: 500; color: var(--dark); margin-bottom: 8px; }
.info-card p { font-size: 0.875rem; color: var(--med); font-family: var(--fBody); margin: 4px 0; }

/* RSVP buttons */
.rsvp-toggle { display: flex; gap: 8px; }
.rsvp-opt { flex: 1; padding: 10px; font-size: 0.875rem; border-radius: 10px; border: 1px solid rgba(139,115,85,0.12); background: rgba(255,255,255,0.65); color: var(--med); font-family: var(--fBody); transition: all 0.2s; }
.rsvp-opt.active { background: linear-gradient(135deg, var(--med), var(--accent)); color: var(--white); border: none; font-weight: 500; }

/* Share buttons */
.share-btn { width: 100%; display: flex; align-items: center; gap: 16px; padding: 14px 16px; border-radius: 14px; text-align: left; border: none; transition: all 0.2s; position: relative; }
.share-btn:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
.share-btn .s-icon { font-size: 1.5rem; }
.share-btn .s-title { font-size: 0.875rem; font-family: var(--fMain); font-weight: 500; color: var(--dark); display: block; }
.share-btn .s-desc { font-size: 0.75rem; font-family: var(--fBody); color: var(--med); opacity: 0.5; display: block; }
.share-btn.wa { background: rgba(37,211,102,0.05); border: 1px solid rgba(37,211,102,0.1); }
.share-btn.fb { background: rgba(59,89,152,0.05); border: 1px solid rgba(59,89,152,0.1); }
.share-btn.link { background: rgba(139,115,85,0.05); border: 1px solid rgba(139,115,85,0.1); }

.tooltip { position: absolute; right: 16px; top: 50%; transform: translateY(-50%); font-size: 0.75rem; padding: 3px 10px; border-radius: 12px; background: var(--accent); color: white; }

/* Guestbook entry */
.gb-entry { animation: fadeUp 0.4s ease-out; }
.gb-entry p { font-size: 0.875rem; color: var(--dark); font-family: var(--fBody); line-height: 1.7; margin-bottom: 10px; }
.gb-entry .meta { display: flex; justify-content: space-between; align-items: center; }
.gb-entry .author { font-size: 0.75rem; font-family: var(--fMain); color: var(--accent); font-weight: 500; }
.gb-entry .date { font-size: 0.75rem; font-family: var(--fBody); color: var(--med); opacity: 0.35; }

/* Label */
.field-label { font-size: 0.7rem; font-family: var(--fMain); color: var(--med); letter-spacing: 0.05em; font-weight: 500; margin-bottom: 6px; display: block; }

/* Lightbox */
.lightbox { position: fixed; inset: 0; z-index: 50; display: flex; align-items: center; justify-content: center; background: rgba(15,10,5,0.9); backdrop-filter: blur(12px); }
.lightbox img { max-height: 82vh; max-width: 88vw; border-radius: 8px; object-fit: contain; box-shadow: 0 0 60px rgba(0,0,0,0.4); }
.lb-btn { position: absolute; top: 50%; transform: translateY(-50%); font-size: 3rem; color: #E8DCCE; opacity: 0.4; background: none; border: none; transition: opacity 0.2s; }
.lb-btn:hover { opacity: 0.9; }
.lb-close { position: absolute; top: 16px; right: 24px; font-size: 1.25rem; color: #E8DCCE; opacity: 0.4; background: none; border: none; transition: opacity 0.2s; }
.lb-close:hover { opacity: 0.9; }
.lb-counter { position: absolute; bottom: 20px; font-size: 0.875rem; color: #E8DCCE; opacity: 0.3; }

/* Quote */
.quote-box { padding: 20px; border-radius: 14px; background: rgba(255,255,255,0.35); text-align: center; margin-top: 28px; }
.quote-box p { font-family: var(--fMain); font-size: 1rem; font-style: italic; font-weight: 300; color: var(--dark); }

/* Footer */
.site-footer { text-align: center; padding: 24px 16px; }
.site-footer p { font-size: 0.75rem; color: var(--med); font-family: var(--fBody); opacity: 0.25; }

/* Success */
.success-card { text-align: center; padding: 32px; }
.success-card .check { font-size: 2.5rem; margin-bottom: 12px; }
.success-card h3 { font-family: var(--fMain); font-size: 1.25rem; font-weight: 300; color: var(--dark); margin-bottom: 8px; }
.success-card p { font-size: 0.875rem; color: var(--med); font-family: var(--fBody); }

.note { text-align: center; font-size: 0.75rem; font-style: italic; color: var(--med); opacity: 0.3; font-family: var(--fBody); margin-top: 16px; }
.count-box { margin-top: 12px; padding: 10px; border-radius: 14px; background: rgba(255,255,255,0.3); text-align: center; }
.count-box p { font-size: 0.75rem; color: var(--med); font-family: var(--fBody); }
.max-w { max-width: 480px; margin-left: auto; margin-right: auto; }
.max-w-sm { max-width: 360px; margin-left: auto; margin-right: auto; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mb-5 { margin-bottom: 20px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.text-center { text-align: center; }
.hidden { display: none; }
.space-y > * + * { margin-top: 12px; }

/* Admin extras */
.del-btn { position:absolute; top:2px; right:2px; width:18px; height:18px; border-radius:50%; background:rgba(192,112,96,0.15); color:#C07060; font-size:10px; border:none; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity 0.2s; cursor:pointer; }
.heart-item, .gb-entry, .card { position:relative; }
.heart-item:hover .del-btn, .gb-entry:hover .del-btn, .card:hover .del-btn { opacity:1; }
.del-btn-lg { padding:4px 12px; border-radius:8px; background:rgba(192,112,96,0.1); color:#C07060; font-size:0.7rem; border:1px solid rgba(192,112,96,0.15); cursor:pointer; transition:all 0.2s; white-space:nowrap; flex-shrink:0; }
.del-btn-lg:hover { background:rgba(192,112,96,0.2); }
.admin-tab { padding:6px 14px; border-radius:8px; font-size:0.75rem; font-family:var(--fMain); border:1px solid rgba(139,115,85,0.12); background:rgba(255,255,255,0.5); color:var(--med); cursor:pointer; transition:all 0.2s; letter-spacing:0.03em; }
.admin-tab.active { background:linear-gradient(135deg, var(--med), var(--accent)); color:var(--white); border-color:transparent; font-weight:600; }

@keyframes heartPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }
