/* ============================================================
   Homepage + signature hero — Pacific Sound Plastic Surgery
   ============================================================ */

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;isolation:isolate;overflow:hidden;
  padding-top:calc(var(--header-h) + 2rem);padding-bottom:3rem}
.hero__bg{position:absolute;inset:0;z-index:-2;background:
  radial-gradient(60% 50% at 78% 22%,rgba(231,216,191,.9) 0%,transparent 60%),
  radial-gradient(55% 45% at 18% 78%,rgba(214,196,164,.55) 0%,transparent 55%),
  var(--bg)}
/* animated mesh gradient canvas sits over bg */
.hero__mesh{position:absolute;inset:0;z-index:-1;opacity:.9;mix-blend-mode:multiply}
.hero__grain{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Ccircle cx='1' cy='1' r='1' fill='%231a1a1a' opacity='0.05'/%3E%3C/svg%3E")}
.hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(1.5rem,4vw,4rem);align-items:center;width:100%}
.hero__copy{max-width:42ch}
.hero__eyebrow{font-size:.8rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep);
  display:flex;align-items:center;gap:.7rem;margin-bottom:1.4rem}
.hero__eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.hero h1{font-size:clamp(2.7rem,6.2vw,5.4rem);font-weight:320;line-height:1.02;margin-bottom:1.3rem}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line > span{display:block;transform:translateY(110%);transition:transform 1s var(--ease)}
.hero.ready h1 .line > span{transform:none}
.hero h1 .line:nth-child(2) > span{transition-delay:.12s}
.hero h1 .line:nth-child(3) > span{transition-delay:.24s}
.hero h1 em{font-style:italic;color:var(--gold-deep)}
.hero__lead{font-size:clamp(1.08rem,1.5vw,1.3rem);color:var(--ink-soft);max-width:46ch;margin-bottom:2rem;
  opacity:0;transform:translateY(16px);transition:opacity 1s var(--ease) .5s,transform 1s var(--ease) .5s}
.hero.ready .hero__lead{opacity:1;transform:none}
.hero__cta{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center;
  opacity:0;transform:translateY(16px);transition:opacity 1s var(--ease) .65s,transform 1s var(--ease) .65s}
.hero.ready .hero__cta{opacity:1;transform:none}
.hero__trust{display:flex;flex-wrap:wrap;gap:.5rem 1.4rem;margin-top:2.2rem;
  opacity:0;transition:opacity 1s var(--ease) .85s}
.hero.ready .hero__trust{opacity:1}
.hero__trust span{display:inline-flex;align-items:center;gap:.5rem;font-size:.86rem;color:var(--ink-soft);font-weight:500}
.hero__trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold)}

/* hero portrait card */
.hero__media{position:relative;justify-self:end}
.hero__portrait{position:relative;width:min(420px,42vw);aspect-ratio:4/5;border-radius:200px 200px 18px 18px;
  overflow:hidden;background:linear-gradient(160deg,var(--gold-soft),var(--mist));border:1px solid var(--line);
  box-shadow:var(--shadow);opacity:0;transform:translateY(30px) scale(.97);transition:opacity 1.1s var(--ease) .35s,transform 1.1s var(--ease) .35s}
.hero.ready .hero__portrait{opacity:1;transform:none}
.hero__portrait img{width:100%;height:100%;object-fit:cover}
.hero__portrait .ph-fill{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:var(--gold-deep);
  font-family:var(--display);font-style:italic;padding:2rem;background:linear-gradient(160deg,#efe3cd,#e3d6bd)}
.hero__badge{position:absolute;bottom:1rem;left:-1.2rem;background:var(--bg-2);border:1px solid var(--line);
  border-radius:14px;padding:.85rem 1.1rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:.7rem}
.hero__badge .b-num{font-family:var(--display);font-size:1.7rem;color:var(--gold-deep);line-height:1}
.hero__badge .b-txt{font-size:.72rem;line-height:1.25;color:var(--ink-soft)}
.hero__scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-faint);display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero__scroll::after{content:"";width:1px;height:36px;background:linear-gradient(var(--gold),transparent);animation:scrollline 2s var(--ease) infinite}
@keyframes scrollline{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

@media (max-width:920px){
  .hero__inner{grid-template-columns:1fr;text-align:left}
  .hero__media{display:none}
  .hero{min-height:auto;padding-block:calc(var(--header-h) + 3rem) 4rem}
}

/* ---------- marquee credential strip ---------- */
.cred-strip{background:var(--ink-900);color:#CFC8BA;padding:1.1rem 0;overflow:hidden;white-space:nowrap}
.cred-track{display:inline-flex;gap:3.5rem;align-items:center;animation:marquee 38s linear infinite;will-change:transform}
.cred-track span{font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--gold-soft);display:inline-flex;align-items:center;gap:3.5rem}
.cred-track span::after{content:"✦";color:rgba(255,255,255,.25);font-style:normal;font-size:.8rem}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.cred-track{animation:none}}

/* ---------- services grid ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.svc-card{position:relative;display:flex;flex-direction:column;min-height:340px;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:var(--bg-2);transition:transform .55s var(--ease),box-shadow .55s}
.svc-card__media{position:relative;height:190px;overflow:hidden;background:linear-gradient(150deg,var(--gold-soft),var(--mist))}
.svc-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.svc-card:hover .svc-card__media img{transform:scale(1.06)}
.svc-card__body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.svc-card__body h3{font-size:1.32rem;margin-bottom:.5rem}
.svc-card__body p{color:var(--ink-soft);font-size:.95rem;flex:1}
.svc-card__media .ph-fill{position:absolute;inset:0;display:grid;place-items:center;color:var(--gold-deep);font-family:var(--display);font-style:italic;font-size:1.3rem}
.svc-more{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-top:1.3rem}
.svc-more a{padding:1rem 1.1rem;border:1px solid var(--line);border-radius:12px;background:var(--bg-2);font-weight:500;
  display:flex;justify-content:space-between;align-items:center;gap:.5rem;transition:.3s;font-size:.95rem}
.svc-more a:hover{border-color:var(--gold);background:#fff;padding-left:1.3rem}
.svc-more a::after{content:"→";color:var(--gold-deep)}
@media (max-width:880px){.svc-grid{grid-template-columns:1fr 1fr}.svc-more{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.svc-grid{grid-template-columns:1fr}.svc-more{grid-template-columns:1fr}}

/* ---------- why / founder split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split--reverse .split__media{order:2}
.split__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;
  background:linear-gradient(160deg,var(--gold-soft),var(--mist));border:1px solid var(--line);box-shadow:var(--shadow)}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__media .ph-fill{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:2rem;color:var(--gold-deep);font-family:var(--display);font-style:italic;font-size:1.4rem}
.why-list{display:grid;gap:1.3rem;margin-top:1.8rem}
.why-item{display:flex;gap:1rem;align-items:flex-start}
.why-item__num{font-family:var(--display);font-style:italic;color:var(--gold);font-size:1.2rem;flex:none;width:2rem}
.why-item h4{margin-bottom:.25rem}
.why-item p{color:var(--ink-soft);font-size:.96rem;margin:0}
@media (max-width:820px){.split{grid-template-columns:1fr}.split--reverse .split__media{order:0}}

/* ---------- testimonials ---------- */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.tcard{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;display:flex;flex-direction:column}
.tcard .stars{color:var(--gold);letter-spacing:.15em;margin-bottom:.9rem;font-size:.95rem}
.tcard blockquote{margin:0 0 1.2rem;font-family:var(--display);font-size:1.12rem;line-height:1.45;color:var(--ink)}
.tcard cite{margin-top:auto;font-style:normal;font-size:.88rem;color:var(--ink-faint)}
.tcard cite b{display:block;color:var(--ink);font-style:normal;font-family:var(--body);font-weight:600;font-size:.95rem;margin-bottom:.1rem}
@media (max-width:880px){.tcards{grid-template-columns:1fr}}

/* ---------- gallery teaser ---------- */
.gteaser{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
.gteaser__tile{aspect-ratio:3/4;border-radius:12px;overflow:hidden;position:relative;
  background:linear-gradient(160deg,var(--gold-soft),var(--mist));border:1px solid var(--line)}
.gteaser__tile .ph-fill{position:absolute;inset:0;display:grid;place-items:center;color:var(--gold-deep);font-family:var(--display);font-style:italic;font-size:.95rem;text-align:center;padding:1rem}
.gteaser__tile:nth-child(2){margin-top:1.6rem}
.gteaser__tile:nth-child(4){margin-top:1.6rem}
@media (max-width:700px){.gteaser{grid-template-columns:1fr 1fr}.gteaser__tile:nth-child(n){margin-top:0}}

/* ---------- spa strip ---------- */
.spa-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem}
.spa-grid a{padding:1.3rem 1rem;border:1px solid var(--line);border-radius:14px;background:var(--bg-2);text-align:center;transition:.35s}
.spa-grid a:hover{border-color:var(--gold);transform:translateY(-4px);background:#fff}
.spa-grid .s-name{font-family:var(--display);font-size:1.15rem;display:block;margin-bottom:.2rem}
.spa-grid .s-sub{font-size:.78rem;color:var(--ink-faint)}
@media (max-width:820px){.spa-grid{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:480px){.spa-grid{grid-template-columns:1fr 1fr}}

/* ---------- contact split ---------- */
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem)}
.contact-info p{margin-bottom:.3rem}
.contact-info .ci-row{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.contact-info .ci-row svg{color:var(--gold-deep);flex:none;margin-top:3px}
.contact-info .ci-row b{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin-bottom:.2rem}
.contact-info .ci-row a,.contact-info .ci-row span{font-size:1.05rem;color:var(--ink)}
@media (max-width:820px){.contact-split{grid-template-columns:1fr}}
