/* ============================================================
   PROGRESS MD — Amarillo, TX · rebuild by MADE IMMERSIVE
   Art direction: clinical cinema in their own colors.
   Ink-navy base (their logo navy) · porcelain bone · matured sage.
   Signature: the progress line — a thin sage rule that draws in.
   ============================================================ */

:root{
  --ink:      #0d1424;
  --ink-2:    #131c33;
  --ink-3:    #1a2542;
  --bone:     #f5f1e9;
  --bone-2:   #ebe5d9;
  --sage:     #a9c096;
  --sage-deep:#75906a;
  --sage-dark:#4c6544;
  --text-d:   #e8e3d8;   /* text on dark */
  --text-dm:  #a7a89f;   /* muted on dark */
  --text-l:   #171d2c;   /* text on light */
  --text-lm:  #5c6070;   /* muted on light */
  --line-d:   rgba(232,227,216,.14);
  --line-l:   rgba(23,29,44,.14);
  --serif: "Bodoni Moda", "Didot", Georgia, serif;
  --sans:  "Switzer", -apple-system, "Helvetica Neue", Arial, sans-serif;
  --mono:  ui-monospace, "SF Mono", "Menlo", monospace;
  --pad: clamp(20px, 5vw, 72px);
  --max: 1280px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  background:var(--ink);
  color:var(--text-d);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
::selection{ background:var(--sage); color:var(--ink); }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- type scale ---------- */
.h-display{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(44px, 8.2vw, 118px);
  line-height:1.02;
  letter-spacing:-.01em;
}
.h-display em{ font-style:italic; font-weight:400; color:var(--sage); }
.h1{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(36px, 5.4vw, 72px); line-height:1.05;
}
.h2{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(30px, 4vw, 52px); line-height:1.1;
}
.h2 em, .h1 em{ font-style:italic; color:var(--sage-deep); }
.on-dark .h2 em, .on-dark .h1 em{ color:var(--sage); }
.h3{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(22px, 2.4vw, 30px); line-height:1.2;
}
.label{
  font-family:var(--mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--sage-deep);
}
.on-dark .label{ color:var(--sage); }
.lede{ font-size:clamp(17px, 1.5vw, 20px); line-height:1.7; max-width:56ch; }
.muted{ color:var(--text-dm); }
.light .muted{ color:var(--text-lm); }

/* ---------- the progress line (signature) ---------- */
.progress-rule{
  position:relative; height:1px; background:var(--line-d); overflow:hidden;
}
.light .progress-rule{ background:var(--line-l); }
.progress-rule::after{
  content:""; position:absolute; inset:0;
  background:var(--sage);
  transform:scaleX(0); transform-origin:left center;
  transition:transform 1.6s cubic-bezier(.22,1,.36,1);
}
.progress-rule.is-in::after{ transform:scaleX(1); }

/* scroll progress beam, top of viewport */
#scrollbeam{
  position:fixed; top:0; left:0; height:2px; width:100%;
  transform-origin:left center; transform:scaleX(0);
  background:linear-gradient(90deg, var(--sage-deep), var(--sage));
  z-index:200; pointer-events:none;
}

/* ---------- header ---------- */
header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .45s ease, border-color .45s ease;
  border-bottom:1px solid transparent;
}
header.is-solid{
  background:rgba(13,20,36,.92);
  -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border-bottom-color:var(--line-d);
}
.nav{
  max-width:var(--max); margin:0 auto; padding:0 var(--pad);
  display:flex; align-items:center; justify-content:space-between;
  height:78px;
}
.nav-logo img{ height:26px; width:auto; filter:brightness(0) invert(1) opacity(.94); }
.nav-links{ display:flex; gap:34px; align-items:center; }
.nav-links a{
  font-size:14px; letter-spacing:.04em; color:var(--text-d); opacity:.82;
  position:relative; padding:6px 0; transition:opacity .3s;
}
.nav-links a:hover{ opacity:1; }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--sage); transform:scaleX(0); transform-origin:left center;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.nav-links a:hover::after, .nav-links a.is-here::after{ transform:scaleX(1); }
.nav-cta{
  font-size:13px; letter-spacing:.06em;
  border:1px solid var(--sage); color:var(--sage) !important; opacity:1 !important;
  padding:10px 22px !important; border-radius:99px;
  transition:background .35s, color .35s !important;
}
.nav-cta:hover{ background:var(--sage); color:var(--ink) !important; }
.nav-cta::after{ display:none; }

/* mobile nav */
.nav-burger{
  display:none; background:none; border:0; cursor:pointer;
  width:40px; height:40px; position:relative; z-index:130;
}
.nav-burger span{
  position:absolute; left:8px; right:8px; height:1.5px; background:var(--text-d);
  transition:transform .4s, opacity .3s, top .4s;
}
.nav-burger span:nth-child(1){ top:15px; }
.nav-burger span:nth-child(2){ top:24px; }
body.nav-open .nav-burger span:nth-child(1){ top:19px; transform:rotate(45deg); }
body.nav-open .nav-burger span:nth-child(2){ top:19px; transform:rotate(-45deg); }
.mobile-menu{
  display:none; position:fixed; inset:0; z-index:120;
  background:rgba(13,20,36,.98);
  -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
  padding:120px var(--pad) 48px;
  flex-direction:column; gap:8px;
  opacity:0; pointer-events:none; transition:opacity .4s ease;
}
body.nav-open .mobile-menu{ opacity:1; pointer-events:auto; }
.mobile-menu a{
  font-family:var(--serif); font-size:34px; line-height:1.35; padding:8px 0;
  border-bottom:1px solid var(--line-d);
}
.mobile-menu a.m-cta{ color:var(--sage); }
.mobile-menu .m-meta{ margin-top:auto; font-size:14px; color:var(--text-dm); }
.mobile-menu .m-meta a{ font-family:var(--sans); font-size:14px; border:0; padding:0; display:inline; }

/* ---------- sections ---------- */
section{ position:relative; }
.wrap{ max-width:var(--max); margin:0 auto; padding:0 var(--pad); }
.sec{ padding:clamp(84px, 11vw, 160px) 0; }
.light{ background:var(--bone); color:var(--text-l); }
.light-2{ background:var(--bone-2); color:var(--text-l); }
.on-dark{ color:var(--text-d); }

/* section head pattern: label + rule + heading */
.sec-head{ margin-bottom:clamp(40px, 6vw, 80px); }
.sec-head .label{ display:block; margin-bottom:18px; }
.sec-head .progress-rule{ margin:26px 0 0; max-width:180px; }

/* ---------- reveal motion ---------- */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity 1s cubic-bezier(.22,1,.36,1), transform 1s cubic-bezier(.22,1,.36,1); }
[data-reveal].is-in{ opacity:1; transform:none; }
[data-reveal="fade"]{ transform:none; }
.d1{ transition-delay:.12s; } .d2{ transition-delay:.24s; } .d3{ transition-delay:.36s; } .d4{ transition-delay:.48s; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none; }
  .progress-rule::after{ transition:none; }
}

/* ---------- hero (home) ---------- */
.hero{
  min-height:100svh; display:flex; align-items:flex-end;
  position:relative; overflow:clip;
  padding-bottom:clamp(56px, 8vh, 96px);
}
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; object-position:center;
  transform:scale(1.08); animation:heroDrift 18s ease-out forwards; }
@keyframes heroDrift{ to{ transform:scale(1.0); } }
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(13,20,36,.55) 0%, rgba(13,20,36,.18) 40%, rgba(13,20,36,.86) 100%),
    linear-gradient(90deg, rgba(13,20,36,.5) 0%, rgba(13,20,36,0) 60%);
}
.hero .wrap{ position:relative; z-index:1; width:100%; }
.hero-kicker{ margin-bottom:22px; }
.hero-title{ max-width:11ch; }
.hero-sub{ margin-top:28px; max-width:46ch; font-size:clamp(16px,1.4vw,19px); color:var(--text-d); opacity:.88; }
.hero-cta-row{ display:flex; align-items:center; gap:28px; margin-top:40px; flex-wrap:wrap; }
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-size:14px; letter-spacing:.05em;
  padding:16px 34px; border-radius:99px;
  border:1px solid var(--sage); color:var(--ink); background:var(--sage);
  transition:background .35s, color .35s, border-color .35s;
}
.btn:hover{ background:transparent; color:var(--sage); }
.btn-ghost{ background:transparent; color:var(--text-d); border-color:var(--line-d); }
.btn-ghost:hover{ border-color:var(--sage); color:var(--sage); background:transparent; }
.light .btn-ghost{ color:var(--text-l); border-color:var(--line-l); }
.light .btn-ghost:hover{ color:var(--sage-dark); border-color:var(--sage-deep); }
.star-line{
  display:flex; align-items:center; gap:10px;
  font-size:13.5px; letter-spacing:.02em; color:var(--text-d); opacity:.85;
}
.star-line .stars{ color:var(--sage); letter-spacing:.12em; font-size:12px; }

/* hero progress line runs the full width under content */
.hero-rule{ margin-top:clamp(36px,5vh,60px); }

/* ---------- trust strip ---------- */
.trust{ border-top:1px solid var(--line-d); border-bottom:1px solid var(--line-d); background:var(--ink-2); }
.trust .wrap{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:0;
}
.trust-item{
  padding:34px 28px; border-left:1px solid var(--line-d);
}
.trust-item:first-child{ border-left:0; }
.trust-item .t-big{
  font-family:var(--serif); font-size:clamp(24px,2.4vw,34px); line-height:1.1; color:var(--text-d);
}
.trust-item .t-small{ font-size:13px; color:var(--text-dm); margin-top:8px; line-height:1.5; }

/* ---------- story band (Lydia) ---------- */
.story{ background:var(--bone); color:var(--text-l); overflow:clip; }
.story-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,6vw,96px);
  align-items:center;
}
.story-imgs{ position:relative; }
.story-imgs .img-a{ width:78%; overflow:clip; border-radius:2px; }
.story-imgs .img-b{
  position:absolute; right:0; bottom:-12%; width:46%;
  overflow:clip; border-radius:2px;
  box-shadow:0 30px 60px -30px rgba(13,20,36,.45);
}
.story-imgs img{ width:100%; height:auto; }
.story-quote{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(20px,1.9vw,25px); line-height:1.45;
  color:var(--sage-dark); margin:30px 0 8px;
  max-width:30ch;
}
.story-attr{ font-size:13.5px; color:var(--text-lm); }

/* ---------- doors (two service worlds) ---------- */
.doors-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,2.4vw,32px); }
.door{
  position:relative; overflow:clip; border-radius:2px;
  aspect-ratio:4/5; display:flex; align-items:flex-end;
  isolation:isolate;
}
.door img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-1;
  transition:transform 1.4s cubic-bezier(.22,1,.36,1);
}
.door:hover img{ transform:scale(1.05); }
.door::after{
  content:""; position:absolute; inset:0; z-index:0;
  background:linear-gradient(180deg, rgba(13,20,36,.06) 30%, rgba(13,20,36,.82) 100%);
  transition:background .5s;
}
.door-body{ position:relative; z-index:1; padding:clamp(24px,3vw,44px); width:100%; }
.door-body .label{ color:var(--sage); }
.door-title{
  font-family:var(--serif); font-size:clamp(28px,3vw,42px); line-height:1.08;
  margin:12px 0 10px; color:var(--text-d);
}
.door-sub{ font-size:14.5px; color:var(--text-d); opacity:.8; max-width:40ch; }
.door-go{
  display:inline-flex; align-items:center; gap:10px; margin-top:18px;
  font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--sage);
}
.door-go .arr{ transition:transform .4s; }
.door:hover .door-go .arr{ transform:translateX(6px); }

/* ---------- toolbox band ---------- */
.toolbox{ background:var(--ink-2); }
.toolbox-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(40px,6vw,90px); align-items:center; }
.toolbox-img{ overflow:clip; border-radius:2px; }
.tool-list{ margin-top:34px; display:grid; gap:0; }
.tool-row{
  display:flex; justify-content:space-between; align-items:baseline; gap:20px;
  padding:16px 0; border-bottom:1px solid var(--line-d);
}
.tool-row:first-child{ border-top:1px solid var(--line-d); }
.tool-name{ font-family:var(--serif); font-size:clamp(17px,1.6vw,21px); }
.tool-tag{ font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dm); text-align:right; white-space:nowrap; }

/* ---------- review teaser / reviews page ---------- */
.review-band{ background:var(--bone-2); color:var(--text-l); }
.big-quote{
  font-family:var(--serif); font-style:italic; font-weight:400;
  font-size:clamp(26px,3.4vw,46px); line-height:1.3;
  max-width:26ch;
}
.big-quote .qm{ color:var(--sage-deep); }
.quote-attr{ margin-top:26px; font-size:14px; color:var(--text-lm); display:flex; align-items:center; gap:14px; }
.quote-attr .stars{ color:var(--sage-dark); letter-spacing:.12em; font-size:12px; }

.review-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.4vw,32px); }
.review-card{
  background:var(--bone); border:1px solid var(--line-l); border-radius:2px;
  padding:clamp(28px,3vw,44px);
  display:flex; flex-direction:column; gap:18px;
}
.review-card .stars{ color:var(--sage-dark); letter-spacing:.14em; font-size:13px; }
.review-card p{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(18px,1.7vw,22px); line-height:1.5; color:var(--text-l);
}
.review-card .who{ margin-top:auto; font-size:13.5px; color:var(--text-lm); }

/* ---------- visit band ---------- */
.visit-band{ position:relative; overflow:clip; }
.visit-band .visit-bg{ position:absolute; inset:0; }
.visit-band .visit-bg img{ width:100%; height:100%; object-fit:cover; }
.visit-band .visit-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(13,20,36,.92), rgba(13,20,36,.72)); }
.visit-band .wrap{ position:relative; z-index:1; }
.visit-cols{ display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(40px,6vw,100px); }
.hours-list{ margin-top:26px; }
.hours-row{
  display:flex; justify-content:space-between; gap:18px;
  padding:12px 0; border-bottom:1px solid var(--line-d);
  font-size:15px;
}
.hours-row .d{ color:var(--text-dm); }
.addr{ font-size:16px; line-height:1.8; }
.addr a{ color:var(--sage); }
.light .addr a{ color:var(--sage-dark); border-bottom:1px solid var(--sage-deep); }

/* ---------- inner page hero ---------- */
.page-hero{
  padding:calc(78px + clamp(64px,10vw,130px)) 0 clamp(56px,7vw,96px);
  position:relative; overflow:clip;
}
.page-hero.has-img{ min-height:72svh; display:flex; align-items:flex-end; padding-bottom:clamp(48px,6vw,80px); }
.page-hero .ph-bg{ position:absolute; inset:0; }
.page-hero .ph-bg img{ width:100%; height:100%; object-fit:cover; }
.page-hero .ph-bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(13,20,36,.6) 0%, rgba(13,20,36,.35) 45%, rgba(13,20,36,.9) 100%);
}
.page-hero .wrap{ position:relative; z-index:1; }
.page-hero .lede{ margin-top:24px; }

/* ---------- treatment sections ---------- */
.tx-section{ border-top:1px solid var(--line-l); }
.tx-section:first-of-type{ border-top:0; }
.tx-grid{
  display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(36px,5vw,80px);
  align-items:start;
}
.tx-grid.flip{ grid-template-columns:1.15fr .85fr; }
.tx-grid.flip .tx-media{ order:2; }
.tx-media{ position:sticky; top:110px; overflow:clip; border-radius:2px; }
.tx-media img{ width:100%; height:auto; }
.tx-item{ padding:26px 0; border-bottom:1px solid var(--line-l); }
.tx-item:last-child{ border-bottom:0; }
.tx-item h4{
  font-family:var(--serif); font-weight:500; font-size:clamp(19px,1.9vw,24px);
  display:flex; justify-content:space-between; align-items:baseline; gap:16px;
}
.tx-item .tx-note{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--sage-dark); white-space:nowrap; }
.tx-item p{ margin-top:10px; font-size:15.5px; color:var(--text-lm); max-width:60ch; }

/* price list rows (lashes etc.) */
.price-row{
  display:flex; justify-content:space-between; align-items:baseline; gap:14px;
  padding:14px 0; border-bottom:1px solid var(--line-l);
}
.price-row .p-name{ font-family:var(--serif); font-size:18px; }
.price-row .p-amt{ font-family:var(--mono); font-size:13px; letter-spacing:.06em; color:var(--sage-dark); }
.price-row .p-dots{ flex:1; border-bottom:1px dotted var(--line-l); transform:translateY(-4px); }

/* ---------- team ---------- */
.team-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3vw,40px);
}
.team-card{ display:flex; flex-direction:column; }
.team-photo{ overflow:clip; border-radius:2px; aspect-ratio:3/4; }
.team-photo img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s cubic-bezier(.22,1,.36,1); }
.team-card:hover .team-photo img{ transform:scale(1.04); }
.team-card h4{ font-family:var(--serif); font-weight:500; font-size:21px; margin-top:18px; }
.team-card .t-role{ font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--sage-dark); margin-top:6px; }
.team-card p{ font-size:14.5px; color:var(--text-lm); margin-top:12px; line-height:1.6; }

/* pillars */
.pillar-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.6vw,36px); }
.pillar{
  border:1px solid var(--line-d); border-radius:2px; padding:clamp(26px,2.8vw,40px);
  background:var(--ink-2);
}
.pillar .p-num{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; color:var(--sage); }
.pillar h4{ font-family:var(--serif); font-weight:500; font-size:22px; margin:14px 0 10px; }
.pillar p{ font-size:14.5px; color:var(--text-dm); }

/* ---------- CTA close ---------- */
.close-cta{ text-align:center; }
.close-cta .h1{ max-width:18ch; margin:0 auto; }
.close-cta .btn{ margin-top:38px; }
.close-cta .star-line{ justify-content:center; margin-top:26px; }

/* ---------- footer ---------- */
footer{ border-top:1px solid var(--line-d); background:var(--ink); padding:56px 0 40px; }
.foot-grid{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start; }
.foot-logo img{ height:22px; filter:brightness(0) invert(1) opacity(.85); }
.foot-col{ font-size:14px; color:var(--text-dm); line-height:2; }
.foot-col a:hover{ color:var(--sage); }
.foot-col .label{ margin-bottom:10px; display:block; }
.foot-legal{
  margin-top:44px; padding-top:22px; border-top:1px solid var(--line-d);
  display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap;
  font-size:12px; color:var(--text-dm);
}
.foot-legal a{ color:var(--sage-deep); }

/* ---------- responsive ---------- */
@media (max-width: 1020px){
  .trust .wrap{ grid-template-columns:repeat(2,1fr); }
  .trust-item:nth-child(3){ border-left:0; }
  .trust-item{ border-top:1px solid var(--line-d); }
  .trust-item:nth-child(-n+2){ border-top:0; }
  .team-grid{ grid-template-columns:repeat(2,1fr); }
  .pillar-grid{ grid-template-columns:1fr; }
}
@media (max-width: 860px){
  .nav-links{ display:none; }
  .nav-burger{ display:block; }
  .mobile-menu{ display:flex; }
  .story-grid, .toolbox-grid, .visit-cols{ grid-template-columns:1fr; }
  .tx-grid, .tx-grid.flip{ grid-template-columns:1fr; }
  .tx-media{ position:relative; top:0; max-height:52vh; }
  .tx-media img{ height:100%; object-fit:cover; }
  .tx-grid.flip .tx-media{ order:0; }
  .doors-grid{ grid-template-columns:1fr; }
  .door{ aspect-ratio:4/3; }
  .review-grid{ grid-template-columns:1fr; }
  .story-imgs .img-b{ bottom:-8%; }
  .story-grid > div:last-child{ padding-bottom:24px; }
}
@media (max-width: 560px){
  body{ font-size:16px; }
  .team-grid{ grid-template-columns:1fr; }
  .trust .wrap{ grid-template-columns:1fr; }
  .trust-item{ border-left:0 !important; padding:22px 0; }
  .trust-item:first-child{ border-top:0; }
  .hero-cta-row{ gap:18px; }
}
