/* ═══════════════════════════════════════════
   Emil & Gyrithe — 40 års fødselsdag
   style.css
   ═══════════════════════════════════════════ */ 

/* ── VARIABLES ── */
:root {
  --navy:        #0d1b2e;
  --navy-mid:    #132033;
  --navy-light:  #1a2d44;
  --navy-card:   #0f1e30;
  --gold:        #c9a84c;
  --gold-bright: #e8c96a;
  --gold-pale:   rgba(201,168,76,0.10);
  --gold-border: rgba(201,168,76,0.30);
  --gold-glow:   rgba(232,201,106,0.16);
  --white:       #f5f0e8;
  --muted:       #8fa3b8;
  --text:        #dde8f0;
  --green:       #3a7a52;
}

/* ── RESET & BASE ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  background: var(--navy);
  color: var(--text);
  font-family: 'Raleway', sans-serif;
  font-weight: 300;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Star field background */
body::before {
  content:'';
  position:fixed; inset:0;
  background-image:
    radial-gradient(1px 1px at 10% 15%, rgba(232,201,106,0.55) 0%, transparent 100%),
    radial-gradient(1px 1px at 25% 45%, rgba(232,201,106,0.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 40%  8%, rgba(255,255,255,0.45) 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 30%, rgba(232,201,106,0.45) 0%, transparent 100%),
    radial-gradient(1px 1px at 70% 60%, rgba(255,255,255,0.28) 0%, transparent 100%),
    radial-gradient(1px 1px at 82% 22%, rgba(232,201,106,0.55) 0%, transparent 100%),
    radial-gradient(1px 1px at 92% 75%, rgba(255,255,255,0.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 15% 80%, rgba(232,201,106,0.28) 0%, transparent 100%),
    radial-gradient(2px 2px at 35% 65%, rgba(232,201,106,0.20) 0%, transparent 100%),
    radial-gradient(2px 2px at 75% 40%, rgba(232,201,106,0.18) 0%, transparent 100%);
  pointer-events:none;
  z-index:0;
}

/* ── ANIMATIONS ── */
@keyframes fadeUp  { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes shimmer { 0%,100%{opacity:.7} 50%{opacity:1} }
@keyframes spin    { to{transform:rotate(360deg)} }

/* ── HERO ── */
.hero { position:relative; overflow:hidden; z-index:1; }

.hero-banner {
  width:100%; display:block;
  max-height:480px; object-fit:cover; object-position:center;
}

.hero-overlay {
  position:absolute; bottom:0; left:0; right:0; height:55%;
  background:linear-gradient(to top, var(--navy) 0%, transparent 100%);
}

/* ── NAV ── */
.nav-wrap {
  position:sticky; top:0; z-index:100;
  background:rgba(13,27,46,0.97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--gold-border);
}

.nav-inner {
  display:flex; justify-content:center;
  overflow-x:auto; scrollbar-width:none;
  max-width:1000px; margin:0 auto; padding:0 12px;
}
.nav-inner::-webkit-scrollbar { display:none; }

.tab-btn {
  flex-shrink:0; padding:16px 18px;
  background:none; border:none; border-bottom:2px solid transparent;
  cursor:pointer;
  font-family:'Cinzel',serif; font-size:0.66rem; font-weight:400;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--muted);
  transition:color .25s, border-color .25s; white-space:nowrap;
}
.tab-btn:hover  { color:var(--gold-bright); }
.tab-btn.active { color:var(--gold); border-bottom-color:var(--gold); }

/* ── PANELS ── */
.panels {
  position:relative; z-index:1;
  max-width:860px; margin:0 auto; padding:56px 24px 100px;
}

.panel { display:none; animation:fadeUp .45s ease both; }
.panel.active { display:block; }

/* ── TYPOGRAPHY ── */
.section-title {
  font-family:'Cinzel',serif;
  font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:600; letter-spacing:.08em; color:var(--gold);
  text-align:center; margin-bottom:10px;
}

.ornament {
  display:flex; align-items:center; justify-content:center;
  gap:14px; margin:14px 0 36px;
}
.ornament::before,
.ornament::after {
  content:''; flex:1; max-width:120px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-border),transparent);
}
.ornament span {
  font-family:'Playfair Display',serif; font-style:italic;
  color:var(--muted); font-size:.9rem; letter-spacing:.06em;
}

.section-sub {
  text-align:center; color:var(--muted); font-size:.92rem;
  line-height:1.75; margin-bottom:40px;
  max-width:560px; margin-left:auto; margin-right:auto;
}

.gold-rule {
  border:none; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-border),transparent);
  margin:44px 0;
}

/* ── WELCOME ── */
.welcome-body {
  font-family:'Playfair Display',serif; font-size:1.2rem;
  line-height:1.9; color:var(--text);
  max-width:620px; margin:0 auto; text-align:center;
}
.welcome-body p  { margin-bottom:22px; }
.welcome-body em { color:var(--gold); font-style:italic; }

.contact-pill {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold-pale); border:1px solid var(--gold-border);
  padding:10px 22px; font-family:'Raleway',sans-serif; font-size:.88rem;
  color:var(--gold); text-decoration:none; letter-spacing:.06em;
  transition:background .2s, color .2s; margin-top:8px;
}
.contact-pill:hover { background:var(--gold-border); color:var(--white); }

/* ── INFO CARDS ── */
.info-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:16px; margin-bottom:32px;
}

.info-card {
  background:var(--navy-card); border:1px solid var(--gold-border);
  padding:26px 22px; position:relative; overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.info-card:hover { border-color:var(--gold); box-shadow:0 0 24px var(--gold-glow); }
.info-card::before {
  content:''; position:absolute; top:0; left:0;
  width:100%; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.info-card .label {
  font-family:'Cinzel',serif; font-size:.62rem;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); margin-bottom:10px;
}
.info-card .value {
  font-family:'Playfair Display',serif; font-size:1.3rem;
  color:var(--white); line-height:1.35;
}
.info-card .detail { font-size:.82rem; color:var(--muted); margin-top:7px; line-height:1.55; }

.map-link {
  display:inline-flex; align-items:center; gap:7px;
  color:var(--gold); text-decoration:none;
  font-family:'Cinzel',serif; font-size:.7rem;
  letter-spacing:.15em; text-transform:uppercase;
  border-bottom:1px solid var(--gold-border); padding-bottom:2px;
  transition:color .2s, border-color .2s; margin-top:10px;
}
.map-link:hover { color:var(--gold-bright); border-color:var(--gold); }

/* ── GOOGLE FORM ── */
.form-wrapper { background:var(--navy-card); border:1px solid var(--gold-border); overflow:hidden; }
.form-wrapper iframe { display:block; width:100%; min-height:920px; }

/* ── GIFTS ── */
.gifts-note {
  background:var(--gold-pale); border:1px solid var(--gold-border);
  padding:18px 24px; font-size:.88rem; color:var(--muted);
  line-height:1.75; margin-bottom:32px; text-align:center;
}
.gifts-note strong { color:var(--gold); }

.gifts-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:18px; margin-bottom:0;
}

.gift-card {
  background:var(--navy-card); border:1px solid var(--gold-border); overflow:hidden;
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.gift-card:hover {
  border-color:var(--gold); box-shadow:0 0 28px var(--gold-glow); transform:translateY(-3px);
}

.gift-img {
  width:100%; height:170px; background:var(--navy-light);
  display:flex; align-items:center; justify-content:center;
  font-size:3.2rem; border-bottom:1px solid var(--gold-border);
}
.gift-img img { width:100%; height:100%; object-fit:cover; }

.gift-body { padding:18px; }
.gift-body h3 { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--white); margin-bottom:6px; }
.gift-body p  { font-size:.82rem; color:var(--muted); line-height:1.55; margin-bottom:12px; }

.gift-link {
  font-family:'Cinzel',serif; font-size:.66rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold); text-decoration:none;
  border-bottom:1px solid var(--gold-border); padding-bottom:1px;
}
.gift-link:hover { color:var(--gold-bright); }

/* ── SHARED BOX (chat + hilsner) ── */
.shared-box { background:var(--navy-card); border:1px solid var(--gold-border); overflow:hidden; }

.shared-box-header {
  background:rgba(201,168,76,0.08); border-bottom:1px solid var(--gold-border);
  padding:14px 20px; display:flex; align-items:center; gap:12px;
}
.shared-box-header h3 {
  font-family:'Playfair Display',serif; font-size:1rem;
  font-style:italic; color:var(--white);
}

.badge {
  font-family:'Cinzel',serif; font-size:.62rem;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--green); color:#d4edda; padding:3px 9px;
}

/* ── ENTRIES LIST (chat) ── */
.entries-list {
  padding:20px; min-height:160px; max-height:360px; overflow-y:auto;
  display:flex; flex-direction:column; gap:14px;
  scrollbar-width:thin; scrollbar-color:var(--gold-border) transparent;
}

.entry-item { display:flex; flex-direction:column; gap:4px; }
.entry-meta  { font-size:.7rem; color:var(--muted); letter-spacing:.05em; }
.entry-bubble {
  background:var(--navy-light); border:1px solid var(--gold-border);
  padding:10px 16px; font-size:.9rem; line-height:1.6; color:var(--text);
}

/* ── HILSNER CARDS ── */
.hilsner-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px; margin-bottom:32px;
}

.hilsen-card {
  background:var(--navy-card); border:1px solid var(--gold-border);
  padding:22px 24px; position:relative; overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.hilsen-card:hover { border-color:var(--gold); box-shadow:0 0 20px var(--gold-glow); }
.hilsen-card::after {
  content:'"'; position:absolute; bottom:-14px; right:14px;
  font-family:'Playfair Display',serif; font-size:6rem;
  color:rgba(201,168,76,0.07); line-height:1; pointer-events:none;
}
.hilsen-card p {
  font-family:'Playfair Display',serif; font-size:1.05rem;
  font-style:italic; line-height:1.8; color:var(--text);
  position:relative; z-index:1;
}
.hilsen-from {
  margin-top:12px; font-family:'Cinzel',serif;
  font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; color:var(--gold);
}
.hilsen-time {
  color:var(--muted); font-size:.58rem;
  margin-left:8px; letter-spacing:.04em; text-transform:none;
}

/* ── INPUT AREA ── */
.input-area { border-top:1px solid var(--gold-border); padding:16px 20px; display:flex; flex-direction:column; gap:10px; }
.input-row  { display:flex; gap:10px; flex-wrap:wrap; }

.f-name, .f-text, .f-msg {
  background:var(--navy); border:1px solid var(--gold-border);
  padding:10px 14px; font-family:'Raleway',sans-serif; font-size:.86rem;
  color:var(--white); outline:none; transition:border-color .2s;
}
.f-name:focus, .f-text:focus, .f-msg:focus { border-color:var(--gold); }
.f-name { width:150px; flex-shrink:0; }
.f-text { flex:1; min-width:120px; }
.f-msg  { width:100%; min-height:90px; resize:vertical; font-family:'Playfair Display',serif; font-style:italic; font-size:.95rem; }

::placeholder { color:var(--muted); }

.send-btn {
  background:var(--gold); color:var(--navy); border:none;
  padding:10px 24px; cursor:pointer;
  font-family:'Cinzel',serif; font-size:.68rem; font-weight:600;
  letter-spacing:.15em; text-transform:uppercase;
  transition:background .2s; align-self:flex-end;
}
.send-btn:hover    { background:var(--gold-bright); }
.send-btn:disabled { opacity:.5; cursor:not-allowed; }

/* ── STATUS MESSAGES ── */
.status-msg {
  font-size:.78rem; color:var(--muted);
  padding:0 20px 12px; min-height:22px;
  display:flex; align-items:center; gap:8px;
}
.spinner {
  width:13px; height:13px;
  border:2px solid var(--gold-border); border-top-color:var(--gold);
  border-radius:50%; animation:spin .7s linear infinite; flex-shrink:0;
}
.s-ok  { color:var(--gold); }
.s-err { color:#e07070; }

/* ── CONFIG BANNER (shown before Firebase is set up) ── */
.config-banner {
  background:rgba(201,168,76,0.1); border:1px solid var(--gold-border);
  padding:20px 24px; margin-bottom:24px;
  font-size:.88rem; line-height:1.75; color:var(--muted);
}
.config-banner strong {
  color:var(--gold-bright); display:block; margin-bottom:6px;
  font-family:'Cinzel',serif; letter-spacing:.1em; font-size:.8rem;
}
.config-banner code {
  background:rgba(255,255,255,0.07); padding:2px 6px;
  font-size:.82rem; color:var(--white);
}

/* ── PROGRAM TIMELINE ── */
.program-list { display:flex; flex-direction:column; }

.program-item { display:flex; position:relative; }
.program-item:not(:last-child)::after {
  content:''; position:absolute; left:72px; top:44px; bottom:0;
  width:1px; background:var(--gold-border);
}

.prog-time {
  width:84px; flex-shrink:0; padding:22px 16px 22px 0;
  font-family:'Cinzel',serif; font-size:.75rem; letter-spacing:.1em;
  color:var(--gold); text-align:right;
}
.prog-dot {
  width:16px; flex-shrink:0;
  display:flex; flex-direction:column; align-items:center; padding-top:28px;
}
.prog-dot::before {
  content:''; width:8px; height:8px; border-radius:50%;
  background:var(--gold); box-shadow:0 0 8px var(--gold-glow); flex-shrink:0;
}
.prog-content { flex:1; padding:20px 0 20px 20px; }
.prog-content h3 { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--white); margin-bottom:4px; }
.prog-content p  { font-size:.83rem; color:var(--muted); line-height:1.6; }

/* ── VIDEO ── */
.video-box  { margin-top:52px; }
.video-label { display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.video-label h3 { font-family:'Playfair Display',serif; font-size:1.4rem; font-style:italic; color:var(--white); }
.video-label .tag {
  font-family:'Cinzel',serif; font-size:.6rem; letter-spacing:.15em; text-transform:uppercase;
  background:rgba(201,168,76,0.12); border:1px solid var(--gold-border); color:var(--gold); padding:4px 10px;
}
.video-embed {
  position:relative; padding-bottom:56.25%; height:0;
  overflow:hidden; border:1px solid var(--gold-border);
}
.video-embed iframe { position:absolute; inset:0; width:100%; height:100%; }

/* ── EMPTY STATE ── */
.empty-state {
  text-align:center; color:var(--muted);
  font-family:'Playfair Display',serif; font-style:italic;
  font-size:1.05rem; padding:28px 0;
}

/* ── FOOTER ── */
footer {
  position:relative; z-index:1; text-align:center;
  padding:28px 24px 48px; border-top:1px solid var(--gold-border);
  color:var(--muted); font-family:'Cinzel',serif;
  font-size:.68rem; letter-spacing:.2em; text-transform:uppercase;
}
footer .g { color:var(--gold); animation:shimmer 3s infinite; }

/* ── RESPONSIVE ── */
@media (max-width:600px) {
  .panels       { padding:36px 16px 80px; }
  .info-grid    { grid-template-columns:1fr 1fr; }
  .hero-banner  { max-height:220px; }
  .f-name       { width:100%; }
}
