/* ===== HOME PAGE ===== */

/* ---------- HERO: full-screen from load, sticky scroll phase for zoom + title-split animation ---------- */
/* Hero is 220vh tall so there's scroll distance for the animation before next section appears */
.hero{position:relative;height:100vh;background:var(--cream);}
.hero-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.hero-media{
  position:absolute;inset:0;
  width:100%;height:100%;border-radius:0;overflow:hidden;
  will-change:transform;
}
.hero-media image-slot{display:block;width:100%;height:100%;}
.hero-dim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,14,40,.08) 0%,rgba(8,14,40,.45) 55%,rgba(8,14,40,.7) 100%);opacity:1;pointer-events:none;}

.hero-titles{position:absolute;z-index:8;width:100%;top:50%;transform:translateY(-50%);display:flex;justify-content:center;gap:.22em;
  color:#fff;mix-blend-mode:normal;pointer-events:none;text-shadow:0 6px 40px rgba(0,0,0,.35);}
.hero-titles h1{font-size:clamp(54px,12.5vw,210px);font-weight:600;margin:0;will-change:transform,opacity;}
.t-left{transform:translateX(0);} .t-right{transform:translateX(0);}

.hero-doodles{position:absolute;inset:0;z-index:9;pointer-events:none;}
.hero-doodles .note-hand{font-size:clamp(22px,2.6vw,40px);transform:rotate(-7deg);text-shadow:0 2px 12px rgba(0,0,0,.25);}
.hero-doodles .doodle{width:clamp(70px,9vw,120px);height:auto;}
.n1{top:20%;left:11%;} .dd1{top:24%;left:18%;}
.n2{top:16%;right:12%;transform:rotate(6deg);} .dd2{top:21%;right:18%;}
.n3{bottom:30%;left:13%;transform:rotate(4deg);} .dd3{bottom:24%;left:19%;width:clamp(70px,8vw,110px);}
.dd-name{position:absolute;left:50%;transform:translateX(-50%);bottom:30%;width:min(46vw,560px);height:auto;}

.hero-foot{position:absolute;left:0;right:0;bottom:5vh;z-index:8;display:flex;flex-direction:column;align-items:center;
  text-align:center;color:#fff;padding:0 24px;opacity:1;transform:translateY(0);will-change:opacity;}
.hero-eyebrow{font-size:clamp(11px,1.1vw,14px);letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.85);margin:0 0 14px;font-weight:500;}
.hero-tag{max-width:30ch;font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(20px,2.4vw,32px);line-height:1.25;color:#fff;margin:0 0 26px;}
.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:10px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.8);}
.scroll-cue svg{width:24px;height:40px;}
.cue-dot{animation:cueMove 1.6s var(--ease) infinite;}
@keyframes cueMove{0%{transform:translateY(0);opacity:1}70%{transform:translateY(14px);opacity:0}100%{opacity:0}}

/* ---------- INTRO ---------- */
.intro{padding:clamp(90px,14vw,180px) 0 clamp(70px,10vw,120px);}
.intro-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:clamp(28px,5vw,72px);align-items:end;margin-top:22px;}
.intro h2{font-size:clamp(32px,4.6vw,68px);font-weight:500;}
.intro .hl{position:relative;font-style:italic;}
.hl-circle{display:inline-block;}
.circle-doodle{width:115%;height:auto;left:-7%;top:-14%;}
.intro-body p{margin:0 0 18px;color:var(--ink-soft);}
.intro-cta{margin-top:8px;}

/* ---------- WHAT I DO ---------- */
.whatido{padding:clamp(70px,10vw,120px) 0;background:var(--cream-deep);position:relative;}
.morph-stage{position:relative;display:flex;align-items:baseline;flex-wrap:wrap;gap:.1em;margin:18px 0 clamp(50px,8vw,90px);
  font-family:var(--serif);font-weight:600;font-size:clamp(44px,9vw,128px);line-height:1;letter-spacing:-.02em;}
.morph-pre{color:var(--ink);}
.morph-wrap{position:relative;display:inline-block;min-width:6ch;}
.morph-word{display:inline-block;color:var(--terra);transition:opacity .34s var(--ease), filter .34s var(--ease);will-change:opacity,filter;}
.morph-ul{position:absolute;left:2.6em;bottom:-.12em;width:min(52vw,560px);height:auto;}

.do-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);}
.do-card{background:rgba(240,233,221,.7);border:1px solid rgba(36,31,26,.08);border-radius:22px;padding:clamp(26px,3vw,40px);
  backdrop-filter:blur(6px);box-shadow:0 24px 50px -36px rgba(36,31,26,.4);transition:transform .4s var(--ease),box-shadow .4s;}
.do-card:hover{transform:translateY(-6px);box-shadow:0 36px 60px -36px rgba(36,31,26,.5);}
.do-num{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--terra);}
.do-card h3{margin:.1em 0 .4em;}
.do-card p{color:var(--ink-soft);font-size:16.5px;margin:0;}

/* ---------- FEATURED COVERFLOW ---------- */
.featured{padding:clamp(70px,10vw,120px) 0;overflow:hidden;}
.feat-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:clamp(36px,5vw,60px);}
.coverflow{position:relative;height:clamp(380px,52vw,560px);perspective:1600px;}
.cf-track{position:absolute;inset:0;transform-style:preserve-3d;}
.cf-card{position:absolute;left:50%;top:50%;width:clamp(280px,38vw,500px);height:clamp(340px,46vw,500px);
  margin-left:calc(clamp(280px,38vw,500px)/-2);margin-top:calc(clamp(340px,46vw,500px)/-2);
  border-radius:22px;overflow:hidden;background:var(--sand);
  box-shadow:0 40px 80px -40px rgba(36,31,26,.55);transition:transform .6s var(--ease),filter .6s var(--ease),opacity .6s;
  will-change:transform;}
.cf-card image-slot{display:block;}
.cf-cap{position:absolute;left:0;right:0;bottom:0;padding:46px 22px 18px;color:#fff;
  background:linear-gradient(transparent,rgba(10,12,28,.75));display:flex;align-items:flex-end;justify-content:space-between;gap:10px;}
.cf-cap h4{font-family:var(--serif);font-weight:500;font-size:24px;margin:0;}
.cf-tag{font-size:11px;letter-spacing:.2em;text-transform:uppercase;background:var(--terra);padding:5px 11px;border-radius:999px;align-self:center;}
.cf-fav{position:absolute;top:-6px;right:-2px;z-index:3;display:flex;flex-direction:column;align-items:center;}
.cf-fav svg{width:54px;height:54px;}
.cf-fav .note-hand{font-size:22px;transform:rotate(-9deg);margin-top:-6px;}
.cf-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:20;width:54px;height:54px;border-radius:999px;
  border:1.5px solid var(--ink);background:var(--cream);color:var(--ink);font-size:20px;cursor:pointer;
  transition:background .3s,color .3s,transform .3s;display:flex;align-items:center;justify-content:center;}
.cf-arrow:hover{background:var(--ink);color:var(--cream);}
.cf-prev{left:clamp(8px,4vw,40px);} .cf-next{right:clamp(8px,4vw,40px);}
.cf-dots{position:absolute;bottom:-34px;left:50%;transform:translateX(-50%);display:flex;gap:9px;}
.cf-dots button{width:9px;height:9px;border-radius:999px;border:none;background:rgba(36,31,26,.22);cursor:pointer;transition:background .3s,width .3s;}
.cf-dots button.on{background:var(--terra);width:26px;}

/* ---------- TESTIMONIAL 3D MARQUEE ---------- */
.proof{padding:clamp(70px,10vw,120px) 0 clamp(80px,11vw,140px);overflow:hidden;}
.proof .wrap{margin-bottom:30px;}
.marquee3d{position:relative;display:flex;justify-content:center;gap:26px;height:clamp(440px,56vw,620px);
  transform:perspective(1200px) rotateX(18deg) rotateZ(-7deg);transform-style:preserve-3d;
  -webkit-mask-image:linear-gradient(transparent,#000 14%,#000 86%,transparent);
  mask-image:linear-gradient(transparent,#000 14%,#000 86%,transparent);}
.mq-col{display:flex;flex-direction:column;gap:24px;width:clamp(240px,26vw,330px);}
.mq-card{background:var(--cream);border:1px solid rgba(36,31,26,.1);border-radius:20px;padding:26px;
  box-shadow:0 26px 50px -34px rgba(36,31,26,.5);}
.mq-card .q{font-family:var(--serif);font-size:19px;line-height:1.4;font-weight:450;margin:0 0 18px;}
.mq-card .who{display:flex;align-items:center;gap:12px;}
.mq-av{width:42px;height:42px;border-radius:999px;background:var(--brown);color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:600;font-size:18px;flex-shrink:0;}
.mq-card .nm{font-weight:600;font-size:15px;}
.mq-card .rl{font-size:13px;color:var(--ink-soft);opacity:.8;}
.mq-card .stars{color:var(--terra);font-size:13px;letter-spacing:2px;margin-top:14px;}
@keyframes mqUp{from{transform:translateY(0)}to{transform:translateY(-50%)}}
@keyframes mqDown{from{transform:translateY(-50%)}to{transform:translateY(0)}}
.mq-col .mq-inner{display:flex;flex-direction:column;gap:24px;}
.mq-col[data-dir="up"] .mq-inner{animation:mqUp 26s linear infinite;}
.mq-col[data-dir="down"] .mq-inner{animation:mqDown 30s linear infinite;}
.marquee3d:hover .mq-inner{animation-play-state:paused;}

/* ---------- CLOSING CTA ---------- */
.home-cta{position:relative;overflow:hidden;padding:clamp(90px,14vw,180px) 0;text-align:center;}
.cta-aurora{position:absolute;left:50%;top:50%;width:72vw;height:60vh;transform:translate(-50%,-50%);z-index:0;pointer-events:none;
  background:radial-gradient(circle at 50% 50%, color-mix(in oklab,var(--terra) 24%,transparent) 0%, color-mix(in oklab,var(--sand) 34%,transparent) 46%, transparent 70%);
  filter:blur(64px);opacity:.65;animation:footBreathe 9s ease-in-out infinite alternate;}
.cta-ghost{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);z-index:0;pointer-events:none;
  font-family:var(--serif);font-weight:700;font-size:34vw;line-height:1;color:transparent;
  -webkit-text-stroke:1.5px rgba(36,31,26,.07);white-space:nowrap;letter-spacing:-.02em;}
.cta-inner{position:relative;z-index:2;}
.cta-big{font-size:clamp(60px,13vw,184px);line-height:.9;margin:.12em 0 0;}
.cta-big .em{color:var(--terra);}
.cta-lead{color:var(--ink-soft);font-size:clamp(17px,1.9vw,22px);max-width:42ch;margin:24px auto 32px;}
.cta-btn{font-size:17px;padding:18px 36px;}

@media(max-width:900px){
  .intro-grid,.cta-inner{grid-template-columns:1fr;}
  .do-grid{grid-template-columns:1fr;}
  .cta-arrow,.cta-note{display:none;}
  /* hero height NOT overridden here — stays 240vh on tablets */
}
@media(max-width:640px){
  .mq-hide-sm{display:none;}
  .hero-media{width:84vw;height:60vh;}
  .marquee3d{transform:perspective(1000px) rotateX(12deg) rotateZ(-4deg);}
}

/* ---------- MY WORKFORCE ---------- */
.workforce{padding:clamp(70px,10vw,120px) 0 clamp(80px,11vw,140px);overflow:hidden;}
.wf-head{text-align:center;max-width:760px;margin:0 auto clamp(40px,6vw,64px);}
.wf-head h2{font-size:clamp(30px,4.6vw,64px);font-weight:500;margin:.2em 0 0;}
.wf-head .italic{color:var(--terra);font-style:italic;}
.wf-sub{color:var(--ink-soft);font-size:clamp(15px,1.6vw,19px);margin:16px auto 0;max-width:46ch;}
.wf-carousel .tool-row{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.wf-carousel .tool-row + .tool-row{margin-top:18px;}
.wf-carousel .tool-track{display:flex;gap:16px;width:max-content;align-items:flex-start;}
.wf-carousel .tool-track[data-dir="l"]{animation:toolScroll 52s linear infinite;}
.wf-carousel .tool-track[data-dir="r"]{animation:toolScroll 62s linear infinite reverse;}
.wf-carousel .tool-row:hover .tool-track{animation-play-state:paused;}
.wf-carousel .tt-name{color:var(--ink-soft);}

/* ---------- IMAGE TRAIL DIVIDER ---------- */
.trail-divider{position:relative;overflow:hidden;background:var(--cream);padding:clamp(56px,8vw,100px) 0 clamp(40px,6vw,70px);
  min-height:60vh;display:flex;flex-direction:column;justify-content:center;}
.td-inner{position:relative;z-index:2;text-align:center;pointer-events:none;}
.td-eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--brown);margin:0 0 14px;}
.trail-word{font-size:clamp(72px,22vw,360px);line-height:.8;letter-spacing:-.02em;color:transparent;
  -webkit-text-stroke:1.5px rgba(36,31,26,.55);}
.trail-tile{position:absolute;width:clamp(92px,9vw,140px);aspect-ratio:3/4;border-radius:10px;background-size:cover;
  background-position:center;background-color:var(--sand);pointer-events:none;z-index:3;opacity:0;
  transform:translate(-50%,-50%) scale(.2) rotate(var(--rot,0deg));
  box-shadow:0 22px 44px -18px rgba(36,31,26,.5);transition:transform .55s var(--ease),opacity .55s var(--ease);}
.trail-tile.ph{background:linear-gradient(135deg,var(--sand),var(--terra));}
.trail-tile.in{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(var(--rot,0deg));}
.trail-tile.out{opacity:0;transform:translate(-50%,-50%) scale(.35) rotate(var(--rot,0deg));}
.trail-pool{position:relative;z-index:2;margin-top:clamp(30px,5vw,54px);}
.tp-label{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--terra);text-align:center;margin:0 0 14px;}
.tp-label span{color:var(--ink-soft);text-transform:none;letter-spacing:0;font-family:var(--serif);font-style:italic;font-size:15px;}
.tp-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;max-width:760px;margin:0 auto;}
.tp-strip image-slot{aspect-ratio:3/4;height:auto!important;width:100%!important;display:block;}
@media(max-width:640px){ .tp-strip{grid-template-columns:repeat(3,1fr);} }

/* ============================================================
   HOME PAGE — MOBILE OPTIMISATION  (comprehensive rewrite)
   ============================================================ */

/* HERO — mobile: stays full-screen, just adjust font sizes */
@media(max-width:820px){
  .hero{height:100vh;}
  .hero-titles h1{font-size:clamp(44px,14vw,100px);}
  /* hide decorative doodles that clip off-screen on mobile */
  .n2,.dd2,.n3,.dd3{display:none;}
  .n1{left:5%;top:18%;} .dd1{left:12%;top:22%;}
  .hero-tag{font-size:clamp(15px,4.5vw,22px);max-width:28ch;}
  .dd-name{width:min(68vw,300px);}
  .hero-doodles .note-hand{font-size:clamp(14px,4.5vw,22px);}
  .hero-doodles .doodle{width:clamp(44px,11vw,70px);}
}
@media(max-width:480px){
  .hero{height:100vh;}
  .hero-titles h1{font-size:clamp(38px,13vw,80px);}
  .hero-foot{padding:0 24px;}
}

/* INTRO */
@media(max-width:820px){
  .intro-grid{grid-template-columns:1fr;gap:24px;}
  .intro{padding:clamp(70px,12vw,120px) 0 clamp(50px,8vw,80px);}
  .intro h2{font-size:clamp(28px,8vw,52px);}
}

/* WHAT I DO */
@media(max-width:820px){
  .do-grid{grid-template-columns:1fr 1fr;gap:14px;}
  .morph-stage{font-size:clamp(34px,10vw,80px);}
}
@media(max-width:480px){
  .do-grid{grid-template-columns:1fr;}
  .morph-stage{font-size:clamp(28px,11vw,56px);}
  .morph-ul{width:min(80vw,300px);}
  .do-card{padding:20px;}
}

/* FEATURED COVERFLOW */
@media(max-width:640px){
  .featured{overflow:hidden;padding-left:0;padding-right:0;}
  .feat-head{padding:0 24px;}
  .coverflow{height:clamp(300px,90vw,420px);}
  .cf-card{
    width:clamp(200px,68vw,320px);
    height:clamp(260px,82vw,380px);
  }
  .cf-arrow{width:40px;height:40px;font-size:16px;}
  .cf-prev{left:8px;} .cf-next{right:8px;}
}

/* TESTIMONIAL 3D MARQUEE */
@media(max-width:640px){
  .marquee3d{
    transform:perspective(800px) rotateX(8deg) rotateZ(-2deg);
    height:clamp(340px,88vw,460px);
    gap:12px;
  }
  .mq-col{width:clamp(190px,68vw,270px);}
  .mq-card .q{font-size:15px;}
  .mq-card{padding:18px;}
}

/* CLOSING CTA */
@media(max-width:640px){
  .cta-big{font-size:clamp(44px,14vw,80px);}
  .cta-ghost{display:none;}
  .home-cta{padding:clamp(60px,12vw,100px) 0;}
  .cta-lead{font-size:clamp(15px,4vw,18px);}
}

/* SOCIAL SHOWCASE BENTO */
@media(max-width:760px){
  .smm-bento{grid-template-columns:1fr;}
  .sb-smalls{grid-template-columns:repeat(3,1fr);}
  .sb-big{aspect-ratio:4/3;min-height:0;}
}
@media(max-width:480px){
  .sb-smalls{grid-template-columns:repeat(2,1fr);}
}

/* TRAIL DIVIDER */
@media(max-width:640px){
  .trail-word{font-size:clamp(52px,20vw,110px);}
  .trail-tile{width:clamp(64px,13vw,90px);}
  .tp-strip{grid-template-columns:repeat(3,1fr);}
}

/* RING GALLERY */
@media(max-width:640px){
  .ring-stage{height:clamp(280px,78vw,400px);}
  .ring{
    width:clamp(130px,36vw,200px);
    height:clamp(190px,52vw,290px);
    margin-left:calc(clamp(130px,36vw,200px) / -2);
    margin-top:calc(clamp(190px,52vw,290px) / -2);
  }
}

/* ---------- CIRCULAR GALLERY (3D ring) ---------- */
.ring-sec{padding:clamp(70px,10vw,120px) 0;overflow:hidden;background:var(--cream-deep);}
.ring-head{margin-bottom:clamp(30px,5vw,56px);}
.ring-head h2{font-size:clamp(34px,5.5vw,80px);}
.ring-stage{position:relative;height:clamp(380px,50vw,560px);perspective:1300px;cursor:grab;touch-action:pan-y;}
.ring-stage:active{cursor:grabbing;}
.ring{position:absolute;left:50%;top:50%;width:clamp(190px,22vw,290px);height:clamp(280px,30vw,400px);
  margin-left:calc(clamp(190px,22vw,290px) / -2);margin-top:calc(clamp(280px,30vw,400px) / -2);
  transform-style:preserve-3d;will-change:transform;}
.ring-card{position:absolute;inset:0;border-radius:16px;overflow:hidden;background:var(--sand);
  box-shadow:0 30px 60px -34px rgba(36,31,26,.55);backface-visibility:hidden;will-change:transform,opacity;}
.ring-card image-slot{display:block;width:100%;height:100%;}
.rc-cap{position:absolute;left:0;right:0;bottom:0;padding:34px 14px 14px;color:#fff;
  background:linear-gradient(transparent,rgba(20,16,12,.72));}
.rc-cap .t{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--sand);}
.rc-cap h4{font-family:var(--serif);font-weight:500;font-size:18px;margin:2px 0 0;}
.ring-ctrl{display:flex;gap:14px;justify-content:center;margin-top:clamp(26px,4vw,40px);}
.ring-ctrl .cf-arrow{position:static;transform:none;}

/* ---------- SOCIAL SHOWCASE (1 big + 6 small) ---------- */
.social-showcase{padding:clamp(10px,3vw,40px) 0 clamp(60px,9vw,120px);overflow:hidden;}
.ss-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:clamp(28px,4vw,48px);flex-wrap:wrap;}
.ss-head h2{font-size:clamp(30px,4.4vw,60px);font-weight:500;margin:.2em 0 0;}
.ss-head .italic{color:var(--terra);font-style:italic;}
.smm-bento{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(12px,1.4vw,18px);align-items:stretch;}
.smm-bento .sb-big{position:relative;margin:0;border-radius:18px;overflow:hidden;min-height:300px;
  box-shadow:0 30px 60px -34px rgba(36,31,26,.5);}
.sb-smalls{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.4vw,18px);}
.sb-cell{position:relative;margin:0;aspect-ratio:1;border-radius:13px;overflow:hidden;
  box-shadow:0 18px 38px -26px rgba(36,31,26,.45);}
.sb-big img,.sb-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease);}
.sb-big:hover img,.sb-cell:hover img{transform:scale(1.05);}
.sb-cap{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 13px;color:#fff;
  background:linear-gradient(transparent,rgba(20,16,12,.74));}
.sb-cap .t{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.85);}
.sb-cap h4{margin:3px 0 0;font-family:var(--serif);font-weight:500;font-size:clamp(15px,1.3vw,20px);}
.sb-cell .sb-cap{padding:20px 12px 9px;}
@media(max-width:760px){
  .smm-bento{grid-template-columns:1fr;}
  .sb-big{aspect-ratio:4/3;min-height:0;}
}
