/* Self-hosted fonts (variable, latin) so the correct weights render at first
   paint with no swap flash and the site works offline from file://. */
@font-face{font-family:'Newsreader';font-style:normal;font-weight:300 600;font-display:swap;src:url('fonts/newsreader-latin.woff2') format('woff2')}
@font-face{font-family:'Newsreader';font-style:italic;font-weight:300 500;font-display:swap;src:url('fonts/newsreader-italic-latin.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url('fonts/hankengrotesk-latin.woff2') format('woff2')}

:root{
  /* Brand accents (unchanged) */
  --pine:#1b2620;
  --evergreen:#2c3a30;
  --cedar:#a6917a;
  --sage:#9aa888;
  --madrona:#be7b57;
  --slate:#657b80;

  /* Surface (neutral) */
  --canvas:#ffffff;
  --surface-soft:#f7f7f7;
  --surface-strong:#f2f2f2;

  /* Hairlines & borders (neutral) */
  --hairline:#dddddd;
  --hairline-soft:#ebebeb;
  --border-strong:#c1c1c1;

  /* Text (neutral) */
  --ink:#222222;
  --body:#3f3f3f;
  --muted:#6a6a6a;
  --muted-soft:#929292;

  /* Legacy aliases kept intentionally for hand-edits / external snippets
     (the stylesheet itself now uses only the semantic names above). */
  --paper:var(--canvas);
  --fog:var(--surface-soft);
  --mist:var(--surface-strong);
  --line:var(--hairline);
  --soft:var(--body);

  /* Effects + type */
  --shadow:0 24px 60px rgba(28,31,26,.14);
  --shadow-soft:0 1px 2px rgba(28,31,26,.04), 0 10px 26px rgba(28,31,26,.06);
  --serif:"Newsreader", Georgia, serif;
  --sans:"Hanken Grotesk", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--canvas);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit}
button,input,textarea,select{font:inherit}
:focus-visible{outline:3px solid rgba(190,123,87,.45);outline-offset:3px}

.skip-link{position:absolute;left:-9999px;top:0;z-index:60;padding:12px 18px;background:var(--pine);color:var(--canvas);border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

.site{display:grid;grid-template-columns:292px minmax(0,1fr);min-height:100vh}
.sidebar{
  position:sticky;
  top:0;
  height:100vh;
  display:flex;
  flex-direction:column;
  padding:34px 24px 24px;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,247,247,.96));
  border-right:1px solid var(--hairline);
  z-index:5;
}
/* Soft shadow on the page side of the divider, fading into the content. */
.sidebar::after{
  content:"";
  position:absolute;
  top:0;
  left:100%;
  width:40px;
  height:100%;
  background:linear-gradient(90deg,rgba(28,31,26,.11),rgba(28,31,26,.03) 45%,rgba(28,31,26,0));
  pointer-events:none;
}
.brand{text-align:center;text-decoration:none}
.brand-logo{
  width:auto;
  height:132px;
  margin:0 auto 10px;
}
.brand-mark-sm{
  display:block;
  width:auto;
  height:34px;
}
.tagline,.label{
  display:block;
  margin-top:10px;
  font-size:.7rem;
  line-height:1.4;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
}
.tagline{color:var(--madrona)}

.nav{display:flex;flex-direction:column;gap:8px;margin:42px 0 24px}
.nav a{
  display:grid;
  grid-template-columns:24px 1fr;
  align-items:center;
  gap:14px;
  min-height:48px;
  padding:10px 14px;
  border-radius:8px;
  color:var(--body);
  text-decoration:none;
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:700;
  transition:background .2s,color .2s,transform .2s;
}
.nav a svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.nav a:hover,.nav a.active{background:var(--surface-strong);color:var(--pine)}
.nav a:hover{transform:translateX(2px)}
.side-quote{margin-top:auto;text-align:center;color:var(--cedar)}
.side-quote svg{width:24px;margin:0 auto 12px;fill:currentColor}
.side-quote p{
  margin:0 auto 14px;
  max-width:22ch;
  font-family:var(--serif);
  font-size:.98rem;
  font-style:italic;
  line-height:1.4;
  color:var(--ink);
}
.socials{display:flex;justify-content:center;gap:16px;margin-bottom:14px}
.socials a{
  display:grid;
  place-items:center;
  padding:6px;
  color:var(--body);
  background:transparent;
  text-decoration:none;
  transition:color .2s,transform .2s;
}
.socials a:hover{color:var(--pine);transform:translateY(-1px)}
.socials a.is-inactive{opacity:.4;pointer-events:none;cursor:default}
.socials svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8}
.side-quote p.copyright{margin:0 auto;max-width:none;text-align:center;color:var(--muted);font-family:var(--sans);font-style:normal;font-size:.6rem;letter-spacing:.04em;line-height:1.5}

.main{min-width:0}
section{scroll-margin-top:24px}
/* Packages sits directly below the dark-green Experience band; land flush at its
   top so the "Book a Session" jump doesn't reveal a sliver of green above it. */
#packages{scroll-margin-top:0}
/* FAQ is taller than the viewport, so the "center short sections" JS skips it.
   Give it a generous top margin so a nav click lands the heading framed (with
   breathing room above) instead of pinned to the very top. The section above it
   (Packages) is a light surface, so the extra space reads as clean padding. */
#faq{scroll-margin-top:clamp(72px,13vh,120px)}
.hero{
  position:relative;
  min-height:760px;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(390px,48%);
  isolation:isolate;
  overflow:hidden;
  background:var(--surface-soft);
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    linear-gradient(90deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.92) 36%,rgba(255,255,255,.2) 68%),
    url("images/portfolio/hero.jpg") right center/cover no-repeat;
  /* AVIF/WebP for browsers that support image-set(); older ones use the line above. */
  background:
    linear-gradient(90deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.92) 36%,rgba(255,255,255,.2) 68%),
    image-set(url("images/portfolio/hero.avif") type("image/avif"), url("images/portfolio/hero.webp") type("image/webp"), url("images/portfolio/hero.jpg") type("image/jpeg")) right center/cover no-repeat;
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:130px;
  z-index:-1;
  background:linear-gradient(0deg,var(--canvas),rgba(255,255,255,0));
}
.hero-copy{align-self:center;padding:70px 70px 110px;max-width:760px}
.eyebrow{display:flex;align-items:center;gap:10px;color:var(--madrona);margin-bottom:28px}
.eyebrow svg{width:22px;height:22px;fill:currentColor}
h1,h2,h3,p{margin-top:0}
h1{
  margin-bottom:28px;
  font-family:var(--serif);
  font-size:5.7rem;
  font-weight:300;
  line-height:.98;
}
h1 em,h2 em{font-style:italic;color:var(--madrona)}
.hero-copy p{max-width:32rem;margin-bottom:34px;color:var(--body);font-size:1.24rem}
.actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 24px;
  border:0;
  border-radius:999px;
  cursor:pointer;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:700;
  font-size:.76rem;
  transition:background .2s,color .2s,transform .2s,box-shadow .2s;
}
.btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7}
.btn-primary{background:var(--pine);color:var(--canvas);box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--madrona);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.68);color:var(--pine);border:1px solid var(--border-strong)}
.btn-ghost:hover{background:var(--canvas);transform:translateY(-2px)}
.hero-trust{list-style:none;margin:30px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:10px 24px}
.hero-trust li{display:flex;align-items:center;gap:9px;font-size:.92rem;font-weight:600;color:var(--body)}
.hero-trust svg{width:18px;height:18px;flex:none;stroke:var(--madrona);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

.feature-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-block:1px solid var(--hairline);
  background:rgba(255,255,255,.82);
}
.feature{
  display:grid;
  grid-template-columns:54px 1fr;
  gap:18px;
  align-items:center;
  padding:32px 28px;
  border-right:1px solid var(--hairline);
}
.feature:last-child{border-right:0}
.feature svg{width:54px;height:54px;stroke:var(--cedar);fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.feature h3{margin:0 0 8px;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase}
.feature p{margin:0;color:var(--body)}

.section-pad{padding:88px 70px}
.split{display:grid;grid-template-columns:minmax(280px,390px) minmax(0,1fr);gap:64px;align-items:start}
/* Center the Experience heading in its band so the "Experience" nav jump
   (which centers this short section on screen) lands the heading mid-screen. */
.experience .split{align-items:center}
.section-kicker{color:var(--madrona);margin-bottom:18px}
h2{
  margin-bottom:22px;
  font-family:var(--serif);
  font-weight:300;
  line-height:1.03;
  font-size:4.15rem;
}
.lead{font-size:1.15rem;color:var(--body);max-width:42rem}

.portfolio{background:linear-gradient(180deg,var(--canvas),var(--surface-soft))}
.portfolio-shell{display:grid;grid-template-columns:390px minmax(0,1fr);gap:54px;align-items:end}
.portfolio-copy{align-self:center}
.portfolio-stage{overflow-x:auto;-webkit-overflow-scrolling:touch}
.portfolio-stage.draggable{cursor:grab;scrollbar-width:none}
.portfolio-stage.draggable::-webkit-scrollbar{display:none}
.portfolio-stage.dragging{cursor:grabbing;user-select:none}
.portfolio-track{display:flex;gap:12px;align-items:center}
.portfolio-card{
  flex:0 0 auto;
  height:clamp(260px,40vh,380px);
  border-radius:8px;
  overflow:hidden;
  position:relative;
  background:var(--surface-strong);
  margin:0;
}
.portfolio-card img{display:block;width:auto;height:100%;object-fit:cover;pointer-events:none}
.counter{font-family:var(--serif);font-size:1.08rem;color:var(--muted);font-variant-numeric:tabular-nums}

.about{background:var(--canvas)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.about-photo{min-height:520px;border-radius:8px;overflow:hidden}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-copy{padding:22px 0 0 28px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.stat{padding-top:16px;border-top:1px solid var(--hairline)}
.stat strong{display:block;font-family:var(--serif);font-size:2.1rem;font-weight:300;color:var(--evergreen)}
.stat span{color:var(--muted);font-size:.9rem}

.experience{background:var(--pine);color:var(--canvas)}
.experience .lead,.experience .step p{color:rgba(255,253,248,.74)}
.experience .section-kicker{color:var(--sage)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px}
.step{padding:28px;border:1px solid rgba(255,253,248,.18);border-radius:8px;background:rgba(255,253,248,.04)}
.step .num{display:block;margin-bottom:24px;font-family:var(--serif);font-size:2.2rem;color:var(--cedar)}
.step h3{font-size:1.05rem;margin-bottom:10px}
.step p{margin:0}

.packages{background:var(--surface-soft)}
.package-guarantee{display:flex;align-items:center;gap:11px;margin:18px 0 0;color:var(--evergreen);font-weight:600;font-size:1rem}
.package-guarantee svg{width:22px;height:22px;flex:none;stroke:var(--madrona);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.package-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
.package-proof{display:flex;align-items:center;gap:7px;margin:0 0 7px;font-size:.85rem;color:var(--muted)}
.package-proof .stars{color:#d8a44b;letter-spacing:1px;font-size:.92rem}
.package-proof .rating{font-weight:700;color:var(--ink)}
.package-heat{display:flex;align-items:center;gap:7px;margin:0 0 18px;font-size:.82rem;font-weight:600;color:var(--muted)}
.package-heat .flame{flex:none;font-size:1.05rem;line-height:1}
.package-heat strong{color:var(--ink);font-weight:700}
.package.featured .package-proof,.package.featured .package-heat{color:rgba(255,253,248,.78)}
.package.featured .package-proof .rating,.package.featured .package-heat strong{color:var(--canvas)}
.package{
  display:flex;
  flex-direction:column;
  min-height:430px;
  padding:30px;
  border-radius:8px;
  border:1px solid var(--hairline);
  background:var(--canvas);
  box-shadow:var(--shadow-soft);
}
.package.featured{background:var(--evergreen);color:var(--canvas);transform:translateY(-14px);box-shadow:0 14px 34px rgba(28,31,26,.16)}
.package .label{margin:0 0 18px;color:var(--madrona)}
.package.featured .label{color:var(--sage)}
.price{font-family:var(--serif);font-size:3.35rem;font-weight:600;margin-bottom:14px}
.package p{color:var(--body)}
.package.featured p{color:rgba(255,253,248,.75)}
.package ul{margin:16px 0 0;padding:0;list-style:none}
.package li{padding:11px 0;border-top:1px solid var(--hairline-soft);color:var(--body)}
.package.featured li{border-top-color:rgba(255,253,248,.16);color:rgba(255,253,248,.82)}
.package .btn{margin-top:auto;align-self:flex-start}
.package.featured .btn{background:var(--canvas);color:var(--pine)}
.addons{margin-top:28px;color:var(--muted);font-size:.95rem}

/* Gift certificates page (gift-certificates.html) */
.giftcert{background:var(--canvas)}
.gift-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,430px);gap:60px;align-items:center}
.gift-copy{max-width:620px}
.gift-art{margin:0;border-radius:14px;overflow:hidden;background:var(--surface-soft);box-shadow:var(--shadow)}
.gift-art img{display:block;width:100%;height:auto}
.gift-actions{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:8px}
.giftcert .lead{margin-bottom:14px}
.giftcert h2{font-size:1.5rem;font-style:italic;font-weight:400;margin:40px 0 8px}
.giftcert-steps{margin:0 0 36px;padding:0;list-style:none;counter-reset:gc}
.giftcert-steps li{position:relative;padding:15px 0 15px 46px;border-top:1px solid var(--hairline-soft);color:var(--body);font-size:1.06rem;counter-increment:gc}
.giftcert-steps li::before{content:counter(gc);position:absolute;left:0;top:13px;font-family:var(--serif);font-size:1.4rem;color:var(--cedar);line-height:1}
.giftcert .fineprint{margin:32px 0 0;color:var(--muted);font-size:.92rem}

.faq-contact{background:linear-gradient(180deg,var(--surface-soft),var(--canvas))}
.faq-contact-grid{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:54px}
.faq-hint{margin:0 0 20px;color:var(--muted);font-size:.95rem}
.faq-list{border-top:1px solid var(--hairline-soft)}
.faq-item{border-bottom:1px solid var(--hairline-soft)}
.faq-button{
  width:100%;
  min-height:68px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 0;
  background:transparent;
  color:var(--ink);
  cursor:pointer;
  text-align:left;
  font-weight:700;
  list-style:none;
}
.faq-button::-webkit-details-marker{display:none}
.faq-button svg{
  width:15px;height:15px;flex:none;
  padding:8px;box-sizing:content-box;
  color:var(--madrona);
  stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;
  border:1px solid var(--hairline);border-radius:50%;
  transition:transform .2s, background .2s, border-color .2s, color .2s;
}
.faq-item[open] .faq-button svg{transform:rotate(45deg)}
.faq-button:hover{color:var(--madrona)}
.faq-button:hover svg{background:var(--madrona);border-color:var(--madrona);color:var(--canvas)}
.faq-panel{padding:0 0 22px;color:var(--body);max-width:62ch}

.contact-card{
  position:sticky;
  top:28px;
  padding:30px;
  border-radius:8px;
  background:var(--pine);
  color:var(--canvas);
  box-shadow:var(--shadow);
}
.contact-card h3{margin:0 0 10px;font-family:var(--serif);font-weight:300;font-size:2.3rem;line-height:1.05}
.contact-card p{color:rgba(255,253,248,.75)}
.contact-card a{color:var(--sage)}
form{display:grid;gap:14px;margin-top:24px}
label{display:grid;gap:7px;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--sage)}
input,textarea,select{
  width:100%;
  border:1px solid rgba(255,253,248,.22);
  border-radius:8px;
  padding:13px 14px;
  color:var(--canvas);
  background:rgba(255,253,248,.08);
}
textarea{min-height:118px;resize:vertical}
input::placeholder,textarea::placeholder{color:rgba(255,253,248,.45)}
.field-error{min-height:0;color:var(--madrona);font-size:.82rem;font-weight:600;letter-spacing:0;text-transform:none}
.form-note{min-height:22px;margin:4px 0 0;color:var(--sage);font-size:.9rem}

footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:28px 70px;
  background:var(--pine);
  color:rgba(255,253,248,.74);
}
footer>p{margin:0;align-self:center}
.footer-wordmark{display:block;width:auto;height:30px;flex:none}
/* A trail of dog paw prints heading left-to-right toward the tagline.
   Toes point right (direction of travel); opacity grows toward the tagline. */
.paw-trail{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-evenly;gap:14px;padding:0 26px}
.paw-trail .paw{width:21px;height:21px;flex:none;color:var(--madrona);fill:currentColor;transform:translateY(var(--ty)) rotate(90deg)}
.paw-trail .paw:nth-child(odd){--ty:-3px}
.paw-trail .paw:nth-child(even){--ty:3px}
.paw-trail .paw:nth-child(1){opacity:.22}
.paw-trail .paw:nth-child(2){opacity:.36}
.paw-trail .paw:nth-child(3){opacity:.50}
.paw-trail .paw:nth-child(4){opacity:.64}
.paw-trail .paw:nth-child(5){opacity:.80}
.paw-trail .paw:nth-child(6){opacity:.96}

.mobile-bar{display:none}
.mobile-only{display:none}

@media (max-width:1180px){
  .site{grid-template-columns:240px minmax(0,1fr)}
  .sidebar{padding-inline:18px}
  .hero{grid-template-columns:1fr;min-height:700px}
  .hero-copy{padding-inline:48px}
  h1{font-size:4.4rem}
  h2{font-size:3.3rem}
  .feature-strip{grid-template-columns:repeat(2,1fr)}
  .feature:nth-child(2){border-right:0}
  .feature:nth-child(-n+2){border-bottom:1px solid var(--hairline)}
  .portfolio-shell,.split,.faq-contact-grid{grid-template-columns:1fr}
  .portfolio-copy{max-width:620px}
  .about-copy{padding-left:0}
  .contact-card{position:static}
}

@media (max-width:820px){
  .site{display:block}
  .mobile-bar{
    position:sticky;
    top:0;
    z-index:20;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:22px;
    padding:12px 18px;
    width:100vw;
    overflow:hidden;
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(12px);
    border-bottom:1px solid var(--hairline);
  }
  .mobile-bar .brand{text-align:left}
  .menu-toggle{border:1px solid var(--hairline);background:var(--surface-strong);border-radius:50%;width:42px;height:42px;display:grid;place-items:center;color:var(--pine);flex:none}
  .menu-toggle svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8}
  .sidebar{
    position:fixed;
    inset:0 auto 0 0;
    z-index:30;
    width:min(320px,84vw);
    transform:translateX(-104%);
    transition:transform .25s ease;
    box-shadow:var(--shadow);
  }
  .sidebar::after{display:none}
  .sidebar.open{transform:none}
  .hero{min-height:690px}
  .hero::before{
    background:
      linear-gradient(180deg,rgba(255,255,255,.99) 0%,rgba(255,255,255,.92) 46%,rgba(255,255,255,.18) 100%),
      url("images/portfolio/hero.jpg") center bottom/cover no-repeat;
    background:
      linear-gradient(180deg,rgba(255,255,255,.99) 0%,rgba(255,255,255,.92) 46%,rgba(255,255,255,.18) 100%),
      image-set(url("images/portfolio/hero.avif") type("image/avif"), url("images/portfolio/hero.webp") type("image/webp"), url("images/portfolio/hero.jpg") type("image/jpeg")) center bottom/cover no-repeat;
  }
  .hero-copy{align-self:start;padding:64px 24px 250px;width:min(100%,390px);overflow:hidden}
  h1{font-size:2.85rem;line-height:1.08}
  .mobile-only{display:block}
  .hero-copy p{font-size:1.08rem}
  .actions{align-items:stretch;flex-direction:column;max-width:330px}
  .btn{width:100%}
  .section-pad{padding:66px 24px}
  .feature-strip{grid-template-columns:1fr}
  .feature{border-right:0;border-bottom:1px solid var(--hairline)}
  .feature:last-child{border-bottom:0}
  .portfolio-card{height:clamp(240px,46vw,360px)}
  .about-grid,.steps,.package-grid,.stats,.gift-grid{grid-template-columns:1fr}
  .gift-grid{gap:34px}
  .gift-art{max-width:420px}
  .package.featured{transform:none}
  footer{display:block;padding:28px 24px}
  footer p{margin-bottom:0}
  .paw-trail{justify-content:flex-start;gap:16px;padding:14px 0}
  /* Mobile: trim clutter — drop the "Easy for you. Gentle for them." Experience
     band (and its now-dead nav link) to keep phone payload/scroll short. */
  .experience{display:none}
  .nav a[href="#experience"]{display:none}
}

@media (max-width:480px){
  h1{font-size:2.62rem;line-height:1.08}
  h2{font-size:2.65rem}
  .actions{align-items:stretch;flex-direction:column}
  .btn{width:100%}
  .about-photo{min-height:360px}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}

/* ===== Portfolio vertical-slider gallery (portfolio.html only) ===== */
.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}

/* Base layout is a real two-column CSS masonry (works with NO JS): photos flow
   into two equal-width columns at their natural proportions, varying heights.
   The JS enhancement below only layers on the staggered reveal — it is never
   required to get two columns. */
.vslider{
  position:relative;
  padding:clamp(8px,1.2vw,18px) clamp(8px,1.2vw,18px) 12vh;
  column-count:2;
  column-gap:clamp(8px,1.2vw,18px);
}
.vcard{
  display:block;
  margin:0 0 clamp(10px,1.6vh,20px);
  break-inside:avoid;
  -webkit-column-break-inside:avoid;
  overflow:hidden;
  border-radius:3px;
  background:var(--surface-strong);
  box-shadow:var(--shadow);
}
.vcard:last-child{margin-bottom:0}
.vcard img{width:100%;height:auto;display:block}

/* Enhanced (JS): same two columns, but built as balanced flex columns so each
   card can rise + scale into view. display:flex supersedes the CSS columns. */
.vslider.is-enhanced{display:flex;column-count:initial;align-items:flex-start;gap:clamp(8px,1.2vw,18px)}
.vslider.is-enhanced .vcol{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:clamp(8px,1.2vw,18px)}
.vslider.is-enhanced .vcol--offset{margin-top:clamp(28px,7vh,90px)}

/* Rise + scale on entry. Opt-in via .is-enhanced, so the no-JS baseline shows
   every photo at rest. */
.vslider.is-enhanced .vcard{
  max-width:none;
  margin:0;
  opacity:0;
  transform:translateY(46px) scale(.955);
  transition:opacity .85s ease, transform .9s cubic-bezier(.16,1,.3,1);
}
.vslider.is-enhanced .vcard.is-in{opacity:1;transform:none}

.vslider-progress{
  position:fixed;
  right:clamp(16px,3vw,40px);
  bottom:clamp(16px,3vh,36px);
  z-index:15;
  padding:8px 15px;
  font-family:var(--serif);
  font-size:1.05rem;
  letter-spacing:.04em;
  color:var(--body);
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(8px);
  border:1px solid var(--hairline);
  border-radius:999px;
  font-variant-numeric:tabular-nums;
  pointer-events:none;
}

@media (max-width:820px){
  .vslider{padding:12px 12px 14vh;column-count:1}
  .vcard{max-width:560px;margin-left:auto;margin-right:auto}
  .vslider.is-enhanced{flex-direction:column;gap:clamp(8px,2vw,16px)}
  .vslider.is-enhanced .vcol{gap:clamp(8px,2vw,16px)}
  .vslider.is-enhanced .vcol--offset{margin-top:0}
  .vcard{border-radius:3px}
}
