/*
Theme Name: Küstenzeit
Theme URI: https://example.de/
Author: Michael
Description: Schlankes, individuelles Theme für das Apartmenthaus Küstenzeit (Ostsee). Startseite als Ankündigung plus News-Bereich. Aufbau vorbereitet für spätere Wohnungs- und Buchungserweiterung.
Version: 0.1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: kuestenzeit
*/

/* =================================================================
   SCHRIFTEN – DSGVO: lokal hosten, NICHT von Google laden.
   Lege die woff2-Dateien in /assets/fonts/ und aktiviere die Blöcke.
   Empfehlung (google-webfonts-helper.herokuapp.com):
     - Cormorant Garamond 400, 500, 600  (Display)
     - Inter 400, 500, 600              (Fließtext)
   Bis dahin greifen die Fallbacks (Georgia / System-Sans).
================================================================= */
/*
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:500;font-display:swap;
  src:url("assets/fonts/cormorant-garamond-v16-latin-500.woff2") format("woff2");}
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:600;font-display:swap;
  src:url("assets/fonts/cormorant-garamond-v16-latin-600.woff2") format("woff2");}
@font-face{font-family:"Inter";font-style:normal;font-weight:400;font-display:swap;
  src:url("assets/fonts/inter-v13-latin-regular.woff2") format("woff2");}
@font-face{font-family:"Inter";font-style:normal;font-weight:500;font-display:swap;
  src:url("assets/fonts/inter-v13-latin-500.woff2") format("woff2");}
@font-face{font-family:"Inter";font-style:normal;font-weight:600;font-display:swap;
  src:url("assets/fonts/inter-v13-latin-600.woff2") format("woff2");}
*/

:root{
  --cream:#FDFEFE;
  --paper:#FFFFFF;
  --navy:#244A6B;
  --ink:#16324A;
  --sand:#C2A06A;
  --sand-deep:#A8854F;
  --sage:#8E9A6C;
  --seafoam:#9DB9C9;
  --text:#2A3744;
  --muted:#5E6B74;
  --line:#E7DFD2;

  --font-display:"Cormorant Garamond","Cormorant",Georgia,"Times New Roman",serif;
  --font-body:"Inter","Helvetica Neue",Arial,system-ui,sans-serif;

  --wrap:1160px;
  --narrow:760px;
  --gap:clamp(1.5rem,4vw,3rem);
  --radius:3px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--cream);color:var(--text);
  font-family:var(--font-body);font-size:17px;line-height:1.75;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--navy);text-decoration:none;}
a:hover{color:var(--sand-deep);}
:focus-visible{outline:2px solid var(--navy);outline-offset:3px;}

h1,h2,h3{font-family:var(--font-display);font-weight:600;color:var(--ink);
  line-height:1.08;letter-spacing:.005em;margin:0 0 .5em;}
p{margin:0 0 1.1em;}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,2.5rem);}
.narrow{max-width:var(--narrow);margin-inline:auto;}

/* Eyebrow – aus dem Logo abgeleitete getrackte Versalien */
.eyebrow{font-family:var(--font-body);font-size:.78rem;font-weight:600;
  letter-spacing:.26em;text-transform:uppercase;color:var(--sand-deep);
  margin:0 0 1rem;}

/* Buttons */
.btn{display:inline-block;font-family:var(--font-body);font-weight:600;
  font-size:.95rem;letter-spacing:.02em;padding:.85em 1.8em;border-radius:var(--radius);
  border:1.5px solid var(--navy);background:var(--navy);color:#fff;cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease;}
.btn:hover{background:transparent;color:var(--navy);}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7);}
.btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff;}

/* =================== HEADER =================== */
.site-header{position:sticky;top:0;z-index:50;background:var(--cream);
  border-bottom:1px solid var(--line);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;
  gap:0;min-height:72px;}
.site-logo{flex-shrink:0;display:flex;align-items:center;}
.site-logo img,.custom-logo-link,.custom-logo{display:block;margin:0!important;padding:0;}
.site-logo img,.custom-logo{height:82px;width:auto;margin:20px 0}
.site-logo .text-logo{font-family:var(--font-display);font-size:1.7rem;color:var(--ink);}
.main-nav{margin-left:auto;}
.main-nav ul{list-style:none;display:flex;gap:1.5rem;margin:0;padding:0;align-items:center;}
.main-nav a{font-size:.88rem;font-weight:500;letter-spacing:.02em;color:var(--ink);white-space:nowrap;}
.main-nav a:hover{color:var(--sand-deep);}
.nav-toggle{display:none;border:0;background:none;cursor:pointer;padding:.4rem;margin-left:auto;}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--ink);margin:5px 0;
  transition:transform .25s ease,opacity .25s ease;}

/* =================== HERO =================== */
.hero{position:relative;height:68vh;max-height:560px;display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;border-radius:var(--radius);}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center 38%;
  border-radius:var(--radius);}
.hero__overlay{border-radius:var(--radius);}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(22,50,74,.20) 0%,rgba(22,50,74,.10) 30%,rgba(22,50,74,.75) 100%);
  border-radius:var(--radius);}
.hero__inner{position:relative;width:100%;
  padding:clamp(2rem,5vw,3.5rem) clamp(1.5rem,4vw,2.5rem);}
.hero-wrap{max-width:var(--wrap);margin-inline:auto;
  padding-inline:clamp(1.25rem,5vw,2.5rem);padding-block:1.5rem 2rem;}
.hero .eyebrow{color:var(--sand);}
.hero__house{font-family:var(--font-body);font-size:.8rem;font-weight:600;
  letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:.6rem;}
.hero__title{font-size:clamp(3.4rem,10vw,7rem);color:#fff;margin:0;font-weight:500;
  text-shadow:0 1px 24px rgba(13,32,48,.35);}
.hero__sub{font-family:var(--font-display);font-size:clamp(1.3rem,3vw,1.9rem);
  color:#fff;font-weight:400;margin:.4rem 0 1.6rem;max-width:30ch;}
.hero__cta{display:flex;gap:.9rem;flex-wrap:wrap;align-items:center;}

/* Wellen-Signature (aus dem Logo) */
.wave{display:block;color:var(--sand);}
.hero .wave{margin:.2rem 0 1.4rem;}
.section-wave{color:var(--seafoam);margin:0 auto;display:block;}

/* =================== SECTIONS =================== */
.section{padding:clamp(3.5rem,9vw,7rem) 0;}
.section--paper{background:var(--paper);border-block:1px solid var(--line);}
.section__head{text-align:center;margin-bottom:clamp(2rem,5vw,3.5rem);}
.section__head h2{font-size:clamp(2.1rem,4.5vw,3.2rem);}
.lead{font-size:1.18rem;color:var(--muted);}

.intro{text-align:center;}
.intro p{font-size:1.12rem;}

/* =================== NEWS =================== */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:clamp(1.4rem,3vw,2.2rem);}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s ease,box-shadow .25s ease;}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(22,50,74,.5);}
.card__media{aspect-ratio:16/10;overflow:hidden;background:var(--line);}
.card__media img{width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;}
.card:hover .card__media img{transform:scale(1.05);}
.card__body{padding:1.5rem 1.6rem 1.8rem;display:flex;flex-direction:column;gap:.6rem;flex:1;}
.card__date{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sand-deep);font-weight:600;}
.card__title{font-family:var(--font-display);font-size:1.55rem;line-height:1.15;margin:0;}
.card__title a{color:var(--ink);}
.card__title a:hover{color:var(--navy);}
.card__excerpt{color:var(--muted);font-size:.97rem;margin:0;}
.card__more{margin-top:auto;font-weight:600;font-size:.9rem;color:var(--navy);}

.center{text-align:center;}
.mt-2{margin-top:2.5rem;}

/* =================== EINZELBEITRAG / SEITE =================== */
.entry{padding:clamp(2.5rem,7vw,5rem) 0;}
.entry__header{text-align:center;margin-bottom:2.5rem;}
.entry__date{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sand-deep);font-weight:600;margin-bottom:.8rem;}
.entry__title{font-size:clamp(2.2rem,5vw,3.4rem);}
.entry__featured{margin:0 0 2.5rem;border-radius:var(--radius);overflow:hidden;}
.entry__content{font-size:1.08rem;}
.entry__content a{color:var(--sand-deep);}
.entry__content a:hover{color:var(--navy);}
.section--related{background:var(--paper);border-top:1px solid var(--line);
  padding:clamp(3rem,7vw,5rem) 0;}
.entry__content h2{font-size:1.9rem;margin-top:2em;}
.entry__content h3{font-size:1.45rem;margin-top:1.6em;}
.entry__content img{border-radius:var(--radius);margin:1.6em 0;}
.entry__content blockquote{border-left:3px solid var(--sand);margin:1.6em 0;
  padding:.4em 0 .4em 1.4em;color:var(--muted);font-family:var(--font-display);
  font-size:1.35rem;font-style:italic;}
.back-link{display:inline-block;margin-top:2.5rem;font-weight:600;}

/* =================== FOOTER =================== */
.site-footer{background:var(--ink);color:rgba(255,255,255,.78);
  padding:clamp(3rem,6vw,4.5rem) 0 2rem;font-size:80%}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3rem;
  align-items:start;}
.site-footer h4{font-family:var(--font-display);color:#fff;font-size:1.35rem;
  font-weight:600;margin:0 0 .8rem;}
.site-footer a{color:rgba(255,255,255,.78);}
.site-footer a:hover{color:var(--sand);}
.footer-logo{margin-bottom:1rem;}
.footer-logo img{width:150px;height:auto;}
.footer-menu ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:2.5rem;
  padding-top:1.4rem;font-size:.84rem;color:rgba(255,255,255,.55);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;}

/* =================== RESPONSIV =================== */
@media (max-width:820px){
  .footer-grid{grid-template-columns:1fr;gap:2rem;}
  .nav-toggle{display:block;}
  .main-nav{position:absolute;top:100%;left:0;right:0;background:var(--cream);
    border-bottom:1px solid var(--line);display:none;}
  .main-nav.is-open{display:block;}
  .main-nav ul{flex-direction:column;gap:0;padding:.5rem 0;}
  .main-nav li{border-top:1px solid var(--line);}
  .main-nav a{display:block;padding:1rem clamp(1.25rem,5vw,2.5rem);}
}

/* =================== MOTION =================== */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(18px);
    animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards;}
  .reveal.d1{animation-delay:.08s;}
  .reveal.d2{animation-delay:.18s;}
  .reveal.d3{animation-delay:.28s;}
  @keyframes rise{to{opacity:1;transform:none;}}
}

/* =================== STARTSEITE =================== */
.hero__overlay{position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(22,50,74,.18) 0%,rgba(22,50,74,.72) 100%);}
.hero__title{font-size:clamp(1.9rem,4.5vw,3.4rem);line-height:1.12;color:#fff;margin:0 0 .8rem;
  font-weight:500;text-shadow:0 2px 28px rgba(13,32,48,.4);}
.btn--hero{background:var(--sand);color:#fff;border-color:var(--sand);font-size:1rem;
  padding:.85rem 2rem;}
.btn--hero:hover{background:var(--sand-deep);border-color:var(--sand-deep);}
.btn--nav{background:var(--sand);color:#fff!important;border:none;padding:.5rem 1.2rem;
  border-radius:var(--radius);font-size:.88rem;font-weight:600;}
.btn--nav:hover{background:var(--sand-deep);}
.btn--ghost-ink{background:transparent;color:var(--ink);border:2px solid var(--ink);
  padding:.65rem 1.6rem;border-radius:var(--radius);font-weight:600;display:inline-block;
  transition:background .2s,color .2s;}
.btn--ghost-ink:hover{background:var(--ink);color:#fff;}
.menu-item--cta{margin-left:.5rem;}

.hero__badge{position:absolute;top:1.5rem;right:2.5rem;width:100px;height:100px;
  opacity:.85;}

.features-bar{background:var(--paper);padding:3rem 0;
  border-bottom:1px solid var(--line);}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2.5rem;}
.feature{text-align:center;padding:.5rem;}
.feature__icon{width:48px;height:48px;margin:0 auto .8rem;color:var(--navy);}
.feature__title{font-family:var(--font-display);font-size:1.1rem;color:var(--ink);
  font-weight:600;margin:0 0 .4rem;}
.feature__text{font-size:.9rem;color:var(--muted);margin:0;}

.intro-section{padding:clamp(3.5rem,8vw,6rem) 0;}
.intro-grid{display:grid;grid-template-columns:1fr;max-width:680px;}
.intro-grid .eyebrow{margin-bottom:.5rem;}
.intro-grid h2{font-size:clamp(2rem,4vw,2.8rem);margin:0 0 1.2rem;}

@media (max-width:820px){
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .hero__badge{width:70px;height:70px;top:1.2rem;right:1.2rem;}
}
@media (max-width:480px){
  .features-grid{grid-template-columns:1fr;}
}

#content{background:#f5f5f5;}

/* =================== NINJA FORMS =================== */
.nf-form-cont{max-width:680px;margin:0 auto;padding:2.5rem 0;}
.nf-form-title h3{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);
  color:var(--ink);margin-bottom:1.5rem;}
.nf-field-label label{font-family:var(--font-body);font-weight:600;font-size:.9rem;
  color:var(--ink);letter-spacing:.02em;margin-bottom:.4rem;display:block;}
.nf-field-element input[type=text],
.nf-field-element input[type=email],
.nf-field-element input[type=tel],
.nf-field-element textarea{
  width:100%;border:1.5px solid var(--line);border-radius:var(--radius);
  background:#fff;color:var(--text);font-family:var(--font-body);font-size:1rem;
  padding:.75rem 1rem;transition:border-color .2s ease,box-shadow .2s ease;
  appearance:none;-webkit-appearance:none;}
.nf-field-element input:focus,
.nf-field-element textarea:focus{
  outline:none;border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(36,74,107,.12);}
.nf-field-element textarea{min-height:160px;resize:vertical;}
.nf-field-container{margin-bottom:1.4rem;}
.nf-error .nf-field-element input,
.nf-error .nf-field-element textarea{border-color:#c0392b;}
.nf-error-msg{font-size:.82rem;color:#c0392b;margin-top:.3rem;}
.nf-field-element input[type=submit],
.nf-form-cont input[type=submit],
input#nf-field-submit,
.nf-form-cont .submit-container input{
  display:inline-block;font-family:var(--font-body);font-weight:600;
  font-size:.95rem;letter-spacing:.03em;padding:.85em 2.2em;
  border-radius:var(--radius);border:none;
  background:var(--navy);color:#fff;cursor:pointer;
  transition:background .2s ease;}
.nf-field-element input[type=submit]:hover,
.nf-form-cont input[type=submit]:hover{background:var(--sand-deep);}
.nf-response-msg{background:#eaf4ee;border:1px solid #a8d5b5;border-radius:var(--radius);
  padding:1rem 1.2rem;color:#1e5c35;font-size:.95rem;margin-top:1rem;}
.ninja-forms-req-symbol{color:var(--sand-deep);}
p.nf-before-field{font-size:.88rem;color:var(--muted);margin-bottom:1.5rem;}

/* WordPress-Standardklassen */
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);}
.aligncenter{margin-inline:auto;}
.wp-caption-text{font-size:.85rem;color:var(--muted);text-align:center;}
