@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,600;0,700;1,500&display=swap');

:root { --ink:#47605D; --sage:#C2D1CF; --clay:#9A5E40; --clay-soft:#CF966E; --cream:#fbfaf7; --white:#fff; --line:rgba(71,96,93,.17); --shadow:0 18px 45px rgba(43,61,58,.12); }
* { box-sizing:border-box; } html { scroll-behavior:smooth; } body { margin:0; color:var(--ink); background:var(--cream); font-family:'DM Sans',Arial,sans-serif; line-height:1.55; } img { display:block; max-width:100%; } a { color:inherit; text-decoration:none; } .skip-link { position:absolute; left:-999px; top:auto; } .skip-link:focus { left:1rem; top:1rem; z-index:100; padding:.7rem 1rem; background:var(--white); border-radius:.5rem; }
.container { width:min(1120px,calc(100% - 2.5rem)); margin-inline:auto; } .section { padding:5.5rem 0; } .eyebrow { display:flex; align-items:center; gap:.55rem; margin:0 0 .75rem; color:var(--clay); font-size:.78rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; } .eyebrow::before { content:''; width:2rem; height:1px; background:currentColor; } h1,h2,h3 { font-family:'Playfair Display',Georgia,serif; line-height:1.06; letter-spacing:-.02em; font-variant-ligatures:none; } h1 { font-size:clamp(3rem,9vw,6.35rem); margin:.1em 0 .25em; } h2 { font-size:clamp(2.25rem,5vw,4.2rem); margin:.05em 0 .3em; } h3 { font-size:1.7rem; margin:.2em 0 .5em; } p { margin:.2rem 0 1rem; } .lead { font-size:clamp(1.05rem,2vw,1.28rem); max-width:55ch; } .button { display:inline-flex; justify-content:center; align-items:center; gap:.45rem; min-height:3rem; padding:.72rem 1.2rem; border:1px solid var(--ink); border-radius:999px; background:var(--ink); color:var(--white); font-weight:700; transition:transform .2s ease,background .2s ease; } .button:hover { transform:translateY(-2px); background:#324946; } .button--clay { border-color:var(--clay); background:var(--clay); } .button--light { background:transparent; color:var(--ink); } .button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible { outline:3px solid var(--clay); outline-offset:3px; }
.site-header { position:sticky; z-index:20; top:0; background:rgba(251,250,247,.94); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); } .nav { display:flex; align-items:center; justify-content:space-between; min-height:4.75rem; gap:1rem; } .brand img { width:145px; height:auto; } .nav-links { display:none; align-items:center; gap:1.4rem; font-size:.9rem; font-weight:600; } .nav-links a { position:relative; } .nav-links a[aria-current='page']::after { content:''; position:absolute; left:0; right:0; bottom:-.45rem; height:2px; background:var(--clay); } .menu-toggle { border:0; padding:.6rem; background:none; color:var(--ink); font:inherit; font-weight:700; } .nav-open .nav-links { display:flex; position:absolute; top:4.75rem; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; padding:.7rem 1.25rem 1.2rem; background:var(--cream); border-bottom:1px solid var(--line); } .nav-open .nav-links a { padding:.75rem 0; } .nav-open .nav-links a:last-child { margin-top:.45rem; text-align:center; color:var(--white); background:var(--ink); border-radius:999px; }
.hero { position:relative; overflow:hidden; padding:5.4rem 0 4.5rem; background:linear-gradient(125deg,#fff 0%,#fff 55%,#e7eeee 100%); } .hero-grid { display:grid; gap:3rem; align-items:center; } .hero-copy { position:relative; z-index:1; } .hero-art { position:relative; display:grid; place-items:center; min-height:300px; } .hero-art::before { content:''; width:min(79vw,430px); aspect-ratio:1; border-radius:50%; background:var(--sage); } .hero-paw { position:absolute; width:min(66vw,330px); filter:drop-shadow(12px 15px 0 rgba(207,150,110,.75)); transform:rotate(-9deg); } .hero-actions { display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.7rem; } .trust-line { display:flex; flex-wrap:wrap; gap:.4rem 1.2rem; margin-top:1.5rem; font-size:.9rem; font-weight:600; } .trust-line span::before { content:'✓'; color:var(--clay); margin-right:.35rem; }
.intro { display:grid; gap:2rem; } .pullquote { padding:2rem; border-left:3px solid var(--clay); background:var(--white); font-family:'Playfair Display',serif; font-size:1.4rem; box-shadow:var(--shadow); } .services-band { background:var(--clay); color:var(--white); } .services-band .eyebrow { color:var(--white); } .cards { display:grid; gap:1rem; margin-top:2.1rem; } .card { height:100%; padding:1.6rem; background:var(--white); color:var(--ink); border-radius:1rem; box-shadow:0 8px 22px rgba(69,43,25,.12); } .card-number { display:grid; place-items:center; width:2.2rem; aspect-ratio:1; margin-bottom:1rem; border-radius:50%; background:var(--sage); font-weight:700; } .card p { font-size:.94rem; } .card .text-link { display:inline-block; margin-top:.5rem; color:var(--clay); font-weight:700; } .resource-banner { display:grid; gap:1.5rem; align-items:center; padding:2rem; border-radius:1.2rem; background:var(--sage); } .resource-banner img { width:98px; justify-self:end; opacity:.9; }
.page-hero { padding:4.5rem 0 3.5rem; text-align:center; background:var(--sage); } .page-hero .lead { margin-inline:auto; } .service-detail { display:grid; gap:2rem; align-items:center; } .service-visual { min-height:280px; display:grid; place-items:center; border-radius:1.2rem; overflow:hidden; background:linear-gradient(145deg,var(--sage),#e9f0ee); } .service-visual img { width:45%; filter:drop-shadow(8px 12px 0 rgba(207,150,110,.65)); } .service-detail.reverse .service-visual { background:linear-gradient(145deg,#d9a37e,#bd815b); } .price { margin:.8rem 0; font-family:'Playfair Display',serif; font-size:3rem; color:var(--clay); } .checklist { list-style:none; padding:0; } .checklist li { margin:.45rem 0; } .checklist li::before { content:'✓'; margin-right:.55rem; color:var(--clay); font-weight:700; } .course { text-align:center; background:var(--ink); color:var(--white); }
.download-grid,.post-grid { display:grid; gap:1rem; } .download-card,.post { padding:1.8rem; border:1px solid var(--line); border-radius:1rem; background:var(--white); } .download-icon { display:grid; place-items:center; width:3.6rem; aspect-ratio:1; margin-bottom:1.3rem; border-radius:50%; background:var(--sage); font-size:1.45rem; } .tag { display:inline-block; padding:.3rem .6rem; border-radius:999px; background:#edf3f2; color:var(--ink); font-size:.75rem; font-weight:700; } .post { display:grid; gap:1rem; } .post-art { min-height:155px; display:grid; place-items:center; border-radius:.75rem; background:var(--sage); } .post-art img { width:43%; } .post:nth-child(2) .post-art { background:var(--clay); } .post time { color:#6f7f7b; font-size:.85rem; }
.about-grid { display:grid; gap:2rem; align-items:center; } .portrait { min-height:340px; border-radius:1rem; overflow:hidden; background:var(--sage); } .portrait img { width:100%; height:100%; object-fit:cover; object-position:center 35%; } .about-copy strong { color:var(--ink); } .team { text-align:center; } .team-card { max-width:730px; margin:2.2rem auto 0; padding:2rem; border-radius:1rem; background:var(--white); box-shadow:var(--shadow); } .team-photo { width:100%; aspect-ratio:16/9; margin:0 auto 1.5rem; border-radius:.7rem; object-fit:cover; object-position:center 43%; } .team-paw { width:115px; margin:0 auto 1rem; }
.contact { background:var(--sage); } .contact-layout { display:grid; gap:2rem; } form { display:grid; gap:1rem; padding:1.3rem; border-radius:1rem; background:var(--white); box-shadow:var(--shadow); } .form-row { display:grid; gap:1rem; } label { display:grid; gap:.35rem; font-weight:700; font-size:.9rem; } input,textarea,select { width:100%; padding:.85rem; border:1px solid #9badaa; border-radius:.4rem; color:var(--ink); font:inherit; background:#fff; } textarea { min-height:130px; resize:vertical; } textarea::placeholder { color:#71827f; opacity:.8; } .form-note { min-height:1.4em; font-weight:600; } .email-fallback { display:none; color:var(--ink); font-size:.88rem; font-weight:700; text-decoration:underline; text-underline-offset:3px; } .email-options { display:none; flex-wrap:wrap; gap:.6rem; } .email-options a { padding:.45rem .7rem; border:1px solid var(--line); border-radius:999px; color:var(--ink); font-size:.82rem; font-weight:700; background:#f4f7f6; } .contact-list { display:grid; gap:1rem; } .contact-item { padding:1.25rem; border-radius:.8rem; background:rgba(255,255,255,.55); } .contact-item span { display:block; font-size:.75rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--clay); } .map-link { display:block; padding:1.2rem; border-radius:.8rem; background:var(--ink); color:var(--white); }
.site-footer { padding:2.8rem 0; color:var(--white); background:var(--ink); } .footer-grid { display:grid; gap:1.4rem; } .footer-brand img { width:155px; filter:brightness(0) invert(1) opacity(.95); } .footer-nav,.social-links { display:flex; flex-wrap:wrap; gap:.5rem 1.1rem; } .social-links a { text-decoration:underline; text-underline-offset:4px; } .footer-small { font-size:.86rem; opacity:.8; } .article { width:min(780px,calc(100% - 2.5rem)); margin:0 auto; } .article-header { padding:4.8rem 0 2rem; } .article-header time { color:var(--clay); font-weight:700; } .article-body { padding-bottom:5rem; font-size:1.08rem; } .article-body h2 { margin-top:2.4rem; font-size:2.25rem; } .article-body strong { font-weight:700; } .article-image { width:100%; margin:1.8rem 0; border-radius:1rem; } .article-body li { margin:.4rem 0; }
.reveal { opacity:0; transform:translateY(18px); transition:opacity .7s ease,transform .7s ease; } .reveal.visible { opacity:1; transform:none; } @media (prefers-reduced-motion:reduce) { html { scroll-behavior:auto; } *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; } }
@media (min-width:700px) { .section { padding:7rem 0; } .menu-toggle { display:none; } .nav-links { display:flex; } .hero { padding:7rem 0 6.5rem; } .hero-grid { grid-template-columns:1.15fr .85fr; } .intro { grid-template-columns:1fr .8fr; align-items:center; } .cards { grid-template-columns:repeat(3,1fr); } .resource-banner { grid-template-columns:1fr auto; padding:2.7rem; } .service-detail { grid-template-columns:1fr 1fr; } .service-detail.reverse .service-visual { order:2; } .download-grid,.post-grid { grid-template-columns:repeat(2,1fr); } .about-grid { grid-template-columns:1fr 1fr; } .contact-layout { grid-template-columns:1.25fr .75fr; } .form-row { grid-template-columns:1fr 1fr; } .footer-grid { grid-template-columns:1.2fr 1fr .8fr; align-items:center; } .header-social { display:flex; } }

/* Refined contact, resource and journal details */
.header-social { display:none; align-items:center; gap:.45rem; margin-right:auto; } .icon-link { display:grid; place-items:center; width:2rem; height:2rem; border-radius:50%; color:var(--ink); background:#edf2f1; transition:background .2s ease,transform .2s ease; } .icon-link:hover { background:var(--sage); transform:translateY(-2px); } .icon-link svg { width:1rem; height:1rem; fill:currentColor; } .social-note { display:flex; align-items:center; flex-wrap:wrap; gap:.65rem; margin-top:1.35rem; font-size:.92rem; font-weight:600; } .course { background:linear-gradient(135deg,var(--ink),#344b48); border-top:8px solid var(--cream); } .pdf-preview { position:relative; height:220px; margin:-.2rem 0 1.5rem; overflow:hidden; border:1px solid var(--line); border-radius:.7rem; background:linear-gradient(145deg,#fff,#eaf1ef); } .pdf-preview iframe { width:185%; height:390px; transform:scale(.54); transform-origin:top left; border:0; pointer-events:none; } .post { transition:transform .2s ease,box-shadow .2s ease; } .post:hover { transform:translateY(-4px); box-shadow:var(--shadow); } .journal-hero h1 { max-width:17ch; margin-inline:auto; font-size:clamp(2.6rem,5.5vw,4.55rem); } .phone-button { width:100%; border:0; padding:0; color:var(--ink); background:transparent; text-align:left; font:inherit; font-size:1.1rem; cursor:pointer; } .map-panel { overflow:hidden; border-radius:1rem; box-shadow:var(--shadow); background:var(--white); } .map-panel iframe { display:block; width:100%; height:320px; border:0; } .map-caption { padding:1.1rem 1.25rem; font-size:.92rem; } .map-link { display:inline-block; margin-top:.6rem; padding:.75rem 1rem; border-radius:999px; }
.nav-open .nav-links a[aria-current='page']::after { right:auto; bottom:.42rem; width:2.15rem; }
.nav-open .nav-links a:last-child[aria-current='page'] { background:var(--clay); color:var(--white); } .nav-open .nav-links a:last-child[aria-current='page']::after { display:none; }
@media (min-width:700px) { .footer-brand > .footer-small { display:none; } }
.header-social { display:none; align-items:center; gap:.45rem; margin-right:auto; } .icon-link { display:grid; place-items:center; width:2rem; height:2rem; border-radius:50%; color:var(--ink); background:#edf2f1; transition:background .2s ease,transform .2s ease; } .icon-link:hover { background:var(--sage); transform:translateY(-2px); } .icon-link svg { width:1rem; height:1rem; fill:currentColor; } .social-note { display:flex; align-items:center; flex-wrap:wrap; gap:.65rem; margin-top:1.35rem; font-size:.92rem; font-weight:600; } .course { background:linear-gradient(135deg,var(--ink),#344b48); border-top:8px solid var(--cream); } .pdf-preview { position:relative; height:220px; margin:-.2rem 0 1.5rem; overflow:hidden; border:1px solid var(--line); border-radius:.7rem; background:linear-gradient(145deg,#fff,#eaf1ef); } .pdf-preview iframe { width:185%; height:390px; transform:scale(.54); transform-origin:top left; border:0; pointer-events:none; } .post { transition:transform .2s ease,box-shadow .2s ease; } .post:hover { transform:translateY(-4px); box-shadow:var(--shadow); } .journal-hero h1 { max-width:17ch; margin-inline:auto; font-size:clamp(2.6rem,5.5vw,4.55rem); } .phone-button { width:100%; border:0; padding:0; color:var(--ink); background:transparent; text-align:left; font:inherit; font-size:1.1rem; cursor:pointer; } .map-panel { overflow:hidden; border-radius:1rem; box-shadow:var(--shadow); background:var(--white); } .map-panel iframe { display:block; width:100%; height:320px; border:0; } .map-caption { padding:1.1rem 1.25rem; font-size:.92rem; } .map-link { display:inline-block; margin-top:.6rem; padding:.75rem 1rem; border-radius:999px; }

/* A little more Petfect personality, without visual noise */
.copy-toast { position:fixed; z-index:100; left:50%; bottom:1.5rem; padding:.75rem 1rem; border-radius:999px; background:var(--ink); color:var(--white); font-weight:700; box-shadow:var(--shadow); opacity:0; transform:translate(-50%,1rem); pointer-events:none; transition:opacity .2s ease,transform .2s ease; } .copy-toast.show { opacity:1; transform:translate(-50%,0); }
.contact form { position:relative; } .enquiry-confirmation { position:absolute; inset:0; z-index:2; display:grid; place-items:center; padding:1.5rem; border-radius:1rem; background:rgba(255,255,255,.97); text-align:center; box-shadow:inset 0 0 0 2px var(--sage); } .enquiry-confirmation > div { max-width:30rem; } .enquiry-confirmation h2 { font-size:clamp(2rem,5vw,3rem); } .enquiry-confirmation .text-link { margin:.3rem .55rem; padding:0; border:0; background:none; color:var(--ink); font:inherit; font-weight:700; text-decoration:underline; text-underline-offset:3px; cursor:pointer; }
.button { position:relative; overflow:hidden; }
.hero--human { padding-block:4.25rem 3.75rem; } .hero-photo-wrap { position:relative; width:min(100%,440px); margin-inline:auto; } .hero-photo { width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center 35%; border-radius:48% 52% 45% 55% / 42% 43% 57% 58%; box-shadow:18px 18px 0 rgba(194,209,207,.92),0 20px 45px rgba(43,61,58,.15); } .hero-photo-wrap::after { content:''; position:absolute; right:-1.2rem; bottom:1.8rem; width:7.3rem; aspect-ratio:1; border-radius:50%; background:var(--clay-soft); opacity:.82; z-index:-1; } .hero-tag { position:absolute; left:-.75rem; bottom:1.7rem; max-width:13rem; padding:.85rem 1rem; border-radius:.85rem; background:var(--white); box-shadow:var(--shadow); font-weight:700; font-size:.9rem; }
.reason-grid,.journey-grid,.story-grid,.photo-mosaic { display:grid; gap:1rem; } .reason { padding:1.5rem; border-radius:1rem; background:var(--white); border:1px solid var(--line); } .reason-mark { display:grid; place-items:center; width:2.7rem; aspect-ratio:1; margin-bottom:1rem; color:var(--white); background:var(--ink); border-radius:45% 55% 50% 50%; font-weight:700; } .reason:nth-child(2) .reason-mark { background:var(--clay); } .reason:nth-child(3) .reason-mark { background:#6a8985; } .journey { position:relative; padding:1.5rem 1.25rem; border-radius:1rem; background:#edf3f2; } .journey-step { display:grid; place-items:center; width:2.2rem; aspect-ratio:1; margin-bottom:.85rem; border-radius:50%; background:var(--clay); color:var(--white); font-weight:700; } .story { padding:1.6rem; border-radius:1rem; background:var(--white); box-shadow:var(--shadow); } .story strong { display:block; margin:.65rem 0 .2rem; font-family:'Playfair Display',Georgia,serif; font-size:1.35rem; } .story p { margin:0; } .mosaic-card { position:relative; min-height:250px; overflow:hidden; border-radius:1rem; background:var(--sage); } .mosaic-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); } .mosaic-card:hover img { transform:scale(1.055); } .mosaic-card--wide { min-height:340px; } .mosaic-caption { position:absolute; right:1rem; bottom:1rem; left:1rem; padding:.7rem .85rem; border-radius:.65rem; background:rgba(255,255,255,.9); color:var(--ink); font-size:.85rem; font-weight:700; } .hub { position:relative; overflow:hidden; padding:2.1rem; border-radius:1.3rem; background:linear-gradient(135deg,#e9f0ef 0%,#d1e0dd 100%); } .hub::after { content:''; position:absolute; width:13rem; height:13rem; right:-5rem; bottom:-7rem; border:2px solid rgba(154,94,64,.35); border-radius:50%; } .hub-grid { display:grid; gap:1.4rem; align-items:center; position:relative; z-index:1; } .hub-list { display:grid; gap:.65rem; list-style:none; padding:0; } .hub-list li::before { content:'\2713'; color:var(--clay); font-weight:700; margin-right:.55rem; } .testimonial-note { margin:1.3rem auto 0; max-width:62ch; text-align:center; font-size:.88rem; color:#5f726e; }
.resource-banner,.contact { background:#D8E3E1; } .page-hero { background:linear-gradient(120deg,#e7efed 0%,#D8E3E1 100%); } .services-band { background:var(--clay); }
main > section:last-child:has(.resource-banner) { display:none; }
.services-band { border-block:8px solid var(--white); } .course { border-top:0; border-bottom:8px solid var(--white); } .site-credit { display:block; margin-top:.8rem; padding:0; border:0; color:rgba(255,255,255,.48); background:none; font:inherit; font-size:.66rem; letter-spacing:.04em; cursor:pointer; } .site-credit:hover,.site-credit:focus-visible { color:var(--white); text-decoration:underline; text-underline-offset:3px; } .paw-confetti { position:fixed; z-index:200; width:3rem; height:3rem; object-fit:contain; pointer-events:none; animation:paw-burst 1.35s ease-out forwards; } @keyframes paw-burst { 0% { opacity:0; transform:translate(0,0) rotate(0) scale(.35); } 12% { opacity:1; } 100% { opacity:0; transform:translate(var(--x),var(--y)) rotate(var(--r)) scale(1); } }
.course .eyebrow,.course .eyebrow::after { color:#fce3d3; } .course .eyebrow::before { background:#fce3d3; } .course h2 { color:var(--white); text-shadow:0 2px 12px rgba(0,0,0,.17); }
.service-visual img[src*="marie-training"],.service-visual img[src*="bodie-zoom"] { width:100%; height:100%; object-fit:cover; filter:none; }
@media (min-width:700px) { .reason-grid { grid-template-columns:repeat(3,1fr); } .journey-grid { grid-template-columns:repeat(3,1fr); } .story-grid { grid-template-columns:repeat(3,1fr); } .photo-mosaic { grid-template-columns:1.05fr .95fr; align-items:stretch; } .photo-mosaic .mosaic-card:nth-child(2) { min-height:160px; } .photo-mosaic .mosaic-card:nth-child(3) { min-height:160px; } .photo-mosaic-side { display:grid; gap:1rem; } .hub-grid { grid-template-columns:1.15fr .85fr; } }
.eyebrow::after { content:'\2726'; }
body { background:radial-gradient(circle at 98% 6%,rgba(194,209,207,.35),transparent 18rem),var(--cream); } .hero::after,.page-hero::after { content:''; position:absolute; width:15rem; height:15rem; border:2px solid rgba(207,150,110,.32); border-radius:45% 55% 58% 42% / 52% 40% 60% 48%; pointer-events:none; } .hero::after { right:-5rem; bottom:-7rem; } .page-hero { position:relative; overflow:hidden; background:linear-gradient(120deg,#dce8e5 0%,var(--sage) 100%); } .page-hero::after { top:-8rem; left:-4rem; } .card,.download-card,.post { border-top:4px solid transparent; } .card:nth-child(1),.download-card:nth-child(1),.post:nth-child(1) { border-top-color:var(--clay); } .card:nth-child(2),.download-card:nth-child(2),.post:nth-child(2) { border-top-color:var(--sage); } .card:hover,.download-card:hover { transform:translateY(-5px) rotate(-.15deg); box-shadow:var(--shadow); } .card,.download-card { transition:transform .24s ease,box-shadow .24s ease; } .hero-paw { animation:gentle-float 6s ease-in-out infinite; } .hero-art::before { animation:soft-pulse 5s ease-in-out infinite; } .eyebrow { font-weight:700; } .eyebrow::after { content:'✦'; margin-left:.15rem; font-size:.75rem; color:var(--clay); } .journal-hero h1 { font-size:clamp(2.35rem,4.6vw,3.85rem); max-width:22ch; } .post h2 { font-size:clamp(1.55rem,2.2vw,2rem); max-width:20ch; } .post .post-kicker { margin:0 0 .45rem; color:var(--clay); font-size:.83rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; } .contact-item small { display:none; } .article-image[src*="post-games-not-punishment"] { display:none; } @keyframes gentle-float { 0%,100% { transform:rotate(-9deg) translateY(0); } 50% { transform:rotate(-6deg) translateY(-9px); } } @keyframes soft-pulse { 0%,100% { transform:scale(1); } 50% { transform:scale(1.035); } } @media (prefers-reduced-motion:reduce) { .hero-paw,.hero-art::before { animation:none; } } 
