/*
Theme Name:  Hornemann Fotografie
Theme URI:   https://anne-hornemann.de
Author:      Anne Hornemann
Description: Altrosa · Burgund · Gold. Alle Inhalte über Design → Anpassen editierbar.
Version:     3.0.0
Requires at least: 6.2
Tested up to: 6.5
Requires PHP: 8.0
License:     GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hornemann
Tags: photography, portfolio, one-column, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, theme-options, translation-ready
*/

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  --burg-deep:  #3A0F18;
  --burg:       #4E1520;
  --burg-mid:   #6B2030;
  --burg-light: #8A3040;
  --rose:       #E8C5BC;
  --rose-deep:  #D4AFA6;
  --rose-muted: #C09890;
  --cream:      #F2EDE4;
  --cream-deep: #EDE5D6;
  --gold:       #BF8C3A;
  --gold-light: #D4A85C;
  --ink:        #1A1410;
  --f-display:  'Cormorant Garamond', Georgia, serif;
  --f-body:     'Crimson Pro', Georgia, serif;
  --f-ui:       'Jost', sans-serif;
  --gap:        clamp(1.5rem, 5vw, 5rem);
  --ease:       cubic-bezier(0.16,1,0.3,1);
}

/* ─── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--f-body);font-size:1.125rem;line-height:1.7;overflow-x:hidden}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
address{font-style:normal}

/* ─── LAYOUT ─────────────────────────────────────────────── */
.wrap       {max-width:1280px;margin-inline:auto;padding-inline:var(--gap)}
.wrap-narrow{max-width:860px; margin-inline:auto;padding-inline:var(--gap)}
.wrap-wide  {max-width:1440px;margin-inline:auto;padding-inline:var(--gap)}

/* ─── TYPE ───────────────────────────────────────────────── */
.disp{font-family:var(--f-display);font-weight:300;line-height:1.0;letter-spacing:-.03em}
em.gold{color:var(--gold)}

.lbl{font-family:var(--f-ui);font-size:.68rem;font-weight:500;
     letter-spacing:.24em;text-transform:uppercase}

.eyebrow{display:flex;align-items:center;gap:.875rem;margin-bottom:1.5rem}
.eyebrow::before{content:'';display:block;width:26px;height:1px;
                  background:currentColor;opacity:.35}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-ui);
     font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
     padding:.8rem 1.8rem;border:1px solid transparent;cursor:pointer;
     border-radius:2px;transition:all .4s var(--ease);white-space:nowrap}
.btn-burg  {background:var(--burg); border-color:var(--burg); color:var(--rose)}
.btn-burg:hover{background:var(--burg-mid);border-color:var(--burg-mid)}
.btn-dark  {background:transparent;border-color:rgba(78,21,32,.3);color:var(--burg)}
.btn-dark:hover{border-color:var(--burg)}
.btn-light {background:transparent;border-color:rgba(232,197,188,.35);color:var(--rose)}
.btn-light:hover{border-color:var(--rose)}
.btn-gold  {background:transparent;border-color:var(--gold);color:var(--gold)}
.btn-gold:hover{background:var(--gold);color:var(--cream)}

/* ─── SECTIONS ───────────────────────────────────────────── */
.s-rose      {background:var(--rose);     color:var(--burg)}
.s-rose-deep {background:var(--rose-deep);color:var(--burg)}
.s-burg      {background:var(--burg);     color:var(--rose)}
.s-burg-deep {background:var(--burg-deep);color:var(--rose)}
.s-cream     {background:var(--cream);    color:var(--ink)}
.s-cream-deep{background:var(--cream-deep);color:var(--ink)}

.pad   {padding:5rem var(--gap)}
.pad-sm{padding:3.5rem var(--gap)}

.top-rule::before{content:'';display:block;position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(to right,transparent,rgba(232,197,188,.18),transparent)}
.top-rule{position:relative}

/* ─── HEADER / NAV ───────────────────────────────────────── */
.site-header{
  position:fixed;inset-inline:0;top:0;z-index:200;
  padding:1.5rem var(--gap);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s var(--ease),padding .3s var(--ease)}
.site-header.scrolled{
  background:rgba(78,21,32,.96);
  backdrop-filter:blur(18px);
  padding:1rem var(--gap);
  border-bottom:1px solid rgba(232,197,188,.1)}

.site-logo{font-family:var(--f-display);font-size:1.75rem;font-weight:300;
           letter-spacing:-.03em;color:var(--burg);line-height:1;transition:color .3s}
.site-logo small{display:block;font-family:var(--f-ui);font-size:.58rem;
                  letter-spacing:.26em;text-transform:uppercase;
                  color:var(--gold);margin-top:.1em}
.site-header.scrolled .site-logo{color:var(--rose)}
/* light pages (hochzeit/familie) */
body.lh .site-logo{color:var(--ink)}
body.lh .site-header.scrolled .site-logo{color:var(--rose)}

.primary-nav{display:flex;align-items:center;gap:2.5rem}
.primary-nav a{font-family:var(--f-ui);font-size:.68rem;font-weight:400;
               letter-spacing:.2em;text-transform:uppercase;
               color:rgba(78,21,32,.5);position:relative;transition:color .3s}
.site-header.scrolled .primary-nav a{color:rgba(232,197,188,.5)}
body.lh .primary-nav a{color:rgba(26,20,16,.45)}
.primary-nav a:hover{color:var(--burg)}
.site-header.scrolled .primary-nav a:hover{color:var(--rose)}
body.lh .primary-nav a:hover{color:var(--ink)}
.primary-nav a::after{content:'';position:absolute;bottom:-3px;left:0;
  width:0;height:1px;background:var(--gold);transition:width .4s var(--ease)}
.primary-nav a:hover::after{width:100%}
.nav-cta{color:var(--gold)!important;border-bottom:1px solid rgba(191,140,58,.4);padding-bottom:1px}
.nav-cta::after{display:none!important}

/* Hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;
            background:none;border:none;cursor:pointer;padding:6px;z-index:300}
.nav-toggle span{display:block;width:26px;height:1px;background:var(--burg);
                  transition:all .3s var(--ease);transform-origin:center}
.site-header.scrolled .nav-toggle span{background:var(--rose)}
body.lh .nav-toggle span{background:var(--ink)}
.nav-toggle[aria-expanded=true] span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle[aria-expanded=true] span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

@media(max-width:860px){
  .nav-toggle{display:flex}
  .primary-nav{
    display:none;position:fixed;inset:0;
    background:rgba(78,21,32,.97);
    flex-direction:column;align-items:center;justify-content:center;
    gap:2.5rem;z-index:250}
  .primary-nav.open{display:flex}
  .primary-nav a{font-family:var(--f-display)!important;font-size:2.5rem!important;
                  letter-spacing:-.02em!important;font-weight:300!important;
                  color:var(--rose)!important;text-transform:none!important}
  .nav-cta{color:var(--gold)!important;font-size:1.875rem!important}}

/* ─── HERO ───────────────────────────────────────────────── */
.hero{
  background:var(--rose);min-height:100svh;
  display:flex;align-items:flex-end;
  padding:8rem var(--gap) 5rem;
  position:relative;overflow:hidden}
.hero__ring{
  position:absolute;border-radius:50%;border:1px solid rgba(78,21,32,.06);
  pointer-events:none}
.hero__ring-1{width:500px;height:500px;bottom:-120px;right:-120px}
.hero__ring-2{width:320px;height:320px;bottom:-60px;right:-60px}
.hero__title{font-family:var(--f-display);font-size:clamp(3.5rem,9vw,9rem);
             font-weight:300;line-height:.95;letter-spacing:-.04em;
             color:var(--burg);margin-bottom:2rem}
.hero__title em{font-style:italic;color:var(--gold)}
.hero__sub{font-family:var(--f-display);font-size:clamp(1rem,2vw,1.375rem);
           font-weight:300;font-style:italic;line-height:1.55;
           color:rgba(78,21,32,.6);max-width:46ch;margin-bottom:2.5rem}
.hero__ctas{display:flex;gap:.875rem;flex-wrap:wrap}
.hero__aside{position:absolute;right:var(--gap);bottom:5rem;
             display:flex;flex-direction:column;align-items:center;gap:3rem}
.hero__loc{writing-mode:vertical-rl;transform:rotate(180deg);
           font-family:var(--f-ui);font-size:.6rem;letter-spacing:.28em;
           text-transform:uppercase;color:rgba(78,21,32,.25)}
.hero__line{width:1px;height:56px;
            background:linear-gradient(to bottom,rgba(78,21,32,.3),transparent);
            animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.2;transform:scaleY(.7)}50%{opacity:.7;transform:scaleY(1)}}

/* ─── STATS BAND ─────────────────────────────────────────── */
.stats-band{display:grid;grid-template-columns:repeat(4,1fr);
            gap:1px;background:rgba(78,21,32,.12)}
.stat{padding:2.5rem 2rem;display:flex;flex-direction:column;gap:.5rem}
.stat__n{font-family:var(--f-display);font-size:clamp(2.5rem,4vw,4.5rem);
         font-weight:300;line-height:1;letter-spacing:-.04em;color:var(--burg)}
.stat__l{opacity:.45}

/* ─── SERVICES LIST ──────────────────────────────────────── */
.services-title{font-family:var(--f-display);
  font-size:clamp(2.5rem,5vw,5.5rem);font-weight:300;
  line-height:1;letter-spacing:-.03em;color:var(--rose);margin-bottom:3rem}
.services-title em{font-style:italic;color:var(--gold)}

.svc-row{border-top:1px solid rgba(232,197,188,.1)}
.svc-row:last-child{border-bottom:1px solid rgba(232,197,188,.1)}
.svc-link{display:grid;grid-template-columns:2.5rem 1fr 1fr auto;
          align-items:center;gap:2rem;padding:1.4rem 0;
          color:inherit;transition:opacity .3s}
.svc-link:hover{opacity:.65}
.svc-num{font-family:var(--f-display);font-size:1.25rem;font-style:italic;color:var(--gold)}
.svc-name{font-family:var(--f-display);font-size:clamp(1.4rem,2.5vw,2.25rem);
          font-weight:300;letter-spacing:-.02em;color:var(--rose)}
.svc-desc{font-size:.8rem;color:rgba(232,197,188,.4);line-height:1.6}
.svc-cta{color:var(--gold)}

/* ─── SPLIT LAYOUT ───────────────────────────────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:1px}
.split-img{overflow:hidden;background:var(--rose-deep);aspect-ratio:3/4}
.split-img img{width:100%;height:100%;object-fit:cover;
               transition:transform .8s var(--ease)}
.split-img:hover img{transform:scale(1.04)}
.split-img-ph{width:100%;height:100%;min-height:420px;
              display:flex;align-items:center;justify-content:center}
.split-body{padding:5rem var(--gap);display:flex;flex-direction:column;
            justify-content:center;gap:1.5rem}
.split-num{color:var(--gold)}
.split-title{font-family:var(--f-display);
  font-size:clamp(2rem,4vw,3.5rem);font-weight:300;
  line-height:1;letter-spacing:-.03em}
.split-text{font-size:1rem;line-height:1.8;opacity:.65;max-width:40ch}

/* ─── PRICING ────────────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);
              gap:1px;background:rgba(26,20,16,.1)}
.pkg{background:var(--cream);padding:2.75rem 2.25rem;
     display:flex;flex-direction:column;gap:1.25rem}
.pkg--hot{background:var(--burg);margin-top:-1.5rem;margin-bottom:-1.5rem;
          padding-top:4.25rem;padding-bottom:4.25rem}
.pkg__badge{display:inline-block;background:var(--gold);color:var(--cream);
            padding:.3rem 1rem;border-radius:20px;margin-bottom:.5rem}
.pkg__num{font-family:var(--f-display);font-size:1.75rem;font-style:italic;
          color:var(--gold);font-weight:300;line-height:1}
.pkg__name{font-family:var(--f-display);font-size:1.875rem;font-weight:300;
           line-height:1;letter-spacing:-.02em;color:var(--ink)}
.pkg--hot .pkg__name{color:var(--rose)}
.pkg__dur{color:var(--gold)}
.pkg__price{font-family:var(--f-display);font-size:3rem;font-weight:300;
            letter-spacing:-.03em;color:var(--ink);line-height:1}
.pkg--hot .pkg__price{color:var(--rose)}
.pkg__list{flex:1;display:flex;flex-direction:column;gap:.6rem}
.pkg__list li{font-size:.9rem;line-height:1.5;padding-left:1.25rem;
              position:relative;color:rgba(26,20,16,.65)}
.pkg--hot .pkg__list li{color:rgba(232,197,188,.65)}
.pkg__list li::before{content:'—';position:absolute;left:0;color:var(--gold);font-size:.75rem}
.pkg__foot{display:flex;align-items:center;justify-content:space-between;
           padding-top:1.5rem;border-top:1px solid rgba(26,20,16,.1);
           cursor:pointer;color:var(--ink);transition:opacity .3s}
.pkg--hot .pkg__foot{border-top-color:rgba(232,197,188,.15);color:var(--rose)}
.pkg__foot:hover{opacity:.6}

/* ─── FAQ ────────────────────────────────────────────────── */
.faq-item{border-top:1px solid rgba(26,20,16,.1)}
.s-burg .faq-item,.s-burg-deep .faq-item{border-top-color:rgba(232,197,188,.1)}
.faq-item:last-child{border-bottom:1px solid rgba(26,20,16,.1)}
.s-burg .faq-item:last-child,.s-burg-deep .faq-item:last-child{border-bottom-color:rgba(232,197,188,.1)}
.faq-q{display:flex;align-items:center;justify-content:space-between;
       gap:2rem;padding:1.375rem 0;cursor:pointer;user-select:none;
       font-family:var(--f-display);font-size:clamp(1.1rem,2vw,1.5rem);
       font-weight:300;letter-spacing:-.01em;color:var(--ink);transition:color .3s}
.s-burg .faq-q,.s-burg-deep .faq-q{color:var(--rose)}
.faq-q:hover,.faq-item.open .faq-q{color:var(--gold)}
.faq-icon{font-size:1.5rem;color:var(--gold);flex-shrink:0;
          transition:transform .4s var(--ease);line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{overflow:hidden;max-height:0;transition:max-height .5s var(--ease)}
.faq-item.open .faq-a{max-height:400px}
.faq-a p{padding-bottom:1.75rem;font-size:1rem;line-height:1.85;
         color:rgba(26,20,16,.6)}
.s-burg .faq-a p,.s-burg-deep .faq-a p{color:rgba(232,197,188,.5)}

/* ─── PULLQUOTE ──────────────────────────────────────────── */
.pullquote{border-left:2px solid var(--gold);padding:.5rem 0 .5rem 2rem;
           max-width:900px;position:relative}
.pullquote__mark{position:absolute;left:-.5rem;top:-1.5rem;
                  font-family:var(--f-display);font-size:8rem;font-weight:300;
                  line-height:.8;opacity:.1;user-select:none;pointer-events:none}
.pullquote__text{font-family:var(--f-display);
  font-size:clamp(1.5rem,3vw,2.5rem);font-weight:300;font-style:italic;
  line-height:1.25;letter-spacing:-.02em;margin-bottom:1rem}
.pullquote__attr{color:var(--gold)}

/* ─── GALLERY GRID ───────────────────────────────────────── */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.gal-item{aspect-ratio:3/4;overflow:hidden;position:relative}
.gal-item--wide{grid-column:span 2;aspect-ratio:16/9}
.gal-item img{width:100%;height:100%;object-fit:cover;
              transition:transform .8s var(--ease),filter .8s var(--ease)}
.gal-item:hover img{transform:scale(1.05);filter:brightness(.85)}
.gal-cap{position:absolute;bottom:0;left:0;right:0;
         padding:1.5rem 1.25rem 1.25rem;
         background:linear-gradient(transparent,rgba(58,15,24,.72));
         opacity:0;transform:translateY(6px);transition:all .4s var(--ease)}
.gal-item:hover .gal-cap{opacity:1;transform:translateY(0)}
.gal-cap-name{font-family:var(--f-display);font-size:1.25rem;
              font-style:italic;font-weight:300;color:var(--rose)}

/* ─── CONTACT FORM ───────────────────────────────────────── */
.cf{display:flex;flex-direction:column;gap:1.25rem;max-width:620px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.cf-field{display:flex;flex-direction:column;gap:.5rem}
.cf-field label{color:rgba(232,197,188,.4)}
.cf-field input,.cf-field textarea,.cf-field select{
  background:rgba(232,197,188,.06);
  border:1px solid rgba(232,197,188,.15);
  color:var(--rose);font-family:var(--f-body);font-size:1rem;
  padding:.875rem 1rem;border-radius:2px;outline:none;width:100%;
  transition:border-color .3s,background .3s}
.cf-field input:focus,.cf-field textarea:focus{
  border-color:rgba(191,140,58,.5);background:rgba(232,197,188,.09)}
.cf-field textarea{min-height:140px;resize:vertical}
.cf-field input::placeholder,.cf-field textarea::placeholder{color:rgba(232,197,188,.25)}
.cf-feedback{font-family:var(--f-ui);font-size:.8rem;padding:.75rem 1rem;border-radius:2px}
.cf-feedback.ok{background:rgba(191,140,58,.15);color:var(--gold);border:1px solid rgba(191,140,58,.3)}
.cf-feedback.err{background:rgba(232,197,188,.1);color:var(--rose-deep);border:1px solid rgba(232,197,188,.2)}

/* ─── FOOTER ─────────────────────────────────────────────── */
.site-footer{background:var(--burg-deep);padding:5rem var(--gap) 2.5rem;
             border-top:1px solid rgba(232,197,188,.07)}
.footer-g{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
          gap:3rem;margin-bottom:4rem}
.footer-name{font-family:var(--f-display);font-size:2.25rem;font-weight:300;
             letter-spacing:-.03em;color:var(--rose);margin-bottom:.25rem}
.footer-tag{font-family:var(--f-display);font-style:italic;
            font-size:1.125rem;color:var(--gold);margin-bottom:1.25rem}
.footer-desc{font-size:.9rem;line-height:1.75;color:rgba(232,197,188,.35);max-width:36ch}
.footer-col h4{margin-bottom:1.25rem;opacity:.6;color:var(--rose)}
.footer-col a,.footer-col p{display:block;font-size:.9rem;line-height:1.75;
  color:rgba(232,197,188,.35);transition:color .3s;margin-bottom:.1rem}
.footer-col a:hover{color:var(--gold)}
.footer-bot{display:flex;justify-content:space-between;align-items:center;
            padding-top:2rem;border-top:1px solid rgba(232,197,188,.08);
            color:rgba(232,197,188,.2)}
.footer-bot a{color:rgba(232,197,188,.2);transition:color .3s}
.footer-bot a:hover{color:var(--gold)}

/* ─── REVEAL ANIMATION ───────────────────────────────────── */
.rev{opacity:0;transform:translateY(30px);
     transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rev.in{opacity:1;transform:translateY(0)}
.rev-d1{transition-delay:.1s}
.rev-d2{transition-delay:.22s}
.rev-d3{transition-delay:.36s}
.rev-d4{transition-delay:.52s}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1100px){
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .footer-g{grid-template-columns:1fr 1fr}
  .svc-link{grid-template-columns:2rem 1fr auto;gap:1.25rem}
  .svc-desc{display:none}}
@media(max-width:860px){
  .split{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .pkg--hot{margin:0;padding:2.75rem 2.25rem}
  .gal{grid-template-columns:repeat(2,1fr)}
  .cf-row{grid-template-columns:1fr}
  .hero__aside{display:none}}
@media(max-width:600px){
  .stats-band{grid-template-columns:1fr 1fr}
  .footer-g{grid-template-columns:1fr}
  .footer-bot{flex-direction:column;gap:.75rem;text-align:center}}
