/* Gästebuch Odd Inge 60 — festlich-elegant, warmes Maritim-Gold (NO/Schiff-Bezug) */
:root{
  --bg:#faf6ee;
  --paper:#fffdf8;
  --ink:#23303a;
  --muted:#5c6b76;
  --gold:#c79a4b;
  --gold-deep:#a87f33;
  --navy:#1f3a4d;
  --line:#e7ddc9;
  --shadow:0 8px 30px rgba(31,58,77,.10);
  --font-display:"Cormorant Garamond",Georgia,serif;
  --font-body:"Inter",system-ui,sans-serif;
  --font-script:"Dancing Script",cursive;
  --radius:14px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--font-body);line-height:1.55;
  background-image:radial-gradient(circle at 20% -10%,#fff6e3 0,transparent 45%),
                   radial-gradient(circle at 90% 0,#f3ead4 0,transparent 40%);
}

/* Sprachleiste */
.langbar{display:flex;gap:.25rem;justify-content:center;flex-wrap:wrap;
  padding:.6rem;position:sticky;top:0;z-index:5;
  background:rgba(250,246,238,.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.langbar button{
  border:1px solid transparent;background:none;cursor:pointer;
  font-family:var(--font-body);font-size:.85rem;color:var(--muted);
  padding:.3rem .7rem;border-radius:999px}
.langbar button.active{background:var(--navy);color:#fff}

/* Hero */
.hero{text-align:center;padding:3rem 1rem 1.5rem}
.hero .kicker{letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);
  font-size:.8rem;font-weight:600;margin:0 0 .4rem}
.hero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2.4rem,7vw,4rem);
  margin:.2rem 0;color:var(--navy);line-height:1.05}
.hero .date{font-family:var(--font-display);font-style:italic;font-size:1.4rem;color:var(--gold-deep);margin:.2rem 0}

.wrap{max-width:640px;margin:0 auto;padding:0 1rem 4rem}
.intro{font-family:var(--font-display);font-size:1.25rem;text-align:center;color:var(--ink);margin:.5rem 0 1rem}
.reqhint{font-size:.82rem;color:var(--muted);text-align:center;margin:0 0 1.5rem}

/* Karten */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.4rem 1.3rem;margin:0 0 1.3rem}
.card h2{font-family:var(--font-display);font-size:1.55rem;font-weight:600;color:var(--navy);
  margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--gold);display:inline-block}

.field{display:block;margin:0 0 1rem}
.field>span,.field>.lbl,.lbl,legend{display:block;font-weight:500;font-size:.92rem;margin:0 0 .35rem;color:var(--ink)}
.req{color:var(--gold-deep);font-style:normal}
input[type=text],input[type=email],textarea,select{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:9px;padding:.6rem .7rem;transition:border-color .15s,box-shadow .15s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(199,154,75,.18)}
textarea{resize:vertical}
.sig-input{font-family:var(--font-script);font-size:1.3rem}

fieldset{border:0;padding:0;margin:0 0 1rem}
.radio{display:flex;align-items:center;gap:.55rem;font-weight:400;margin:.3rem 0;cursor:pointer}
.radio input{accent-color:var(--gold-deep);width:1.05rem;height:1.05rem}
.radio span{margin:0}

.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}
@media(max-width:460px){.three{grid-template-columns:1fr}}

.hint{display:block;color:var(--muted);font-size:.8rem;margin-top:.3rem}
.photo-preview{margin-top:.7rem}
.photo-preview img{max-width:180px;border-radius:10px;border:1px solid var(--line);box-shadow:var(--shadow)}

button[type=submit],#again-btn{
  display:block;width:100%;font-family:var(--font-body);font-weight:600;font-size:1.05rem;
  color:#fff;background:linear-gradient(135deg,var(--gold) 0,var(--gold-deep) 100%);
  border:0;border-radius:999px;padding:.95rem;cursor:pointer;box-shadow:var(--shadow);
  transition:transform .1s,filter .15s}
button[type=submit]:hover,#again-btn:hover{filter:brightness(1.05)}
button[type=submit]:active{transform:scale(.99)}
button[disabled]{opacity:.6;cursor:wait}

.err{color:#b3261e;background:#fdecea;border:1px solid #f5c6c2;border-radius:9px;padding:.7rem;font-size:.9rem;text-align:center}
.hidden{display:none!important}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* Danke-Overlay */
.thanks{position:fixed;inset:0;background:rgba(31,58,77,.55);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:20}
.thanks-box{background:var(--paper);border-radius:18px;box-shadow:var(--shadow);
  padding:2.4rem 2rem;text-align:center;max-width:420px}
.thanks-box h2{font-family:var(--font-display);font-size:2rem;color:var(--navy);margin:0 0 .6rem}
.thanks-box p{color:var(--muted);margin:0 0 1.4rem}

.foot{text-align:center;color:var(--gold-deep);font-family:var(--font-display);font-style:italic;
  font-size:1.1rem;padding:2rem 1rem 3rem}
