/* =============================================================================
   @project  Sretna Šapica
   @file     public/assets/css/main.css
   @version  2.1.0
   @date     2026-03-21
   @author   Claude Sonnet 4.6 / Anthropic

   Brand: orange primary · warm cream · Nunito (display/900) · Lora (body/serif)
   Tokens extracted directly from sretnasapica.css (WP child theme)
============================================================================= */

/* ── Brand tokens ─────────────────────────────────────────────────── */
:root {
  --orange:        #E8660A;
  --orange-dark:   #C4510A;
  --orange-light:  #FFEFE0;
  --green:         #2F7A2F;
  --green-dark:    #1E5C1E;
  --green-light:   #EAF4EA;
  --black:         #1A1A1A;
  --grey-dark:     #3D3D3D;
  --grey-mid:      #767676;
  --grey-light:    #F5F2EE;
  --grey-border:   #E0D9D0;
  --white:         #FFFCF8;
  --cream:         #FDF8F2;

  --radius-sm:  6px;
  --radius-md:  12px;
  --radius-lg:  20px;
  --radius-xl:  32px;

  --shadow-sm:  0 2px 8px rgba(232,102,10,0.08);
  --shadow-md:  0 4px 20px rgba(232,102,10,0.12);
  --shadow-lg:  0 8px 40px rgba(232,102,10,0.16);

  --font-head:  'Nunito', sans-serif;
  --font-body:  'Lora', serif;
  --transition: all 0.2s cubic-bezier(0.4,0,0.2,1);

  --container: 1180px;
  --narrow:    720px;
}

/* ── Reset ────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:1rem;line-height:1.65;color:var(--grey-dark);background:var(--cream)}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--orange);text-decoration:none}
a:hover{color:var(--orange-dark);text-decoration:underline}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}

/* ── Typography ───────────────────────────────────────────────────── */
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:900;line-height:1.15;color:var(--black);letter-spacing:-0.5px}
h1{font-size:clamp(2rem,5vw,3rem)}
h2{font-size:clamp(1.5rem,3vw,2.1rem)}
h3{font-size:1.2rem;font-weight:800}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
em{font-style:italic;color:var(--orange)}
.text-muted{color:var(--grey-mid)}
.text-center{text-align:center}
.small{font-size:.875rem}
.muted{color:var(--grey-mid);font-size:.875rem;font-family:var(--font-head)}

/* ── Layout ───────────────────────────────────────────────────────── */
.container{max-width:var(--container);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.container--narrow{max-width:var(--narrow)}
.section{padding-block:clamp(3rem,8vw,6rem)}
.section--narrow{padding-block:clamp(2rem,6vw,4rem)}

/* ── Buttons ──────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:var(--radius-lg);font-family:var(--font-head);font-size:.95rem;font-weight:800;line-height:1;border:2px solid transparent;transition:var(--transition);text-decoration:none!important;white-space:nowrap;letter-spacing:.3px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--orange);color:var(--white);border-color:var(--orange);box-shadow:0 4px 16px rgba(232,102,10,.35);position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);pointer-events:none}
.btn-primary:hover{background:var(--orange-dark);border-color:var(--orange-dark);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,102,10,.45)}
.btn-ghost{background:transparent;color:var(--orange);border-color:var(--orange)}
.btn-ghost:hover{background:var(--orange-light);color:var(--orange-dark)}
.btn-outline{background:transparent;color:var(--grey-dark);border-color:var(--grey-border);font-weight:700}
.btn-outline:hover{border-color:var(--orange);color:var(--orange)}
.btn-white{background:var(--white);color:var(--orange-dark);border-color:var(--white);font-weight:800}
.btn-white:hover{background:var(--cream);transform:translateY(-2px)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6);font-weight:700}
.btn-outline-white:hover{border-color:var(--white);background:rgba(255,255,255,.1)}
.btn-green{background:var(--green);color:var(--white);border-color:var(--green);font-weight:800}
.btn-green:hover{background:var(--green-dark);border-color:var(--green-dark);color:var(--white);transform:translateY(-1px)}
.btn-lg{padding:1rem 2.5rem;font-size:1.05rem}
.btn-sm{padding:.45rem 1rem;font-size:.82rem;border-radius:var(--radius-sm)}

/* ── Header ───────────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:100;background:rgba(253,248,242,.95);backdrop-filter:blur(12px);border-bottom:2px solid var(--grey-border)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;min-height:68px;gap:1.5rem}
.site-logo{display:flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-size:1.3rem;font-weight:900;color:var(--black);text-decoration:none;letter-spacing:-0.5px}
.site-logo em{font-style:italic;color:var(--orange)}
.logo-paw{font-size:1.5rem}
.main-nav ul{display:flex;align-items:center;gap:.15rem}
.main-nav a{padding:.5rem 1rem;border-radius:var(--radius-sm);color:var(--grey-dark);font-family:var(--font-head);font-weight:700;font-size:.9rem;transition:var(--transition)}
.main-nav a:hover,.main-nav a.active{background:var(--orange-light);color:var(--orange-dark);text-decoration:none}
.nav-cta{margin-left:.5rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:.5rem}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--black);border-radius:2px;transition:transform .2s,opacity .2s}

/* ── Hero ─────────────────────────────────────────────────────────── */
.hero{position:relative;background:var(--black);overflow:hidden;padding-block:clamp(4rem,12vw,8rem) clamp(5rem,14vw,10rem)}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(232,102,10,.25) 0%,transparent 55%),radial-gradient(ellipse at 10% 80%,rgba(232,102,10,.12) 0%,transparent 40%)}
.hero-inner{position:relative;display:grid;grid-template-columns:1fr auto;align-items:center;gap:3rem}
.hero-eyebrow{font-family:var(--font-head);font-size:.8rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--orange);margin-bottom:.75rem}
.hero-title{font-family:var(--font-head);font-size:clamp(2.4rem,6vw,3.8rem);font-weight:900;color:var(--white);line-height:1.1;letter-spacing:-1px;margin-bottom:1.25rem}
.hero-title em{color:var(--orange);font-style:italic}
.hero-sub{font-family:var(--font-body);font-size:1.1rem;color:rgba(255,252,248,.8);max-width:500px;margin-bottom:2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}
.hero-badge{display:flex;align-items:center;justify-content:center}
.badge-circle{width:168px;height:168px;border:3px solid rgba(232,102,10,.4);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(232,102,10,.1);backdrop-filter:blur(4px);animation:badge-spin 20s linear infinite}
@keyframes badge-spin{to{transform:rotate(360deg)}}
.badge-circle>*{animation:badge-unspin 20s linear infinite}
@keyframes badge-unspin{to{transform:rotate(-360deg)}}
.badge-icon{font-size:2.5rem}
.badge-line1,.badge-line2{color:var(--white);font-family:var(--font-head);font-weight:900;font-size:.95rem}
.hero-wave{position:absolute;bottom:-1px;left:0;right:0}
.hero-wave svg{display:block;width:100%;height:60px}

/* ── Trust bar ────────────────────────────────────────────────────── */
.trust-bar{background:var(--orange-light);border-bottom:2px solid var(--grey-border);padding-block:1.25rem}
.trust-items{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem}
.trust-item{display:flex;align-items:center;gap:.5rem;font-family:var(--font-head);font-weight:800;font-size:.9rem;color:var(--orange-dark)}
.trust-icon{font-size:1.3rem}

/* ── Section header ───────────────────────────────────────────────── */
.section-header{text-align:center;margin-bottom:clamp(2rem,5vw,3.5rem)}
.section-eyebrow{font-family:var(--font-head);font-size:.75rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);margin-bottom:.5rem}
.section-title{font-family:var(--font-head);color:var(--black)}

/* ── Services grid ────────────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.service-card{background:var(--white);border:2px solid var(--grey-border);border-radius:var(--radius-xl);padding:2rem 1.75rem;transition:var(--transition);box-shadow:var(--shadow-sm)}
.service-card:hover{border-color:var(--orange);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.service-card--featured{border-color:var(--orange);background:var(--orange-light)}
.service-card__icon{font-size:2.25rem;margin-bottom:1rem}
.service-card h3{margin-bottom:.5rem;font-size:1.1rem}
.service-card p{color:var(--grey-mid);font-size:.95rem;font-family:var(--font-body)}
.service-link{display:inline-block;margin-top:1rem;font-family:var(--font-head);font-weight:800;font-size:.875rem;color:var(--orange)}

/* ── How it works ─────────────────────────────────────────────────── */
.how-section{background:var(--grey-light)}
.steps{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem}
.step{flex:1;min-width:200px;max-width:280px;text-align:center;padding:1.5rem}
.step-number{font-family:var(--font-head);font-size:3rem;font-weight:900;color:var(--orange);opacity:.2;line-height:1;margin-bottom:.5rem}
.step h3{margin-bottom:.5rem;font-size:1.05rem}
.step p{font-size:.92rem;color:var(--grey-mid);font-family:var(--font-body)}
.step-arrow{font-size:1.5rem;color:var(--grey-border);padding-top:2.5rem;flex-shrink:0}
.how-cta{text-align:center}

/* ── CTA strip ────────────────────────────────────────────────────── */
.cta-strip{background:var(--black);padding-block:clamp(2.5rem,6vw,4rem)}
.cta-strip__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:2rem}
.cta-strip__text h2{color:var(--white);font-size:clamp(1.4rem,3vw,2rem)}
.cta-strip__text p{color:rgba(255,252,248,.7);margin:0;font-family:var(--font-body)}
.cta-strip__actions{display:flex;flex-wrap:wrap;gap:.75rem}

/* ── Page hero ────────────────────────────────────────────────────── */
.page-hero{background:var(--black);padding-block:clamp(3rem,8vw,5rem);text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'🐾';position:absolute;top:-10px;right:20px;font-size:140px;opacity:.04;pointer-events:none;line-height:1}
.page-hero--short{padding-block:clamp(2rem,5vw,3.5rem)}
.page-title{font-family:var(--font-head);color:var(--white);margin-bottom:.5rem}
.page-sub{color:rgba(255,252,248,.75);font-family:var(--font-body);font-size:1.1rem}
.page-hero .section-eyebrow{color:var(--orange)}

/* ── Service detail ───────────────────────────────────────────────── */
.service-detail{display:grid;grid-template-columns:80px 1fr;gap:2rem;padding-block:2.5rem;align-items:start}
.service-detail--reverse{direction:rtl}
.service-detail--reverse>*{direction:ltr}
.service-detail__icon{font-size:3.5rem}
.service-detail h2{margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.service-detail p{color:var(--grey-mid);margin-bottom:1rem;font-family:var(--font-body)}
.section-divider{border:none;border-top:2px solid var(--grey-border);margin:0}
.tag{font-family:var(--font-head);font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;background:var(--orange-light);color:var(--orange-dark);padding:.2rem .65rem;border-radius:99px;border:1px solid rgba(232,102,10,.2)}
.feature-list{padding-left:1.25rem;list-style:disc}
.feature-list li{padding-block:.25rem;color:var(--grey-mid);font-family:var(--font-body)}
.feature-list li::marker{color:var(--orange)}

/* ── Gallery ──────────────────────────────────────────────────────── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.gallery-item{display:block;overflow:hidden;border-radius:var(--radius-lg);aspect-ratio:4/3;background:var(--grey-light);border:2px solid var(--grey-border);transition:var(--transition)}
.gallery-item:hover{border-color:var(--orange);box-shadow:var(--shadow-md)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-item:hover img{transform:scale(1.04)}
.lightbox-overlay{position:fixed;inset:0;background:rgba(26,26,26,.95);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s}
.lightbox-overlay.active{opacity:1;pointer-events:all}
.lightbox-overlay img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-lg)}
.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;background:rgba(232,102,10,.8);border:none;color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}
.lightbox-close:hover{background:var(--orange)}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(232,102,10,.7);border:none;color:#fff;font-size:2rem;padding:.75rem 1rem;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition)}
.lightbox-prev:hover,.lightbox-next:hover{background:var(--orange)}
.lightbox-prev{left:1.5rem}
.lightbox-next{right:1.5rem}

/* ── Kontakt ──────────────────────────────────────────────────────── */
.kontakt-grid{display:grid;grid-template-columns:1fr 2fr;gap:3rem;align-items:start}
.kontakt-info h2{margin-bottom:1.25rem;font-size:1.4rem}
.contact-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}
.contact-list li{display:flex;align-items:center;gap:.75rem;font-family:var(--font-body)}
.contact-icon{font-size:1.25rem;flex-shrink:0}
.kontakt-hours h3{font-size:1.05rem;margin-bottom:.75rem}
.kontakt-hours table{border-collapse:collapse;width:100%;font-family:var(--font-body)}
.kontakt-hours td{padding:.4rem .5rem;font-size:.9rem;border-bottom:1px solid var(--grey-border)}
.kontakt-hours td:first-child{font-family:var(--font-head);font-weight:700;padding-left:0}

/* ── Prose ────────────────────────────────────────────────────────── */
.prose h2{font-size:1.3rem;margin:2rem 0 .75rem;padding-top:1rem;border-top:2px solid var(--grey-border)}
.prose h2:first-of-type{border-top:none;padding-top:0;margin-top:1rem}
.prose ul{padding-left:1.5rem;list-style:disc;margin-bottom:1rem}
.prose li{padding-block:.2rem;font-family:var(--font-body)}
.prose p{color:var(--grey-mid);font-family:var(--font-body)}

/* ── Forms ────────────────────────────────────────────────────────── */
.form{display:flex;flex-direction:column;gap:1.25rem}
.form-section{border:2px solid var(--grey-border);border-radius:var(--radius-xl);padding:1.75rem;background:var(--cream);position:relative;overflow:hidden}
.form-section::before{content:'🐾';position:absolute;top:-8px;right:16px;font-size:100px;opacity:.04;pointer-events:none;line-height:1}
.form-section__title{font-family:var(--font-head);font-size:1.1rem;font-weight:900;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;color:var(--black)}
.form-section__num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--orange);color:var(--white);border-radius:50%;font-family:var(--font-head);font-size:.8rem;font-weight:900;flex-shrink:0}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-family:var(--font-head);font-weight:700;font-size:.78rem;letter-spacing:.5px;text-transform:uppercase;color:var(--grey-dark)}
.form-group input,.form-group select,.form-group textarea{padding:.8rem 1rem;border:2px solid var(--grey-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.95rem;color:var(--black);background:var(--white);transition:var(--transition);width:100%;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--orange);box-shadow:0 0 0 4px rgba(232,102,10,.10)}
.form-group.has-error input,.form-group.has-error select,.form-group.has-error textarea{border-color:#E53935;box-shadow:0 0 0 4px rgba(229,57,53,.10)}
.form-error{font-family:var(--font-head);font-size:.78rem;font-weight:700;color:#C62828}
.required{color:var(--orange)}
.form-row{display:grid;gap:1rem}
.form-row--2{grid-template-columns:1fr 1fr}
.form-row--3{grid-template-columns:1fr 1fr 1fr}
.form-submit{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}
.form-note{font-family:var(--font-head);font-size:.82rem;color:var(--grey-mid)}
.radio-group{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-top:.25rem}
.radio-label{display:flex;align-items:center;gap:.5rem;font-family:var(--font-body);cursor:pointer;padding:.6rem .9rem;border-radius:var(--radius-sm);border:2px solid transparent;transition:var(--transition)}
.radio-label:hover{background:var(--orange-light);border-color:var(--orange)}
.radio-label input{width:auto;accent-color:var(--orange)}
.checkbox-group{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.25rem}
.checkbox-label{display:flex;align-items:center;gap:.5rem;font-family:var(--font-body);cursor:pointer;padding:.7rem .9rem;border-radius:var(--radius-sm);border:2px solid var(--grey-border);background:var(--white);transition:var(--transition)}
.checkbox-label:hover{border-color:var(--orange);background:var(--orange-light)}
.checkbox-label input{width:auto;accent-color:var(--orange)}

/* Dog row */
.dog-row{border:2px solid var(--grey-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1rem;background:var(--white);transition:var(--transition)}
.dog-row:hover{border-color:var(--orange);box-shadow:var(--shadow-sm)}
.dog-row__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}
.dog-row__title{font-size:1rem;font-weight:900;margin:0;font-family:var(--font-head)}
.remove-dog{background:none;border:2px solid var(--grey-border);border-radius:var(--radius-sm);color:var(--grey-mid);font-size:.85rem;padding:.2rem .5rem;line-height:1;cursor:pointer;transition:var(--transition);font-family:var(--font-head);font-weight:700}
.remove-dog:hover{border-color:#E53935;color:#E53935}
.vet-details{margin-top:1rem}
.vet-details summary{cursor:pointer;font-family:var(--font-head);font-size:.875rem;color:var(--grey-mid);font-weight:700;padding:.4rem 0}
.vet-details .form-row{margin-top:1rem}

/* Owner card */
.owner-card{display:flex;align-items:center;gap:1rem;background:var(--orange-light);border:2px solid rgba(232,102,10,.3);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:1.5rem}
.owner-card__icon{font-size:2rem}
.owner-card__info{flex:1;display:flex;flex-direction:column;gap:.15rem}
.owner-card__info strong{font-family:var(--font-head);font-size:1rem;font-weight:900}
.owner-card__info span{font-size:.875rem;color:var(--grey-mid);font-family:var(--font-body)}
.owner-card__edit{font-size:1.1rem;color:var(--grey-mid)}
.owner-card__edit:hover{color:var(--orange)}

/* ── Alerts & flash ───────────────────────────────────────────────── */
.alert{padding:1rem 1.25rem;border-radius:var(--radius-md);margin-bottom:1.5rem;font-family:var(--font-head);font-size:.9rem;font-weight:600;border-left:5px solid transparent}
.alert strong{display:block;margin-bottom:.4rem;font-weight:800}
.alert ul{padding-left:1.25rem;list-style:disc}
.alert--error{background:#FFF0EC;border-color:var(--orange);color:var(--orange-dark)}
.alert--warning{background:#FFF8EC;border-color:#F5A623;color:#7A4F00}
.alert--info{background:var(--green-light);border-color:var(--green);color:var(--green-dark)}
.flash{padding:.9rem clamp(1rem,4vw,2rem);font-family:var(--font-head);font-weight:700;font-size:.9rem;text-align:center}
.flash--success{background:linear-gradient(135deg,var(--green-light),#F5FAF5);color:var(--green-dark);border-bottom:2px solid var(--green)}

/* ── Footer ───────────────────────────────────────────────────────── */
.site-footer{background:var(--black);color:rgba(255,252,248,.65);padding-block:3rem 1.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
.footer-brand .logo-paw{font-size:1.8rem}
.footer-brand strong{display:block;color:var(--white);font-family:var(--font-head);font-size:1.1rem;font-weight:900;margin:.25rem 0 .5rem}
.footer-brand p{font-size:.9rem;font-family:var(--font-body);line-height:1.5}
.footer-links h4,.footer-contact h4{color:var(--white);font-family:var(--font-head);font-size:.75rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem}
.footer-links ul,.footer-contact ul{display:flex;flex-direction:column;gap:.5rem}
.footer-links a,.footer-contact a,.footer-contact li{font-size:.875rem;color:rgba(255,252,248,.65);font-family:var(--font-body);text-decoration:none}
.footer-links a:hover,.footer-contact a:hover{color:var(--orange)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.25rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;font-family:var(--font-head);font-size:.8rem}
.footer-bottom a{color:rgba(255,252,248,.5)}
.footer-bottom a:hover{color:var(--orange)}
.staging-badge{background:var(--orange);color:var(--white);padding:.15rem .55rem;border-radius:var(--radius-sm);font-weight:900;font-size:.7rem;letter-spacing:.1em}

/* ── Error page ───────────────────────────────────────────────────── */
.error-page{text-align:center;padding-block:6rem}
.error-code{font-family:var(--font-head);font-size:8rem;font-weight:900;color:var(--orange);opacity:.15;line-height:1}
.error-title{margin-bottom:.75rem}
.error-msg{color:var(--grey-mid);font-family:var(--font-body);margin-bottom:2rem}

/* ── Responsive ───────────────────────────────────────────────────── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .hero-badge{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .kontakt-grid{grid-template-columns:1fr}
  .service-detail{grid-template-columns:60px 1fr}
}
@media(max-width:680px){
  .nav-toggle{display:flex}
  .main-nav{display:none;position:absolute;top:68px;left:0;right:0;background:var(--cream);border-bottom:2px solid var(--grey-border);padding:1rem;box-shadow:var(--shadow-md)}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:.25rem}
  .nav-cta{margin-left:0;margin-top:.5rem}
  .form-row--2,.form-row--3{grid-template-columns:1fr}
  .steps{flex-direction:column;align-items:center}
  .step-arrow{transform:rotate(90deg);padding:0}
  .footer-grid{grid-template-columns:1fr}
  .cta-strip__inner{flex-direction:column}
  .service-detail{grid-template-columns:1fr}
  .service-detail--reverse{direction:ltr}
  .service-detail__icon{font-size:2.5rem}
}

/* ── Logo image ───────────────────────────────────────────────────── */
.site-logo__img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  border-radius: var(--radius-sm);
}
.footer-logo-img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  margin-bottom: .25rem;
  border-radius: var(--radius-sm);
}

/* ── Hero background photo ────────────────────────────────────────── */
.hero-bg-img {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}
.hero-bg-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: .12;
  filter: grayscale(30%);
}

/* ── Yes/No pill grid ─────────────────────────────────────────────── */
.yesno-grid {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-top: .25rem;
}
.yesno-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .6rem .9rem;
  background: var(--white);
  border: 1.5px solid var(--grey-border);
  border-radius: var(--radius-md);
}
.yesno-label {
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--grey-dark);
  flex: 1;
}
.yesno-pills {
  display: flex;
  gap: .4rem;
  flex-shrink: 0;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .35rem .9rem;
  border-radius: 99px;
  border: 2px solid var(--grey-border);
  font-family: var(--font-head);
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  transition: var(--transition);
  background: var(--white);
  color: var(--grey-mid);
  white-space: nowrap;
}
.pill input[type=radio] {
  display: none;
}
.pill:hover {
  border-color: var(--orange);
  color: var(--orange);
}
.pill--active,
.pill:has(input:checked) {
  background: var(--orange);
  border-color: var(--orange);
  color: var(--white);
}

/* ── Vet fields ───────────────────────────────────────────────────── */
.vet-fields {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 1rem;
}

/* ── Blog ─────────────────────────────────────────────────────────── */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}
.blog-card {
  background: var(--white);
  border: 2px solid var(--grey-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: var(--transition);
  box-shadow: var(--shadow-sm);
}
.blog-card:hover {
  border-color: var(--orange);
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.blog-card__body { padding: 1.75rem; }
.blog-card__date {
  font-family: var(--font-head);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--orange);
  display: block;
  margin-bottom: .5rem;
}
.blog-card__title {
  font-size: 1.15rem;
  margin-bottom: .75rem;
}
.blog-card__title a {
  color: var(--black);
  text-decoration: none;
}
.blog-card__title a:hover { color: var(--orange); }
.blog-card__excerpt {
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--grey-mid);
  margin-bottom: 1rem;
}
.blog-card__link {
  font-family: var(--font-head);
  font-weight: 800;
  font-size: .875rem;
  color: var(--orange);
}
.blog-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 3rem;
}
.pagination-info {
  font-family: var(--font-head);
  font-size: .875rem;
  color: var(--grey-mid);
}

/* Blog single post */
.blog-post { margin-bottom: 3rem; }
.blog-post__footer { margin-top: 3rem; padding-top: 2rem; border-top: 2px solid var(--grey-border); }

/* Blog prose overrides */
.blog-post.prose h2 { font-size: 1.5rem; }
.blog-post.prose h3 { font-size: 1.2rem; margin: 1.5rem 0 .5rem; }
.blog-post.prose img {
  border-radius: var(--radius-lg);
  margin: 1.5rem 0;
  max-width: 100%;
}
.blog-post.prose a { color: var(--orange); font-weight: 600; }

