:root{
    --navy:#1d1e56;
    --navy-deep:#020f59;
    --coral:#f1392c;
    --coral-soft:#f15b57;
    --pink:#fde9f4;
    --pink-mid:#fbd9ea;
    --paper:#fdf4f8;
    --white:#ffffff;
    --ink:#1d1e56;
    --muted:#5a5b85;
    --maxw:1180px;
    --display:"Fraunces",Georgia,serif;
    --body:"Raleway",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    --script:"Dancing Script",cursive;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--body);
    color:var(--ink);
    background:var(--paper);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}

  /* ---------- progress bar ---------- */
  .progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--coral);z-index:100;transition:width .1s linear}

  /* ---------- top nav ---------- */
  .nav{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;justify-content:space-between;
    padding:18px clamp(20px,5vw,56px);transition:background .4s ease,padding .4s ease,box-shadow .4s ease;}
  .nav.scrolled{background:rgba(253,244,248,.92);backdrop-filter:blur(10px);padding:12px clamp(20px,5vw,56px);box-shadow:0 1px 0 rgba(29,30,86,.08)}
  .nav .brand{font-family:var(--display);font-weight:600;font-size:1.05rem;letter-spacing:.01em;color:var(--navy);display:flex;align-items:center;gap:9px}
  .nav .brand .dot{width:9px;height:9px;border-radius:50%;background:var(--coral)}
  .nav .nav-cta{font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;
    border:1.5px solid var(--navy);color:var(--navy);padding:9px 18px;border-radius:40px;transition:all .25s ease}
  .nav .nav-cta:hover{background:var(--navy);color:var(--white)}

  /* ---------- layout ---------- */
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}
  section{position:relative}

  .section-label{font-family:var(--body);font-weight:700;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;
    color:var(--navy);display:flex;align-items:center;gap:12px;margin-bottom:18px;justify-content:flex-start}
  .section-label::before{content:"";width:28px;height:2px;background:var(--coral);display:inline-block;flex-shrink:0}
  .section-label .num{color:var(--coral);opacity:1;font-variant-numeric:tabular-nums}
  .section-label--dark{color:var(--white)}
  .section-label--center{justify-content:center}

  h2.section-title{font-family:var(--display);font-weight:340;font-size:clamp(2rem,5vw,3.4rem);line-height:1.05;color:var(--navy);
    letter-spacing:-.01em;margin-bottom:22px}
  h2.section-title em{font-style:italic;color:var(--coral)}

  .lede{font-size:clamp(1.02rem,1.6vw,1.22rem);color:var(--muted);max-width:62ch}
  .colours-lede{max-width:760px}
  .body-col p:not(.section-label){margin-bottom:1.1em;color:var(--muted);font-size:1.02rem}
  .body-col p strong{color:var(--navy);font-weight:700}
  .body-col p em{color:var(--coral);font-style:italic;font-weight:600}

  /* ---------- INTRO HERO (about Juli) ---------- */
  .nav-menu{display:flex;align-items:center;gap:26px}
  .nav-menu a{font-family:var(--body);font-weight:600;font-size:.86rem;letter-spacing:.03em;color:var(--navy);transition:color .2s}
  .nav-menu a:hover{color:var(--coral)}
  .nav-menu .nav-cta{font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;border:1.5px solid var(--navy);
    padding:9px 18px;border-radius:40px}
  .nav-menu .nav-cta:hover{background:var(--navy);color:#fff}

  .me-hero.invite{min-height:88vh}
  .me-hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;
    padding:120px clamp(20px,5vw,40px) 80px;overflow:hidden;background:
    radial-gradient(125% 85% at 88% 15%, var(--pink-mid) 0%, var(--paper) 58%)}
  .me-grid{max-width:var(--maxw);margin:0 auto;width:100%;display:grid;grid-template-columns:1.05fr .95fr;
    gap:clamp(30px,5vw,70px);align-items:center;position:relative;z-index:2}
  .me-text{position:relative}
  .me-hero .me-eyebrow{font-family:var(--body);font-weight:700;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;
    color:var(--coral);margin-bottom:24px;display:flex;align-items:center;gap:13px;opacity:0;transform:translateY(18px)}
  .me-hero .me-eyebrow::before{content:"";width:30px;height:2px;background:var(--coral)}
  .me-hero h1{font-family:var(--display);font-weight:300;font-size:clamp(2.3rem,5.5vw,4.4rem);line-height:1.04;color:var(--navy);
    letter-spacing:-.02em}
  .me-hero h1 .name{font-style:italic;color:var(--coral);font-weight:400}
  .me-hero h1 span.line{display:block;overflow:hidden}
  .me-hero h1 span.line > span{display:inline-block;transform:translateY(110%)}
  .me-hero .hi-name{font-family:var(--script);font-size:clamp(1.6rem,3.4vw,2.6rem);color:var(--coral);font-weight:600;
    margin-top:6px;opacity:0;transform:translateY(18px)}
  .me-hero .hi-name .wave{display:inline-block;animation:wave 2.4s ease-in-out infinite;transform-origin:70% 70%}
  @keyframes wave{0%,60%,100%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}
  .me-hero.loaded .hi-name{opacity:1;transform:none;transition:opacity .8s ease .65s,transform .8s ease .65s}
  .me-hero .me-sub{font-size:clamp(1rem,1.5vw,1.2rem);color:var(--muted);max-width:46ch;margin-top:26px;
    opacity:0;transform:translateY(18px)}
  .me-hero .me-sub strong{color:var(--navy);font-weight:600}
  .me-hero .me-actions{margin-top:36px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;opacity:0;transform:translateY(18px)}
  .me-hero .me-btn{font-family:var(--body);font-weight:700;font-size:.95rem;background:var(--navy);color:#fff;
    padding:15px 30px;border-radius:50px;transition:transform .25s ease,box-shadow .25s ease;box-shadow:0 14px 34px -16px rgba(29,30,86,.7)}
  .me-hero .me-btn:hover{transform:translateY(-3px);box-shadow:0 20px 42px -16px rgba(29,30,86,.75)}
  .me-hero .me-link{font-weight:600;font-size:.95rem;color:var(--navy);border-bottom:1.5px solid var(--coral);padding-bottom:3px;transition:color .2s}
  .me-hero .me-link:hover{color:var(--coral)}
  .me-photo{position:relative;justify-self:center}
  .me-photo img{width:100%;max-width:430px;border-radius:16px;box-shadow:0 30px 70px -30px rgba(29,30,86,.5);position:relative;z-index:2}
  .me-photo .ph-ring{position:absolute;width:130px;height:130px;border:2px solid var(--coral);border-radius:50%;
    top:-26px;left:-26px;opacity:.4;z-index:1}
  .me-photo::after{content:"";position:absolute;width:60%;height:60%;background:var(--navy);border-radius:16px;
    right:-22px;bottom:-22px;opacity:.08;z-index:0}
  .me-hero.loaded .me-eyebrow,.me-hero.loaded .me-sub,.me-hero.loaded .me-actions{opacity:1;transform:none;transition:opacity .8s ease,transform .8s ease}
  .me-hero.loaded .me-eyebrow{transition-delay:.1s}
  .me-hero.loaded .me-sub{transition-delay:.85s}
  .me-hero.loaded .me-actions{transition-delay:1s}
  .me-hero.loaded h1 span.line > span{transform:translateY(0);transition:transform .9s cubic-bezier(.22,1,.36,1)}
  .me-hero.loaded h1 span.line:nth-child(2) > span{transition-delay:.3s}
  .me-hero.loaded h1 span.line:nth-child(3) > span{transition-delay:.45s}

  /* ---------- LOGO SHOWCASE (light/dark toggle) ---------- */
  .logo-stage{position:relative;border-radius:20px;overflow:hidden;background:var(--paper);
    transition:background 1.1s cubic-bezier(.4,0,.2,1);padding:30px 30px 24px;
    box-shadow:0 30px 60px -32px rgba(29,30,86,.4)}
  .logo-stage.dark{background:var(--navy)}
  .logo-stage .stage-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
  .logo-stage .stage-label{font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--navy);transition:color .9s ease}
  .logo-stage.dark .stage-label{color:var(--paper)}
  .logo-toggle{display:inline-flex;align-items:center;gap:11px;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700}
  .logo-toggle .lbl{transition:opacity .4s ease,color .9s ease;color:var(--navy)}
  .logo-stage.dark .logo-toggle .lbl{color:var(--paper)}
  .logo-toggle .lbl.off{opacity:.32}
  .logo-switch{width:58px;height:30px;border-radius:30px;border:none;cursor:pointer;background:var(--navy);
    position:relative;transition:background .6s ease;padding:0;flex:0 0 auto}
  .logo-stage.dark .logo-switch{background:var(--coral)}
  .logo-switch::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;
    background:var(--paper);transition:transform .5s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px rgba(0,0,0,.25)}
  .logo-stage.dark .logo-switch::after{transform:translateX(28px)}
  .logo-grid{display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:auto auto;gap:14px}
  .logo-cell{position:relative;border-radius:13px;display:flex;align-items:center;justify-content:center;
    padding:20px;min-height:110px;background:rgba(29,30,86,.04);transition:background .9s ease}
  .logo-stage.dark .logo-cell{background:rgba(255,255,255,.05)}
  .logo-cell.primary{grid-row:1 / span 2;padding:28px}
  .logo-cell .pair{position:relative;width:100%;display:flex;align-items:center;justify-content:center}
  .logo-cell.primary .pair{min-height:290px}
  .logo-cell.small .pair{min-height:104px}
  .logo-cell .pair img{position:absolute;max-width:100%;width:auto;height:auto;transition:opacity 1s ease}
  .logo-cell.primary .pair img{max-height:320px}
  .logo-cell.small .pair img{max-height:116px}
  .pair img.dark-v{opacity:0}
  .logo-stage.dark .pair img.light-v{opacity:0}
  .logo-stage.dark .pair img.dark-v{opacity:1}
  .logo-cell .cap{position:absolute;bottom:8px;left:13px;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;
    font-weight:700;color:var(--navy);opacity:.4}
  .logo-stage.dark .logo-cell .cap{color:var(--paper);opacity:.5}
  @media(max-width:680px){
    .logo-grid{grid-template-columns:1fr;grid-template-rows:none}
    .logo-cell.primary{grid-row:auto}
    .logo-cell.primary .pair{min-height:210px}
    .logo-cell.primary .pair img{max-height:230px}
  }


  /* ---------- PATTERN + BOOKMARK MOCKUP (05) ---------- */
  .pattern-duo{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(18px,3vw,32px);align-items:stretch}
  .pattern-tile{border-radius:16px;min-height:420px;
    background-color:var(--navy);
    background-image:url('img/pattern-tile.png');
    background-repeat:repeat;background-size:auto clamp(360px,48vw,520px);
    box-shadow:0 26px 60px -32px rgba(29,30,86,.55);
    border:1px solid rgba(29,30,86,.1)}
  .pattern-mockup{margin:0;border-radius:16px;overflow:hidden;
    box-shadow:0 26px 60px -30px rgba(29,30,86,.5);background:var(--white)}
  .pattern-mockup img{width:100%;height:100%;object-fit:cover;display:block;min-height:420px}
  @media(max-width:860px){
    .pattern-duo{grid-template-columns:1fr;gap:18px}
    .pattern-tile{min-height:260px}
    .pattern-mockup img{min-height:auto}
  }


  .motif-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.6vw,18px);
    background:linear-gradient(160deg,var(--pink) 0%,var(--paper) 100%);
    border-radius:18px;padding:clamp(16px,2.4vw,28px);
    box-shadow:0 24px 60px -32px rgba(29,30,86,.4)}
  .motif-cell{aspect-ratio:1/1;border-radius:13px;background:rgba(255,255,255,.5);
    display:flex;align-items:center;justify-content:center;padding:14px;
    transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,background .4s ease}
  .motif-cell img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;
    filter:drop-shadow(0 6px 10px rgba(29,30,86,.12));animation:motif-float 6s ease-in-out infinite}
  .motif-cell:nth-child(1) img{animation-delay:-.2s}
  .motif-cell:nth-child(2) img{animation-delay:-1.1s}
  .motif-cell:nth-child(3) img{animation-delay:-2.4s}
  .motif-cell:nth-child(4) img{animation-delay:-3.1s}
  .motif-cell:nth-child(5) img{animation-delay:-.7s}
  .motif-cell:nth-child(6) img{animation-delay:-1.9s}
  .motif-cell:nth-child(7) img{animation-delay:-2.8s}
  .motif-cell:nth-child(8) img{animation-delay:-3.6s}
  .motif-cell:nth-child(9) img{animation-delay:-1.4s}
  @keyframes motif-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
  .motif-cell:hover{transform:translateY(-4px) scale(1.04);background:#fff;
    box-shadow:0 18px 36px -18px rgba(29,30,86,.4)}
  .motif-cell:hover img{animation-play-state:paused}
  /* staggered reveal as the grid scrolls in */
  .motif-grid .motif-cell{opacity:0;transform:translateY(20px) scale(.92);
    transition:opacity .6s ease,transform .6s cubic-bezier(.22,1,.36,1)}
  .motif-grid.in .motif-cell{opacity:1;transform:none}
  .motif-grid.in .motif-cell:nth-child(1){transition-delay:.05s}
  .motif-grid.in .motif-cell:nth-child(2){transition-delay:.12s}
  .motif-grid.in .motif-cell:nth-child(3){transition-delay:.19s}
  .motif-grid.in .motif-cell:nth-child(4){transition-delay:.26s}
  .motif-grid.in .motif-cell:nth-child(5){transition-delay:.33s}
  .motif-grid.in .motif-cell:nth-child(6){transition-delay:.40s}
  .motif-grid.in .motif-cell:nth-child(7){transition-delay:.47s}
  .motif-grid.in .motif-cell:nth-child(8){transition-delay:.54s}
  .motif-grid.in .motif-cell:nth-child(9){transition-delay:.61s}

  .morework{background:linear-gradient(180deg,#fdf0dd 0%,#fbe8cf 100%);padding:clamp(70px,10vw,120px) clamp(20px,5vw,40px);
    --choco:#7a3b1d;--rasp:#e0143c;--cream:#fdf0dd}
  .morework .wrap{max-width:1100px;margin:0 auto}
  .morework .mw-head{max-width:760px;margin-bottom:clamp(36px,5vw,56px)}
  .morework .section-title{color:var(--choco)}
  .morework .section-title em{color:var(--rasp);font-style:italic}
  .morework .lede{color:#6b4a33}
  .morework .lede em{font-style:italic;color:var(--choco);font-weight:500}
  /* gallery */
  .mw-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.6vw,20px);margin-bottom:clamp(48px,6vw,72px)}
  .mw-photo{margin:0;border-radius:14px;overflow:hidden;box-shadow:0 18px 40px -24px rgba(122,59,29,.55);background:#fff}
  .mw-photo img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/5;transition:transform .5s ease}
  .mw-photo:hover img{transform:scale(1.04)}
  /* easter egg block */
  .mw-egg{text-align:center;max-width:780px;margin:0 auto}
  .mw-egg h3{font-family:var(--display);font-weight:400;font-size:clamp(1.4rem,2.6vw,2rem);color:var(--choco);margin-bottom:16px;letter-spacing:-.01em}
  .mw-egg p{color:#6b4a33;font-size:clamp(1rem,1.4vw,1.12rem);max-width:64ch;margin:0 auto;text-align:left}
  .mw-icons{display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(10px,2vw,22px);margin:clamp(28px,4vw,40px) 0 14px}
  .mw-icons img{width:clamp(70px,9vw,104px);height:auto;transition:transform .35s ease}
  .mw-icons img:hover{transform:translateY(-6px) rotate(-4deg)}
  .mw-egg p.mw-egg-hint{font-family:var(--script);color:var(--rasp);font-size:clamp(1.2rem,2vw,1.5rem);text-align:center!important;max-width:none;margin-left:auto;margin-right:auto}
  @media(max-width:760px){
    .mw-gallery{grid-template-columns:repeat(2,1fr)}
    .mw-icons img{width:74px}
  }

  /* about-end + contact */
  .about-actions{margin-top:32px;display:flex;flex-wrap:wrap;gap:16px;align-items:center}
  .about-end .me-btn{font-family:var(--body);font-weight:700;font-size:.95rem;background:var(--navy);color:#fff;
    padding:15px 30px;border-radius:50px;transition:transform .25s ease,box-shadow .25s ease;box-shadow:0 14px 34px -16px rgba(29,30,86,.7)}
  .about-end .me-btn:hover{transform:translateY(-3px)}
  .about-end .me-link{font-weight:600;font-size:.95rem;color:var(--navy);border-bottom:1.5px solid var(--coral);padding-bottom:3px;transition:color .2s}
  .about-end .me-link:hover{color:var(--coral)}
  .contact-band{background:linear-gradient(180deg,var(--paper) 0%,var(--pink) 100%);padding:clamp(70px,11vw,130px) 0}
  .contact-band .me-btn{display:inline-block;font-family:var(--body);font-weight:700;font-size:1.05rem;background:var(--coral);color:#fff;
    padding:17px 36px;border-radius:50px;transition:transform .25s ease,box-shadow .25s ease;box-shadow:0 18px 40px -16px rgba(241,57,44,.6)}
  .contact-band .me-btn:hover{transform:translateY(-3px);background:#ff4738}

  /* selected work transition label */
  .work-intro{text-align:center;padding:clamp(60px,9vw,110px) clamp(20px,5vw,40px) 0}
  .work-intro h2{font-family:var(--display);font-weight:330;font-size:clamp(1.8rem,4vw,2.8rem);color:var(--navy);letter-spacing:-.01em}
  .work-intro h2 em{font-style:italic;color:var(--coral)}

  /* ---------- HERO ---------- */
  .hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;
    padding:120px clamp(20px,5vw,40px) 60px;overflow:hidden}
  .hero-inner{max-width:var(--maxw);margin:0 auto;width:100%;position:relative;z-index:2}
  /* peeking guardian cat — peeks out from above the meta divider line */
  .peek-cat{position:absolute;right:clamp(20px,7vw,140px);width:clamp(200px,24vw,360px);z-index:1;pointer-events:none;
    transform:translateY(120%);transition:transform .18s linear;will-change:transform}
  @media(max-width:680px){.peek-cat{width:150px;right:16px}}
  .hero .kicker{font-family:var(--script);font-size:clamp(1.6rem,4vw,2.6rem);color:var(--navy);font-weight:500;margin-bottom:-.1em;opacity:0;transform:translateY(20px)}
  .hero h1{font-family:var(--display);font-weight:330;font-size:clamp(2.8rem,9vw,6.6rem);line-height:.96;color:var(--navy);letter-spacing:-.02em;margin:.08em 0 .14em}
  .hero h1 .book{display:block;color:var(--coral);font-weight:600}
  .hero h1 span.line{display:block;overflow:hidden}
  .hero h1 span.line > span{display:block;transform:translateY(105%)}
  .hero .tagline{font-family:var(--script);font-size:clamp(1.15rem,2.2vw,1.65rem);color:var(--navy);font-weight:500;opacity:0;transform:translateY(20px);max-width:min(900px,80%);white-space:nowrap}
  @media(max-width:1100px){.hero .tagline{white-space:normal}}
  .hero .meta{display:flex;flex-wrap:nowrap;gap:0;margin-top:clamp(36px,6vw,60px);border-top:1.5px solid rgba(29,30,86,.16);
    position:relative;z-index:3}
  /* mask strip that hides the cat's lower half below the divider line */
  .hero .meta::before{content:"";position:absolute;left:-100vw;right:-100vw;top:1px;height:60vh;
    background:linear-gradient(180deg, var(--paper) 0%, var(--paper) 65%, rgba(253,244,248,0) 100%);z-index:2;pointer-events:none}
  .hero .meta .item{position:relative;z-index:3;padding:18px 0 4px 0;flex:1 1 0;min-width:0;margin-right:clamp(28px,4vw,56px)}
  .hero .meta .item:not(:last-child){border-right:1px solid rgba(29,30,86,.12);padding-right:clamp(28px,4vw,56px);margin-right:clamp(28px,4vw,56px)}
  .hero .meta .k{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);font-weight:700;margin-bottom:5px}
  .hero .meta .v{font-family:var(--display);font-size:1.04rem;color:var(--navy);font-weight:450}
  .hero-bg-cat{position:absolute;bottom:-4%;left:-6%;width:min(46vw,560px);opacity:.07;z-index:1;pointer-events:none}
  .hero-deco{position:absolute;top:6%;right:-40px;width:min(34vw,360px);z-index:1;pointer-events:none;opacity:.9}
  .scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:.2em;
    text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadein 1s ease 1.8s forwards}
  .scroll-hint .line{width:1px;height:34px;background:var(--navy);opacity:.3;animation:scrolldown 1.8s ease-in-out infinite}
  @keyframes scrolldown{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}}
  @keyframes fadein{to{opacity:1}}

  .hero.loaded .kicker,.hero.loaded .tagline,.hero.loaded .meta{opacity:1;transform:translateY(0);transition:opacity .8s ease,transform .8s ease}
  .hero.loaded .kicker{transition-delay:.15s}
  .hero.loaded .tagline{transition-delay:.9s}
  .hero.loaded .meta{transition-delay:1.1s}
  .hero.loaded h1 span.line > span{transform:translateY(0);transition:transform .9s cubic-bezier(.22,1,.36,1)}
  .hero.loaded h1 span.line:nth-child(2) > span{transition-delay:.35s}
  .hero.loaded h1 span.line:nth-child(3) > span{transition-delay:.5s}

  /* ---------- generic section spacing ---------- */
  .blk{padding:clamp(70px,11vw,140px) 0}
  .blk.tight{padding:clamp(50px,8vw,90px) 0}

  /* ---------- reveal ---------- */
  .reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s cubic-bezier(.22,1,.36,1)}
  .reveal.in{opacity:1;transform:none}
  .reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}

  /* ---------- two column ---------- */
  .two{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px);align-items:center}
  .two.text-first{grid-template-columns:.9fr 1.1fr}
  .figure{border-radius:14px;overflow:hidden;box-shadow:0 24px 60px -28px rgba(29,30,86,.45);background:var(--white)}
  /* client section: tall window photo — capped height, centered crop, framed for the navy band */
  .client-figure{align-self:center;max-height:520px;border-radius:16px;
    border:2px solid var(--coral);box-shadow:0 30px 70px -30px rgba(0,0,0,.55);
    padding:8px;background:rgba(241,57,44,.06)}
  .client-figure img{width:100%;height:100%;max-height:504px;object-fit:cover;object-position:center 38%;border-radius:11px}
  .figure img{width:100%}
  .figure.framed{border:1px solid rgba(29,30,86,.08)}

  /* ---------- client (navy band) ---------- */
  .band-navy{background:var(--navy);color:var(--pink)}
  .band-navy h2.section-title{color:var(--white)}
  .band-navy h2.section-title em{color:var(--coral-soft)}
  .band-navy .body-col p{color:rgba(253,233,244,.82)}
  .band-navy .body-col p strong{color:var(--white)}
  .band-navy .body-col p em{color:var(--coral-soft)}
  .pull{font-family:var(--display);font-style:italic;font-weight:340;font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.25;
    color:var(--white);margin-top:8px}
  .pull span{color:var(--coral-soft)}

  /* ---------- colors interactive ---------- */
  .swatches{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:6px}
  .swatch{border-radius:12px;padding:20px;min-height:150px;display:flex;flex-direction:column;justify-content:space-between;
    cursor:pointer;transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s ease;position:relative;overflow:hidden}
  .swatch:hover{transform:translateY(-6px);box-shadow:0 20px 40px -20px rgba(29,30,86,.5)}
  .swatch .nm{font-family:var(--display);font-size:1.15rem;font-weight:500}
  .swatch .hx{font-size:.78rem;letter-spacing:.08em;font-weight:600;opacity:.85;font-variant-numeric:tabular-nums}
  .swatch .desc{font-size:.82rem;line-height:1.4;opacity:.9;max-width:34ch}
  .swatch .copied{position:absolute;top:12px;right:14px;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;
    background:rgba(255,255,255,.9);color:var(--navy);padding:3px 8px;border-radius:20px;opacity:0;transition:opacity .25s ease;font-weight:700}
  .swatch.show .copied{opacity:1}
  .sw-navy{background:var(--navy);color:#fff}
  .sw-pink{background:var(--pink-mid);color:var(--navy)}
  .sw-coral{background:var(--coral);color:#fff}
  .sw-paper{background:var(--paper);color:var(--navy);border:1px solid rgba(29,30,86,.12)}
  .color-note{font-family:var(--script);font-size:1.5rem;color:var(--navy);margin-top:26px;line-height:1.3}

  /* ---------- full-bleed pattern ---------- */
  .bleed{position:relative;overflow:hidden;height:clamp(300px,42vw,480px);
    background-color:var(--navy);background-repeat:repeat;background-size:auto clamp(300px,42vw,480px)}
  .bleed .cap{position:absolute;left:clamp(20px,5vw,56px);bottom:clamp(20px,4vw,40px);max-width:380px;
    background:rgba(253,244,248,.94);backdrop-filter:blur(6px);padding:22px 26px;border-radius:12px;border-left:3px solid var(--coral)}
  .bleed .cap h3{font-family:var(--display);font-weight:450;font-size:1.3rem;color:var(--navy);margin-bottom:6px}
  .bleed .cap p{font-size:.92rem;color:var(--muted);margin:0}

  /* ---------- tech / from concept to code ---------- */
  .band-paper2{background:linear-gradient(180deg,var(--pink) 0%,var(--paper) 100%)}
  .tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
  .tech-card{background:var(--white);border-radius:14px;padding:28px 26px;border:1px solid rgba(29,30,86,.07);
    box-shadow:0 16px 40px -30px rgba(29,30,86,.5);transition:transform .3s ease,box-shadow .3s ease}
  .tech-card:hover{transform:translateY(-5px);box-shadow:0 24px 50px -28px rgba(29,30,86,.45)}
  .tech-card .ic{font-family:var(--display);font-size:1.6rem;color:var(--coral);font-weight:600;margin-bottom:14px;
    width:46px;height:46px;border-radius:11px;background:var(--pink);display:flex;align-items:center;justify-content:center}
  .tech-card h3{font-family:var(--display);font-weight:500;font-size:1.18rem;color:var(--navy);margin-bottom:9px;line-height:1.2}
  .tech-card p{font-size:.92rem;color:var(--muted);margin:0}
  .stats{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,64px);margin-top:54px;justify-content:center;text-align:center}
  .stat .n{font-family:var(--display);font-size:clamp(2.2rem,5vw,3.4rem);font-weight:330;color:var(--navy);line-height:1;letter-spacing:-.02em}
  .stat .n em{color:var(--coral);font-style:normal}
  .stat .l{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:10px;font-weight:600}

  /* ---------- demo CTA ---------- */
  .demo{background:var(--navy);color:var(--pink);text-align:center;padding:clamp(80px,13vw,150px) clamp(20px,5vw,40px);position:relative;overflow:hidden}
  .demo .badge{display:inline-flex;align-items:center;gap:9px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
    font-weight:700;color:var(--coral-soft);border:1.5px solid rgba(241,91,87,.5);padding:8px 18px;border-radius:40px;margin-bottom:30px}
  .demo .badge .live{width:8px;height:8px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 0 rgba(241,57,44,.6);animation:pulse 2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(241,57,44,.6)}70%{box-shadow:0 0 0 12px rgba(241,57,44,0)}100%{box-shadow:0 0 0 0 rgba(241,57,44,0)}}
  .demo h2{font-family:var(--display);font-weight:330;font-size:clamp(2.2rem,6vw,4.2rem);line-height:1.04;color:var(--white);
    letter-spacing:-.02em;margin-bottom:22px}
  .demo h2 em{font-style:italic;color:var(--coral-soft)}
  .demo p{font-size:clamp(1rem,1.7vw,1.18rem);color:rgba(253,233,244,.8);max-width:54ch;margin:0 auto 16px}
  .demo p.fine{font-size:.92rem;color:rgba(253,233,244,.55);max-width:50ch;margin-bottom:42px}
  .demo .btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--body);font-weight:700;font-size:1rem;letter-spacing:.02em;
    background:var(--coral);color:#fff;padding:18px 38px;border-radius:50px;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
    box-shadow:0 18px 40px -16px rgba(241,57,44,.7)}
  .demo .btn:hover{transform:translateY(-3px);background:#ff4738;box-shadow:0 24px 50px -16px rgba(241,57,44,.8)}
  .demo .btn .arrow{transition:transform .25s ease}
  .demo .btn:hover .arrow{transform:translate(4px,-4px)}
  .demo .try{margin-top:34px;display:flex;flex-wrap:wrap;gap:10px 22px;justify-content:center}
  .demo .try a{font-size:.84rem;letter-spacing:.03em;color:rgba(253,233,244,.7);border-bottom:1px solid rgba(253,233,244,.25);
    padding-bottom:2px;transition:color .2s ease,border-color .2s ease}
  .demo .try a:hover{color:var(--coral-soft);border-color:var(--coral-soft)}

  /* ---------- footer ---------- */
  .foot{background:var(--navy-deep);color:rgba(253,233,244,.7);padding:48px clamp(20px,5vw,40px);text-align:center}
  .foot .fb{font-family:var(--display);font-size:1.2rem;color:var(--white);font-weight:500;margin-bottom:10px}
  .foot .fb .dot{color:var(--coral)}
  .foot a.contact{color:var(--coral-soft)}
  .foot .small{font-size:.8rem;opacity:.6;margin-top:14px}

  /* ---------- responsive ---------- */
  @media(max-width:860px){
    .section-label,.section-label--center{justify-content:flex-start}
    .work-intro{text-align:left}
    .me-grid{grid-template-columns:1fr;gap:40px}
    .me-photo{order:-1}
    .me-photo img{max-width:300px}
    .nav-menu{gap:16px}
    .nav-menu a:not(.nav-cta){display:none}
    .two,.two.text-first{grid-template-columns:1fr;gap:34px}
    .two .figure{order:-1}
    .two.flip .figure{order:0}
    .two.flip .motif-grid{order:-1}
    .motif-grid{max-width:460px;margin:0 auto;width:100%}
    .swatches{grid-template-columns:repeat(2,1fr)}
    .tech-grid{grid-template-columns:1fr}
    .hero .meta{flex-wrap:wrap}
    .hero .meta .item{padding:14px 0 4px;margin-right:22px;border-right:none!important;flex:1 1 40%}
    .hero-deco{display:none}
    /* scroll-hint ne csússzon a tartalomra mobilon: kerüljön a folyamba, levegővel */
    .scroll-hint{position:static;transform:none;margin:48px auto 8px;left:auto;bottom:auto}
    /* a tagline kapjon helyet a kikukucskáló macskának */
    .hero .tagline{max-width:74%}
  }
  @media(max-width:520px){
    .swatches{grid-template-columns:1fr}
    .hero .meta{gap:0}
    .nav .nav-cta{display:none}
    .motif-grid{gap:6px;padding:10px;max-width:340px}
    .motif-cell{padding:6px;border-radius:9px}
    .motif-cell img{max-height:78px}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important}
    .reveal{opacity:1;transform:none}
    .hero h1 span.line>span{transform:none}
    .hero .kicker,.hero .tagline,.hero .meta{opacity:1;transform:none}
  }

