/* ============================================================
   Dr. Jessyca Perez — site styles
   Aesthetic: "Quiet Practice" — serene editorial, sage + cream
   ============================================================ */

:root{
  --ink:#3a3f37;
  --ink-soft:#5e655a;
  --sage:#8c9a82;
  --sage-deep:#6d7c62;
  --cream:#f4f1e9;
  --ivory:#fbfaf5;
  --mist:#e7e6db;
  --line:#d8d6c8;
  --maxw:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Mulish',sans-serif;
  background:var(--ivory);
  color:var(--ink);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
.serif{font-family:'Cormorant Garamond',serif}
::selection{background:var(--sage);color:var(--ivory)}
img{max-width:100%;display:block}
a{color:inherit}

/* atmosphere */
.grain{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}

/* ---------- nav ---------- */
nav{position:absolute;top:0;left:0;right:0;z-index:10;padding:34px 0}
nav.solid{position:sticky;background:rgba(251,250,245,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:22px 0}
nav .wrap{display:flex;align-items:center;justify-content:space-between}
.mark{font-family:'Cormorant Garamond',serif;font-size:1.45rem;letter-spacing:.02em;color:var(--ink);text-decoration:none}
.mark span{color:var(--sage-deep);font-style:italic}
.navlinks{display:flex;gap:38px;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.navlinks a{color:var(--ink-soft);text-decoration:none;transition:color .3s;position:relative}
.navlinks a:hover,.navlinks a.active{color:var(--sage-deep)}
.navlinks a.active::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:1px;background:var(--sage)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:40px;
  font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;text-decoration:none;transition:.35s;cursor:pointer;border:none;font-family:inherit}
.btn-fill{background:var(--sage-deep);color:var(--ivory)}
.btn-fill:hover{background:var(--ink);transform:translateY(-2px)}
.btn-ghost{color:var(--ink-soft);padding-left:0;padding-right:0}
.btn-ghost:hover{color:var(--sage-deep)}
.btn-ghost::after{content:"→";transition:transform .3s}
.btn-ghost:hover::after{transform:translateX(5px)}

/* ---------- home hero ---------- */
.home-hero{position:relative;padding:190px 0 110px;overflow:hidden}
.halo{position:absolute;top:-12%;right:-8%;width:720px;height:720px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#cdd4c0 0%,#dfe0d2 38%,rgba(247,245,237,0) 70%);
  filter:blur(8px);z-index:0}
.home-hero .wrap{position:relative;z-index:2}
.eyebrow{font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;color:var(--sage-deep);
  font-weight:600;margin-bottom:30px;opacity:0;animation:rise .9s .1s ease forwards}
.home-hero h1{font-family:'Cormorant Garamond',serif;font-weight:500;line-height:.96;
  font-size:clamp(3.4rem,9vw,7.6rem);letter-spacing:-.01em;color:var(--ink);
  opacity:0;animation:rise 1s .25s ease forwards}
.home-hero h1 em{font-style:italic;color:var(--sage-deep);display:block}
.lede{max-width:520px;margin-top:34px;font-size:1.12rem;color:var(--ink-soft);
  opacity:0;animation:rise 1s .5s ease forwards}
.cta-row{margin-top:46px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;
  opacity:0;animation:rise 1s .7s ease forwards}

.portrait{position:absolute;top:150px;right:60px;width:320px;height:420px;
  border-radius:200px 200px 16px 16px;overflow:hidden;z-index:1;
  background:linear-gradient(160deg,#aeb9a1,#7e8d72);
  box-shadow:0 40px 80px -30px rgba(90,100,80,.5);
  opacity:0;animation:rise 1.2s .55s ease forwards}
.portrait img{width:100%;height:100%;object-fit:cover;object-position:center 16%}
.portrait .initials{font-family:'Cormorant Garamond',serif;font-size:7rem;color:rgba(255,255,255,.32);
  position:absolute;top:42%;left:50%;transform:translate(-50%,-50%)}
.portrait .tag{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);font-size:.62rem;letter-spacing:.24em;
  text-transform:uppercase;color:rgba(255,255,255,.85);background:rgba(60,70,52,.4);
  padding:7px 16px;border-radius:30px;backdrop-filter:blur(4px)}
@media(max-width:980px){.portrait{display:none}}

@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* ---------- credentials marquee ---------- */
.creds{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--cream);overflow:hidden;padding:22px 0}
.creds-track{display:flex;gap:60px;white-space:nowrap;animation:slide 38s linear infinite;width:max-content}
.creds-track span{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.3rem;color:var(--sage-deep);display:flex;align-items:center;gap:60px}
.creds-track span::after{content:"·";color:var(--line)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- sub-page hero ---------- */
.page-hero{position:relative;padding:200px 0 80px;overflow:hidden}
.page-hero .halo{top:-30%;right:-14%;width:620px;height:620px}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{animation:none;opacity:1}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-weight:500;line-height:1;
  font-size:clamp(2.8rem,7vw,5.4rem);letter-spacing:-.01em;color:var(--ink)}
.page-hero h1 em{font-style:italic;color:var(--sage-deep)}
.page-hero .lede{animation:none;opacity:1;margin-top:26px}

/* ---------- generic section ---------- */
section{padding:110px 0}
.sec-label{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--sage-deep);
  font-weight:600;margin-bottom:26px}

/* about split */
.about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
.about-grid h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.08;color:var(--ink)}
.about-grid p{margin-bottom:22px;color:var(--ink-soft);font-size:1.06rem}
.about-grid p:last-child{margin-bottom:0}

/* focus areas */
.focus{background:var(--cream)}
.focus-head{text-align:center;max-width:560px;margin:0 auto 70px}
.focus-head h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.05;margin-bottom:18px}
.focus-head p{color:var(--ink-soft)}
.focus-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.fcard{background:var(--ivory);padding:48px 44px;transition:.4s}
.fcard:hover{background:#fff}
.fnum{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--sage);margin-bottom:18px}
.fcard h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.7rem;color:var(--ink);margin-bottom:14px}
.fcard p{color:var(--ink-soft);font-size:.98rem}

/* split media */
.split{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.split h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2rem,4vw,3rem);line-height:1.06;margin-bottom:26px}
.split p{color:var(--ink-soft);margin-bottom:30px}
.media-list{list-style:none}
.media-list li{display:flex;justify-content:space-between;align-items:baseline;
  padding:20px 0;border-top:1px solid var(--line);font-size:1.02rem;gap:20px}
.media-list li:last-child{border-bottom:1px solid var(--line)}
.media-list .where{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.3rem;color:var(--ink)}
.media-list .what{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-deep);text-align:right;white-space:nowrap}

/* podcast band */
.pod{background:var(--sage-deep);color:var(--ivory);border-radius:30px;padding:70px;position:relative;overflow:hidden}
.pod::before{content:"";position:absolute;right:-60px;top:-60px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,#8a987d 0%,rgba(138,152,125,0) 70%)}
.pod .sec-label{color:#cdd4c0}
.pod h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.04;margin-bottom:20px;position:relative}
.pod p{color:#dde0d3;max-width:520px;position:relative;margin-bottom:34px}
.pod .btn-fill{background:var(--ivory);color:var(--ink)}
.pod .btn-fill:hover{background:#fff;color:var(--ink)}

/* contact teaser / page */
.contact{text-align:center}
.contact h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2.6rem,7vw,5.4rem);line-height:1;margin-bottom:30px}
.contact h2 em{font-style:italic;color:var(--sage-deep)}
.contact .mail{font-family:'Cormorant Garamond',serif;font-size:1.7rem;color:var(--ink-soft);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:4px;transition:.3s;display:inline-block}
.contact .mail:hover{color:var(--sage-deep);border-color:var(--sage)}

/* ---------- about page extras ---------- */
.bio-portrait{width:100%;aspect-ratio:3/4;border-radius:180px 180px 16px 16px;overflow:hidden;
  background:linear-gradient(160deg,#aeb9a1,#7e8d72);position:relative;box-shadow:0 30px 60px -34px rgba(90,100,80,.5)}
.bio-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 14%}
.bio-portrait .initials{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:7rem;color:rgba(255,255,255,.3)}
.bio-portrait .tag{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);font-size:.62rem;letter-spacing:.24em;
  text-transform:uppercase;color:rgba(255,255,255,.85);background:rgba(60,70,52,.4);padding:7px 16px;border-radius:30px}

.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:10px}
.facts div{background:var(--cream);padding:40px 30px;text-align:center}
.facts .big{font-family:'Cormorant Garamond',serif;font-size:2.8rem;color:var(--sage-deep);line-height:1}
.facts .small{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:14px;line-height:1.6}

.timeline{max-width:760px;margin:0 auto}
.tl-row{display:grid;grid-template-columns:120px 1fr;gap:36px;padding:30px 0;border-top:1px solid var(--line);align-items:baseline}
.tl-row:last-child{border-bottom:1px solid var(--line)}
.tl-row .yr{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.5rem;color:var(--sage-deep)}
.tl-row .what b{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.25rem;display:block;color:var(--ink);margin-bottom:4px}
.tl-row .what span{color:var(--ink-soft);font-size:.98rem}

.degrees{list-style:none;max-width:760px;margin:40px auto 0}
.degrees li{padding:24px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:30px;align-items:baseline}
.degrees li:last-child{border-bottom:1px solid var(--line)}
.degrees .deg{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--ink)}
.degrees .school{font-size:.86rem;color:var(--ink-soft);text-align:right;white-space:nowrap}

/* ---------- speaking page ---------- */
.topics{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.topic{background:var(--ivory);padding:44px 36px}
.topic h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.5rem;margin-bottom:12px}
.topic p{color:var(--ink-soft);font-size:.96rem}

/* ---------- podcast page ---------- */
.ep{display:grid;grid-template-columns:60px 1fr auto;gap:30px;align-items:center;
  padding:32px 0;border-top:1px solid var(--line)}
.ep:last-child{border-bottom:1px solid var(--line)}
.ep .epnum{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.6rem;color:var(--sage)}
.ep .eptitle{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--ink)}
.ep .epdesc{font-size:.95rem;color:var(--ink-soft);margin-top:4px}
.ep .play{width:48px;height:48px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--sage-deep);transition:.3s;flex-shrink:0}
.ep .play:hover{background:var(--sage-deep);color:var(--ivory);border-color:var(--sage-deep)}

/* ---------- contact page form ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-info h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(2rem,4vw,3rem);line-height:1.06;margin-bottom:24px}
.contact-info p{color:var(--ink-soft);margin-bottom:30px}
.contact-info .detail{padding:20px 0;border-top:1px solid var(--line)}
.contact-info .detail:last-child{border-bottom:1px solid var(--line)}
.contact-info .detail .k{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage-deep);margin-bottom:6px}
.contact-info .detail .v{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--ink);text-decoration:none}
.form-field{margin-bottom:22px}
.form-field label{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.form-field input,.form-field textarea{width:100%;background:var(--cream);border:1px solid var(--line);border-radius:12px;
  padding:15px 18px;font-family:inherit;font-size:1rem;color:var(--ink);transition:.3s}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--sage);background:#fff}
.form-field textarea{min-height:140px;resize:vertical}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:48px 0;background:var(--cream)}
footer .wrap{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.foot-left{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--ink)}
.foot-left span{color:var(--sage-deep);font-style:italic}
.foot-links{display:flex;gap:28px;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.foot-links a{text-decoration:none;transition:.3s}
.foot-links a:hover{color:var(--sage-deep)}

/* ---------- responsive ---------- */
@media(max-width:760px){
  .wrap{padding:0 24px}
  .navlinks{display:none}
  .home-hero{padding:140px 0 70px}
  .page-hero{padding:140px 0 60px}
  .about-grid,.split,.focus-grid,.contact-grid,.facts,.topics{grid-template-columns:1fr}
  .facts,.topics{border-left:1px solid var(--line)}
  .pod{padding:46px 30px}
  section{padding:74px 0}
  .tl-row{grid-template-columns:80px 1fr;gap:18px}
  .ep{grid-template-columns:40px 1fr auto;gap:16px}
  footer .wrap{flex-direction:column;text-align:center}
}
