/*
Theme Name: Somann's Hundepension
Theme URI: https://www.somanns.de
Author: Somann's Hundepension
Author URI: https://www.somanns.de
Description: Modernes, verspieltes One-Page-Theme fuer die Bayerische Hundeschule & Tierpension Somann in Ruppmannsburg bei Thalmaessing. Mobile-first, Forstgruen/Gold-Palette, Galerie, Kontaktformular. Speziell fuer diesen Familienbetrieb gestaltet.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: somanns
Tags: business, one-page, custom-colors, custom-menu, featured-images, responsive
*/

/* ================================================================
   DESIGN TOKENS
   ================================================================ */
:root{
  --green-900:#13322a;
  --green-700:#1d4435;
  --green-600:#2a5a47;
  --green-500:#3f7059;
  --gold:#c9a45c;
  --gold-deep:#a9843a;
  --cream:#f7f2e7;
  --cream-2:#efe7d6;
  --card:#fffdf7;
  --ink:#262219;
  --muted:#6f685a;
  --line:#e3d9c3;

  --maxw:1180px;
  --radius:22px;
  --radius-lg:34px;
  --shadow:0 18px 40px -22px rgba(19,50,42,.45);
  --shadow-soft:0 10px 30px -18px rgba(19,50,42,.35);

  --ff-display:"Fraunces",Georgia,"Times New Roman",serif;
  --ff-body:"Nunito",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

/* ================================================================
   RESET / BASE
   ================================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--ff-body);
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  line-height:1.7;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-700);text-decoration:none}
a:hover{color:var(--gold-deep)}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:600;line-height:1.12;color:var(--green-900);margin:0 0 .5em}
h1{font-size:clamp(2.3rem,1.6rem + 3.4vw,4rem);letter-spacing:-.5px}
h2{font-size:clamp(1.85rem,1.3rem + 2.4vw,2.9rem)}
h3{font-size:clamp(1.25rem,1.05rem + .8vw,1.55rem)}
p{margin:0 0 1em}
.wrap{width:min(100% - 2.2rem,var(--maxw));margin-inline:auto}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;z-index:999;background:#fff;padding:.6rem 1rem;border-radius:10px}

:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:6px}

/* eyebrow label */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ff-body);font-weight:800;
  text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;
  color:var(--gold-deep);margin:0 0 .9rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block;border-radius:2px}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--ff-body);font-weight:800;font-size:1rem;
  padding:.82rem 1.5rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease;
  line-height:1;
}
.btn-primary{background:var(--gold);color:var(--green-900);box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--gold-deep);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-ghost:hover{background:#fff;color:var(--green-900);transform:translateY(-2px)}
.btn-green{background:var(--green-700);color:#fff}
.btn-green:hover{background:var(--green-900);color:#fff;transform:translateY(-2px)}

/* ================================================================
   HEADER / NAV
   ================================================================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(247,242,231,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:box-shadow .25s ease,border-color .25s ease,background .25s ease;
}
.site-header.is-scrolled{box-shadow:0 8px 24px -18px rgba(19,50,42,.5);border-color:var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{height:52px;width:auto;border-radius:8px}
.brand .brand-text{display:none}
.nav-toggle{
  display:inline-flex;flex-direction:column;gap:5px;justify-content:center;
  width:46px;height:46px;border:0;background:var(--green-700);border-radius:12px;cursor:pointer;padding:0 12px
}
.nav-toggle span{height:2.5px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.main-nav{position:fixed;inset:0 0 0 auto;width:min(82vw,320px);background:var(--green-700);
  transform:translateX(100%);transition:transform .3s ease;padding:5.5rem 1.6rem 2rem;z-index:55;box-shadow:var(--shadow)}
.main-nav.is-open{transform:translateX(0)}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}
.main-nav a{display:block;color:#f3ead6;font-weight:800;letter-spacing:.04em;padding:.7rem .4rem;border-radius:10px;text-transform:uppercase;font-size:.95rem}
.main-nav a:hover,.main-nav a:focus{background:rgba(255,255,255,.1);color:#fff}
.main-nav .menu-item-has-children>a::after{content:" ›"}
.nav-overlay{position:fixed;inset:0;background:rgba(19,50,42,.45);opacity:0;visibility:hidden;transition:.3s;z-index:54}
.nav-overlay.is-open{opacity:1;visibility:visible}

@media (min-width:920px){
  .nav-toggle,.nav-overlay{display:none}
  .brand img{height:60px}
  .brand .brand-text{display:block;font-family:var(--ff-display);font-weight:600;color:var(--green-900);
    font-size:1.05rem;line-height:1.05}
  .brand .brand-text small{display:block;font-family:var(--ff-body);font-weight:700;font-size:.62rem;
    letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
  .main-nav{position:static;width:auto;background:transparent;transform:none;padding:0;box-shadow:none}
  .main-nav ul{flex-direction:row;align-items:center;gap:.2rem}
  .main-nav a{color:var(--green-900);text-transform:none;font-size:1rem;padding:.5rem .85rem}
  .main-nav a:hover,.main-nav a:focus{background:rgba(31,68,53,.08);color:var(--green-900)}
  .main-nav .nav-cta a{background:var(--gold);color:var(--green-900)!important;border-radius:999px;padding:.6rem 1.2rem}
  .main-nav .nav-cta a:hover{background:var(--gold-deep);color:#fff!important}
}

/* ================================================================
   HERO
   ================================================================ */
.hero{position:relative;color:#fff;isolation:isolate}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:url(assets/img/hero-dogs.jpg) center 35%/cover no-repeat;
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(19,50,42,.55) 0%,rgba(19,50,42,.45) 40%,rgba(19,50,42,.82) 100%);
}
.hero-inner{padding:clamp(3.5rem,9vw,7rem) 0 clamp(3rem,7vw,5.5rem);max-width:760px}
.hero .eyebrow{color:var(--gold)}
.hero .eyebrow::before{background:var(--gold)}
.hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:500}
.hero-lead{font-size:clamp(1.05rem,1rem + .5vw,1.3rem);max-width:46ch;color:#f4eddd;margin-bottom:1.8rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;margin-top:2.2rem;font-weight:800;font-size:.92rem;color:#f4eddd}
.hero-badges span{display:inline-flex;align-items:center;gap:.45rem}
.hero-badges span::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--gold)}

/* paw scroll cue */
.scroll-cue{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:1;color:#fff;opacity:.85;font-size:1.4rem;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}
@media (prefers-reduced-motion:reduce){.scroll-cue{animation:none}}

/* ================================================================
   SECTIONS / LEASH SIGNATURE
   ================================================================ */
.section{padding:clamp(3.2rem,7vw,5.5rem) 0;position:relative}
.section--cream{background:var(--cream)}
.section--paper{background:var(--cream-2)}
.section-head{max-width:62ch;margin-bottom:2.2rem}
.section-head.center{margin-inline:auto;text-align:center}
.lead{font-size:1.12rem;color:var(--muted)}

/* dashed leash line connecting sections */
.leash{display:block;height:64px;position:relative}
.leash::before{
  content:"";position:absolute;left:50%;top:0;bottom:14px;
  border-left:3px dashed var(--gold);transform:translateX(-50%);opacity:.7;
}
.leash::after{
  content:"🐾";position:absolute;left:50%;bottom:-4px;transform:translateX(-50%);
  font-size:1.5rem;filter:grayscale(.1)
}

/* ================================================================
   ALERT / NEWS BANNER
   ================================================================ */
.notice{
  background:var(--card);border:1px solid var(--line);border-left:6px solid var(--gold);
  border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-soft);
  display:grid;gap:.4rem;margin-top:-2.4rem;position:relative;z-index:5;
}
.notice h3{color:var(--gold-deep);margin:0;display:flex;align-items:center;gap:.5rem}
.notice p{margin:.2rem 0;color:var(--ink)}
.notice .small{font-size:.95rem;color:var(--muted)}

/* ================================================================
   ABOUT
   ================================================================ */
.about-grid{display:grid;gap:2.2rem;align-items:center}
.about-photos{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.polaroid{
  background:#fff;padding:.7rem .7rem 2.2rem;border-radius:14px;box-shadow:var(--shadow);
  transition:transform .25s ease;
}
.polaroid img{border-radius:8px;aspect-ratio:3/4;object-fit:cover;width:100%}
.polaroid figcaption{font-family:var(--ff-display);font-style:italic;text-align:center;color:var(--green-700);margin-top:.5rem;font-size:.98rem}
.polaroid:nth-child(1){transform:rotate(-3deg)}
.polaroid:nth-child(2){transform:rotate(2.5deg);margin-top:1.6rem}
.polaroid:nth-child(1):hover{transform:rotate(-1deg) translateY(-4px)}
.polaroid:nth-child(2):hover{transform:rotate(0deg) translateY(-4px)}
.stat-row{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.6rem}
.stat{background:var(--green-700);color:#fff;border-radius:var(--radius);padding:1.1rem 1.3rem;flex:1 1 140px;box-shadow:var(--shadow-soft)}
.stat b{display:block;font-family:var(--ff-display);font-size:1.9rem;color:var(--gold);line-height:1}
.stat span{font-size:.9rem;color:#e9e0cd;font-weight:700}

@media (min-width:860px){
  .about-grid{grid-template-columns:1fr 1fr;gap:3.2rem}
  .about-grid.reverse .about-text{order:2}
}

/* ================================================================
   SERVICES
   ================================================================ */
.cards{display:grid;gap:1.4rem}
.card{
  background:var(--card);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-soft);border:1px solid var(--line);
  display:flex;flex-direction:column;transition:transform .22s ease,box-shadow .22s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-media{aspect-ratio:16/11;overflow:hidden}
.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.5rem 1.7rem;display:flex;flex-direction:column;flex:1}
.card-body h3{display:flex;align-items:center;gap:.5rem}
.card-icon{font-size:1.2rem}
.card-body p{color:var(--muted);flex:1}
.card .btn{align-self:flex-start;margin-top:.4rem}
@media (min-width:720px){.cards{grid-template-columns:repeat(3,1fr)}}

/* ================================================================
   GALLERY
   ================================================================ */
.gallery{columns:2;column-gap:1rem}
.gallery figure{margin:0 0 1rem;break-inside:avoid;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-soft);position:relative}
.gallery img{width:100%;transition:transform .5s ease}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figure::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(19,50,42,.35),transparent 55%);opacity:0;transition:.3s}
.gallery figure:hover::after{opacity:1}
@media (min-width:640px){.gallery{columns:3}}
@media (min-width:1000px){.gallery{columns:3}}

/* ================================================================
   CONTACT
   ================================================================ */
.contact-grid{display:grid;gap:1.6rem}
.info-card{background:var(--green-700);color:#fff;border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow)}
.info-card h3{color:#fff}
.info-list{list-style:none;margin:0 0 1.2rem;padding:0;display:grid;gap:.9rem}
.info-list li{display:flex;gap:.8rem;align-items:flex-start;color:#eee5d2}
.info-list .ic{flex:0 0 auto;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.12);display:grid;place-items:center;font-size:1rem}
.info-list a{color:#fff;font-weight:800}
.info-list a:hover{color:var(--gold)}
.hours{border-top:1px solid rgba(255,255,255,.18);padding-top:1.2rem}
.hours h4{color:var(--gold);font-family:var(--ff-body);font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;margin:0 0 .7rem}
.hours dl{display:grid;grid-template-columns:1fr auto;gap:.35rem 1rem;margin:0;font-size:.95rem}
.hours dt{color:#eee5d2}
.hours dd{margin:0;text-align:right;color:#fff;font-weight:700}
.hours .closed{color:var(--gold)}

.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow-soft)}
.form-row{display:grid;gap:1rem}
.field label{display:block;font-weight:800;font-size:.9rem;margin-bottom:.35rem;color:var(--green-900)}
.field input,.field textarea{
  width:100%;font:inherit;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:14px;
  background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,164,92,.25)}
.field textarea{min-height:130px;resize:vertical}
.hp{position:absolute;left:-9999px}
.form-note{font-size:.85rem;color:var(--muted);margin:.4rem 0 0}
.form-msg{border-radius:12px;padding:.9rem 1rem;margin-bottom:1rem;font-weight:700}
.form-msg.ok{background:#e6f1ea;color:#1d4435;border:1px solid #bcd9c7}
.form-msg.err{background:#fae9e2;color:#8a3b1e;border:1px solid #f0c8b8}
@media (min-width:760px){
  .field-half{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr 1.05fr}
}

/* ================================================================
   PAGE (legal etc.)
   ================================================================ */
.page-hero{background:var(--green-700);color:#fff;padding:clamp(2.6rem,6vw,4rem) 0 clamp(2.4rem,5vw,3.4rem)}
.page-hero h1{color:#fff}
.page-content{padding:clamp(2.4rem,5vw,3.6rem) 0 4rem}
.page-content .wrap{max-width:820px}
.page-content h2{font-size:1.5rem;margin-top:2rem}
.page-content h3{font-size:1.2rem;margin-top:1.4rem}
.page-content ol,.page-content ul{padding-left:1.3rem}
.page-content li{margin-bottom:.5rem}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{background:var(--green-900);color:#d9d1bf}
.footer-top{padding:clamp(2.6rem,6vw,3.6rem) 0 2rem;display:grid;gap:2rem}
.footer-brand img{background:#fff;padding:.5rem .7rem;border-radius:12px;height:64px;width:auto}
.footer-brand p{margin-top:1rem;max-width:34ch;color:#bdb4a0}
.footer-col h4{color:var(--gold);font-family:var(--ff-body);font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;margin:0 0 .9rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.footer-col a{color:#d9d1bf}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.1rem 0;font-size:.85rem;color:#9a9384}
.footer-bottom .wrap{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;align-items:center}
.footer-bottom a{color:#bdb4a0}
@media (min-width:780px){.footer-top{grid-template-columns:1.6fr 1fr 1fr}}

/* ================================================================
   SCROLL REVEAL
   ================================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
