:root{--cream:#fff8ef;--ink:#332821;--brown:#8a5a3b;--rose:#f4c7bd;--soft:#fff1ed;--green:#53765a}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);background:var(--cream)}
a{color:inherit}
.site-header{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem clamp(1rem,4vw,4rem);background:rgba(255,248,239,.9);backdrop-filter:blur(10px);border-bottom:1px solid #ecd8ca}
.brand{display:flex;align-items:center;gap:.5rem;font-weight:800;text-decoration:none;font-size:1.1rem}
.paw{font-size:1.35rem}
.logo-mark{width:42px;height:42px;object-fit:contain;border-radius:50%;background:white}
nav{display:flex;gap:1rem;flex-wrap:wrap;font-size:.95rem}
nav a{text-decoration:none;font-weight:650}
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center;min-height:72vh;padding:clamp(2rem,6vw,6rem) clamp(1rem,4vw,4rem)}
.eyebrow{color:var(--brown);font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem}
h1{font-size:clamp(2.5rem,6vw,5.5rem);line-height:.95;margin:.2rem 0 1rem}
h2{font-size:clamp(2rem,4vw,3.4rem);line-height:1;margin:.2rem 0 1rem}
.lead{font-size:1.2rem;max-width:44rem;color:#5b4940}
.actions,.contact-buttons{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.5rem}
.button{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.1rem;border-radius:999px;background:var(--green);color:white;text-decoration:none;font-weight:750;box-shadow:0 8px 24px #0001}
.button.secondary{background:white;color:var(--ink);border:1px solid #ead3c8}
.hero-card,.puppy-card,.video-card{background:white;border:1px solid #efd8cd;border-radius:2rem;box-shadow:0 20px 60px #6b3e2620;overflow:hidden}
.hero-card img{width:100%;display:block}
.section{padding:clamp(2.5rem,6vw,5rem) clamp(1rem,4vw,4rem)}
.section-heading{max-width:58rem;margin-bottom:1.5rem}
.section-heading p:not(.eyebrow){max-width:42rem;color:#5b4940}
.puppy-grid,.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem}
.puppy-photo-wrap{position:relative;overflow:hidden}
.puppy-main-photo{display:block;width:100%;padding:0;border:0;background:transparent;cursor:zoom-in}
.puppy-card img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--soft);display:block}
.photo-banner{position:absolute;left:-12%;right:-12%;top:1.4rem;transform:rotate(-10deg);padding:.65rem 1rem;background:rgba(83,118,90,.94);color:white;text-align:center;text-transform:uppercase;letter-spacing:.08em;font-weight:900;font-size:clamp(.9rem,2.4vw,1.15rem);box-shadow:0 10px 26px #0004}
.puppy-thumbs{display:grid;grid-template-columns:repeat(auto-fit,minmax(54px,1fr));gap:.45rem;padding:.7rem .8rem 0}
.puppy-thumb,.placed-thumb{padding:0;border:2px solid transparent;background:transparent;border-radius:.5rem;overflow:hidden;cursor:pointer}
.puppy-thumb.active{border-color:var(--green)}
.puppy-thumb img{aspect-ratio:1;object-fit:cover}
.puppy-body{padding:1rem}
.status{display:inline-block;padding:.25rem .6rem;border-radius:999px;background:var(--soft);color:var(--brown);font-weight:800;font-size:.8rem}
.puppy-card h3{margin:.7rem 0 .4rem;font-size:1.45rem}
.video-card{position:relative}
.video-card iframe{display:block;width:100%;aspect-ratio:16/9;border:0;background:#000}
.video-expand{position:absolute;right:.75rem;bottom:.75rem;z-index:1;padding:.55rem .75rem;border:0;border-radius:999px;background:rgba(255,255,255,.94);color:var(--ink);font-weight:800;box-shadow:0 8px 22px #0004;cursor:pointer}
dl{display:grid;gap:.35rem;margin:1rem 0 0}
dl div{display:flex;justify-content:space-between;border-top:1px solid #f0ddd5;padding-top:.35rem}
dt{font-weight:800}
dd{margin:0;color:#6a554b}
.split{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1fr);gap:2rem;align-items:center}
.soft{background:var(--soft)}
.placed-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.8rem;max-width:56rem}
.placed-thumb{position:relative;background:white;border-color:#efd8cd;box-shadow:0 12px 30px #6b3e2618}
.placed-thumb img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.placed-thumb span{display:block;padding:.55rem .45rem;font-weight:800;color:var(--ink);background:white}
.lightbox[hidden],.section[hidden]{display:none}
.lightbox{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:1rem}
.lightbox-backdrop{position:absolute;inset:0;background:rgba(20,14,10,.76)}
.lightbox-panel{position:relative;z-index:1;max-width:min(92vw,980px);max-height:88vh}
.lightbox-panel img{display:block;max-width:100%;max-height:88vh;border-radius:.75rem;background:white;box-shadow:0 24px 70px #0008}
.video-lightbox-panel{width:min(94vw,1100px)}
.video-lightbox-panel iframe{display:block;width:100%;aspect-ratio:16/9;border:0;border-radius:.75rem;background:#000;box-shadow:0 24px 70px #0008}
.lightbox-close{position:absolute;top:.75rem;right:.75rem;width:2.5rem;height:2.5rem;border:0;border-radius:999px;background:white;color:var(--ink);font-size:1.6rem;line-height:1;cursor:pointer;box-shadow:0 8px 20px #0003}
.contact{text-align:center;background:white}
.contact .contact-buttons{justify-content:center}
.note,footer{color:#725e54}
footer{text-align:center;padding:2rem 1rem}
@media(max-width:760px){.site-header{align-items:flex-start;flex-direction:column}.hero,.split{grid-template-columns:1fr}nav{font-size:.9rem}}
