/* ===================================================================
   Enchanted Media Management — styles
   Palette: brighter earth tones, golden-hour, magical
=================================================================== */
:root{
  --cream:#FBF4E6;
  --parchment:#F5E8D2;
  --sand:#E9CDA1;
  --gold:#E2B85B;
  --gold-deep:#B98B2C;
  --clay:#D2A646;        /* was orange clay → gold */
  --terracotta:#B68A2A;  /* accent / heading gold (was orange-rust) */
  --sage:#9CAE83;
  --moss:#5E7350;
  --forest:#3C4D36;
  --ink:#2E2A20;
  --ink-soft:#5b5343;
  --sky-top:#a9c9e2;
  --sky-mid:#d8dcd0;
  --sky-low:#efdcb8;

  --radius:18px;
  --shadow-soft:0 18px 50px -22px rgba(76,55,30,.45);
  --shadow-card:0 26px 60px -30px rgba(76,55,30,.55);
  --maxw:1180px;
  --font-display:"Fraunces",Georgia,serif;
  --font-body:"Jost","Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.serif-italic{font-family:var(--font-display);font-style:italic;font-weight:400}

/* ===== Static background image (floating castle) ===== */
#scene-wrap{
  position:fixed;inset:0;z-index:0;
  background:#e7dcc6 url("assets/castle-bg.jpg") center center / cover no-repeat;
}
.scene-veil{
  position:absolute;inset:0;pointer-events:none;
  /* subtle bottom-only fade so the hero blends into the page below */
  background:linear-gradient(180deg,transparent 84%,rgba(251,244,230,.4) 100%);
}
/* WebGL canvas that animates the clouds (transparent until the texture draws, so the
   static-image fallback shows underneath — no flash) */
#cloudgl{position:absolute;inset:0;width:100%;height:100%;display:block}
/* gold fairy-dust canvas (drifts over the castle) */
#island{position:absolute;inset:0;width:100%;height:100%;display:block;pointer-events:none}

/* ===== Loader ===== */
#loader{
  position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:14px;
  background:linear-gradient(180deg,var(--sky-top),var(--sky-mid));
  transition:opacity .8s ease,visibility .8s ease;
}
#loader.hidden{opacity:0;visibility:hidden}
.loader-mark{font-size:38px;color:var(--gold-deep);animation:spin 3s linear infinite}
.loader-text{font-family:var(--font-display);font-style:italic;color:var(--ink-soft);letter-spacing:.04em}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== Layout ===== */
.container{width:min(var(--maxw),92vw);margin:0 auto}
.narrow{max-width:760px}
.center{text-align:center;margin-inline:auto}
main{position:relative;z-index:1}
section{position:relative}

/* ===== Typography ===== */
h1,h2,h3{font-family:var(--font-display);font-weight:500;line-height:1.05;letter-spacing:-.01em}
.eyebrow{
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;margin-bottom:1rem;
}
.kicker{
  font-family:var(--font-display);font-style:italic;color:var(--terracotta);
  letter-spacing:.12em;font-size:1rem;margin-bottom:1.4rem;
}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:64ch;margin-inline:auto}

/* ===== Buttons ===== */
.btn{
  display:inline-block;padding:.92em 1.7em;border-radius:100px;
  font-family:var(--font-body);font-weight:500;font-size:.98rem;letter-spacing:.02em;
  cursor:pointer;border:1.5px solid transparent;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.btn-primary{
  background:linear-gradient(135deg,var(--gold),var(--clay));
  color:#fff;box-shadow:0 14px 30px -12px rgba(201,123,90,.7);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 40px -14px rgba(201,123,90,.85)}
.btn-ghost{background:rgba(255,255,255,.45);border-color:rgba(94,115,80,.4);color:var(--forest);backdrop-filter:blur(6px)}
.btn-ghost:hover{transform:translateY(-3px);background:rgba(255,255,255,.7)}
.btn-full{width:100%;text-align:center;margin-top:.4rem}

/* ===== Navigation ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1rem,4vw,2.4rem);
  transition:background .4s ease,box-shadow .4s ease,padding .4s ease;
}
.nav.scrolled{
  background:rgba(251,244,230,.82);backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(120,95,60,.12);padding-top:.75rem;padding-bottom:.75rem;
}
.brand{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--ink)}
.brand-mark{color:var(--gold-deep)}
.brand-name em{font-style:italic;font-weight:400;color:var(--terracotta)}
.nav-links{display:flex;align-items:center;gap:1.8rem}
.nav-links a{font-size:.95rem;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--terracotta)}
.nav-cta{
  background:var(--forest);color:var(--cream)!important;padding:.6em 1.3em;border-radius:100px;
  box-shadow:0 10px 24px -12px rgba(60,77,54,.8);
}
.nav-cta:hover{background:var(--moss)}

/* ===== Hero ===== */
.hero{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:7rem 1.2rem 5rem;
}
.hero-inner{max-width:880px;position:relative}
.hero-inner::before{
  content:"";position:absolute;z-index:-1;inset:-8% -12%;
  background:radial-gradient(60% 55% at 50% 50%,rgba(251,244,230,.78) 0%,rgba(251,244,230,.5) 45%,rgba(251,244,230,0) 78%);
  filter:blur(6px);pointer-events:none;
}
.hero-title{
  font-size:clamp(2.8rem,9vw,6.6rem);font-weight:400;color:var(--ink);
  text-shadow:0 2px 30px rgba(251,244,230,.6);
}
.hero-title span{display:block}
.hero-title .serif-italic{color:var(--terracotta)}
.hero-sub{
  font-size:clamp(1.05rem,2.2vw,1.3rem);color:var(--ink-soft);
  max-width:60ch;margin:1.6rem auto 0;
}
.hero-by{font-family:var(--font-display);font-style:italic;font-size:1.25rem;margin-top:1.2rem;color:var(--ink)}
.hero-by strong{font-weight:600;font-style:normal;color:var(--terracotta)}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.2rem}

.scroll-cue{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);
}
.scroll-dot{width:22px;height:36px;border:1.5px solid var(--ink-soft);border-radius:14px;position:relative}
.scroll-dot::after{content:"";position:absolute;top:7px;left:50%;width:4px;height:7px;background:var(--terracotta);border-radius:4px;transform:translateX(-50%);animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

/* ===== Section panels (frosted parchment over the 3D sky) ===== */
.journey,.roadmap,.work,.contact{padding:clamp(5rem,10vw,8rem) 0;position:relative;z-index:1}
.journey{
  background:linear-gradient(180deg,rgba(251,244,230,0) 0%,rgba(251,244,230,.92) 14%,var(--cream) 100%);
}
.roadmap{background:var(--cream)}
.work{background:linear-gradient(180deg,var(--cream),var(--parchment))}
.contact{
  background:linear-gradient(180deg,var(--parchment),#efd9b8);
}

/* ===== Journey ===== */
.journey h2,.roadmap h2,.work h2{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:1.2rem;color:var(--ink)}
.journey .lead{margin-top:.4rem}
.stats{display:flex;gap:clamp(1.5rem,5vw,4rem);justify-content:center;flex-wrap:wrap;margin-top:3.4rem}
.stat{display:flex;flex-direction:column;align-items:center}
.stat .num{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,3.8rem);font-weight:600;color:var(--terracotta);line-height:1}
.stat .lbl{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:.5rem}

/* ===== Roadmap ===== */
.roadmap .center{margin-bottom:3.5rem}
.map{position:relative;max-width:680px;margin:0 auto;padding:1rem 0}
/* central dashed connector line down the middle */
.map::before{content:"";position:absolute;top:10px;bottom:10px;left:50%;width:2px;transform:translateX(-50%);
  background:repeating-linear-gradient(to bottom,rgba(185,139,44,.45) 0 7px,transparent 7px 16px);z-index:0}
.map-path{display:none}
.milestones{list-style:none;position:relative;z-index:1;display:flex;flex-direction:column;gap:clamp(2rem,4vw,3rem)}
/* every milestone centred: node on the line, card beneath */
.milestone,
.milestone[data-side="left"],
.milestone[data-side="right"]{position:relative;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;gap:1rem;min-height:0}
.ms-node{
  flex:0 0 auto;width:62px;height:62px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:#fff;
  background:linear-gradient(135deg,var(--gold),var(--clay));
  box-shadow:0 0 0 6px rgba(224,169,94,.18),var(--shadow-soft);
  position:relative;z-index:2;
}
.ms-node.ms-star{background:linear-gradient(135deg,var(--terracotta),var(--gold-deep));box-shadow:0 0 0 6px rgba(181,97,63,.2),0 0 30px rgba(224,169,94,.6)}
.ms-node.ms-end{background:linear-gradient(135deg,var(--moss),var(--forest))}
.ms-card{
  background:rgba(255,255,255,.82);backdrop-filter:blur(8px);
  border:1px solid rgba(156,174,131,.35);border-radius:var(--radius);
  padding:1.5rem 1.8rem;width:100%;max-width:540px;box-shadow:var(--shadow-soft);text-align:left;
}
.ms-card h3{font-size:1.4rem;color:var(--forest);margin-bottom:.5rem}
.ms-card h3 em{font-style:italic;font-weight:400;color:var(--terracotta);font-size:.92em}
.ms-card p{color:var(--ink-soft);font-size:.98rem}

/* ===== Work — uniform cards, single column, all equal size ===== */
.work .center{margin-bottom:3.4rem}
.work-grid{display:flex;flex-direction:column;gap:1.6rem;max-width:900px;margin:0 auto}
.work-card{
  position:relative;
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card);border:1px solid rgba(233,205,161,.6);
  display:flex;flex-direction:row;align-items:stretch;height:240px;
  transition:transform .4s ease,box-shadow .4s ease;
}
.work-card:hover{transform:translateY(-6px);box-shadow:0 36px 70px -30px rgba(76,55,30,.6)}
.wc-media{position:relative;overflow:hidden;background:var(--sand);flex:0 0 38%}
.wc-media>img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .6s ease}
.work-card:hover .wc-media>img{transform:scale(1.05)}
.wc-body{padding:1.5rem 2rem;display:flex;flex-direction:column;justify-content:center;gap:.5rem;flex:1}
.wc-tag{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.wc-body h3{font-size:1.7rem;color:var(--ink)}
.wc-body p{color:var(--ink-soft);font-size:.96rem}

/* client logo tiles — logo / wordmark centred on a branded panel */
.wc-logo{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem;
  background:linear-gradient(150deg,#41513a 0%,#2f2a20 100%);padding:1.4rem}
.wc-logo>img{width:auto;max-width:82%;max-height:60%;object-fit:contain}
.work-card:hover .wc-logo>img{transform:none}
.wc-wordmark .wm-name{font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:1.7rem;line-height:1.04;color:var(--cream);text-align:center}
.wc-wordmark .wm-sub{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,232,210,.62)}

/* follower stats + handle */
.wc-stats{display:flex;align-items:baseline;gap:1.1rem;margin-top:.45rem;flex-wrap:wrap}
.wc-stat{font-size:.92rem;color:var(--ink-soft)}
.wc-stat b{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--terracotta);margin-right:.18rem}
.wc-handle{font-size:.85rem;font-weight:500;color:var(--gold-deep);letter-spacing:.01em}

/* whole client card is a link to Instagram */
.wc-stretch{position:absolute;inset:0;z-index:4;border-radius:var(--radius)}
.work-card.client{cursor:pointer}
.work-card.client:hover .wc-handle{color:var(--terracotta)}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.contact-intro h2{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:1.2rem;color:var(--ink)}
.contact-info{list-style:none;margin-top:2.2rem;display:flex;flex-direction:column;gap:1rem}
.contact-info li{display:flex;align-items:center;gap:.9rem;font-size:1.1rem;color:var(--ink)}
.ci-ico{
  width:44px;height:44px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.6);color:var(--terracotta);font-size:1.1rem;border:1px solid rgba(181,97,63,.3);
}
.contact-info a{transition:color .2s}
.contact-info a:hover{color:var(--terracotta)}
.ci-tag{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);
  border:1px solid rgba(185,139,44,.4);border-radius:100px;padding:.18em .6em;font-weight:600}

.contact-form{
  background:rgba(255,255,255,.75);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.7);border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,2.4rem);box-shadow:var(--shadow-card);position:relative;
}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.05rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.field label span{color:var(--terracotta)}
.field label .opt{color:var(--sage);text-transform:none;letter-spacing:0;font-style:italic}
.field input,.field textarea{
  font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:rgba(255,255,255,.85);border:1.5px solid rgba(156,174,131,.45);
  border-radius:12px;padding:.8em .95em;transition:border .2s,box-shadow .2s;resize:vertical;
}
.field input:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(224,169,94,.18);
}
.field input.invalid,.field textarea.invalid{border-color:var(--terracotta);box-shadow:0 0 0 4px rgba(181,97,63,.14)}
.form-note{font-size:.78rem;color:var(--ink-soft);text-align:center;margin-top:.9rem}
.form-success{
  position:absolute;inset:0;border-radius:var(--radius);background:rgba(251,244,230,.96);
  backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:2rem;gap:.6rem;
}
.form-success .fs-mark{font-size:2.6rem;color:var(--gold-deep);animation:spin 4s linear infinite}
.form-success strong{font-family:var(--font-display);font-size:1.7rem;color:var(--forest)}
.form-success p{color:var(--ink-soft);max-width:34ch}
.form-success[hidden]{display:none}

/* ===== Footer ===== */
.footer{background:var(--forest);color:var(--parchment);padding:3.2rem 0;position:relative;z-index:1;text-align:center}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:.7rem}
.footer .brand{color:var(--cream);font-size:1.5rem}
.footer .brand-name em{color:var(--gold)}
.footer-tag{color:rgba(245,232,210,.75);font-size:.95rem}
.footer-contact{display:flex;gap:.7rem;align-items:center;justify-content:center;flex-wrap:wrap;color:var(--gold)}
.footer-contact a{white-space:nowrap}
.footer-contact a:hover{color:#fff}
.footer-copy{font-size:.8rem;color:rgba(245,232,210,.55);margin-top:.6rem}

/* ===== Reveal animations ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1) var(--d,0s),transform .9s cubic-bezier(.2,.7,.2,1) var(--d,0s)}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:860px){
  .nav-links{gap:1rem}
  .nav-links a:not(.nav-cta){display:none}
  .contact-grid{grid-template-columns:1fr}
  .milestone[data-side="left"],.milestone[data-side="right"]{flex-direction:column;align-items:center;text-align:center;justify-content:center}
  .ms-card{max-width:none}
  .map-path{display:none}
  .milestones{gap:2rem}
  .milestone{min-height:0}
}
@media(max-width:560px){
  /* stack uniform cards (image on top, text below) on phones — still equal sizes */
  .work-card{flex-direction:column;height:auto}
  .wc-media{flex:0 0 auto;height:200px}
  .wc-body{padding:1.3rem 1.4rem 1.5rem}
  /* footer contact: stack each item on its own centered line (no mid-number breaks) */
  .footer-contact{flex-direction:column;gap:.4rem}
  .footer-contact span{display:none}
  /* journey stats: even 3-up row instead of an awkward 2 + 1 wrap */
  .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-top:2.6rem}
  .stat .num{font-size:2.3rem}
  .stat .lbl{font-size:.62rem;letter-spacing:.08em;margin-top:.35rem}
}
@media(max-width:480px){
  .field-row{grid-template-columns:1fr}
  .hero{padding-top:6rem}
}

/* ===== Reduced motion ===== */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.2s!important}
  .reveal{opacity:1;transform:none}
}
