  :root {
    --cream:#fff7f3; --pink050:#fdeef0; --pink100:#fbdce5; --pink150:#f9d0dd;
    --pink200:#f6bdd0; --rose:#f2a4bd; --hotpink:#e96aa0; --magenta:#d6478c;
    --lav:#e9ddf7; --lavInk:#b496df; --mint:#cdeede; --mintInk:#7fc6a4;
    --butter:#fdecb8; --butterInk:#eec45f; --ink:#4b3a41; --inkSoft:#8a757e;
    --line:rgba(75,58,65,0.12);

    --serif:"Cormorant Garamond", Georgia, serif;
    --round:"Baloo 2", system-ui, sans-serif;
    --body:"Quicksand", system-ui, sans-serif;
    --mono:ui-monospace, "SF Mono", Menlo, monospace;

    --sh-photo:0 18px 40px rgba(75,58,65,.20);
    --sh-card:0 12px 26px rgba(75,58,65,.15);
    --sh-plain:0 8px 20px rgba(75,58,65,.08);
    --sh-mat:0 6px 14px rgba(75,58,65,.10);
    --sh-itin:0 8px 20px rgba(214,71,140,.08);
    --sh-badge:0 4px 10px rgba(75,58,65,.12);
    --sh-social:0 4px 12px rgba(214,71,140,.16);
  }

  * { box-sizing:border-box; }
  html,body { margin:0; padding:0; }
  body {
    min-height:100vh; color:var(--ink);
    background:linear-gradient(180deg, var(--pink100) 0%, var(--pink050) 45%, var(--cream) 100%) no-repeat;
    font-family:var(--body); font-size:16px; line-height:1.5;
    -webkit-font-smoothing:antialiased;
  }
  a { color:inherit; text-decoration:none; }

  .wrap { max-width:1080px; margin:0 auto; padding-left:72px; padding-right:72px; }

  .star, .sparkle { display:inline-block; position:relative; }
  .star {
    clip-path:polygon(50% 2%, 61% 35%, 96% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 4% 35%, 39% 35%);
    background:radial-gradient(circle at 38% 32%, var(--c1) 0%, var(--c2) 55%, var(--c3) 100%);
  }
  .star.pink    { --c1:#ffd1e8; --c2:#ec5fa0; --c3:#a8246b; }
  .star.magenta { --c1:#ffc2e6; --c2:#d6478c; --c3:#7d1a52; }
  .star.lav     { --c1:#efe2ff; --c2:#b496df; --c3:#6f54a8; }
  .star.silver  { --c1:#ffffff; --c2:#d7d9e0; --c3:#9aa0ad; }
  .star::after {
    content:""; position:absolute; top:14%; left:26%; width:22%; height:22%;
    border-radius:50%; background:#fff; mix-blend-mode:screen; opacity:.85;
  }
  .sparkle {
    clip-path:polygon(50% 0%, 58% 42%, 100% 50%, 58% 58%, 50% 100%, 42% 58%, 0% 50%, 42% 42%);
  }

  .heart { display:inline-block; position:relative; line-height:0; }
  .heart svg { display:block; width:100%; height:100%; }
  .heart i { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:75%; }

  .badge {
    display:inline-flex; align-items:center; gap:5px;
    font-family:var(--round); font-weight:700; font-size:12.5px;
    padding:6px 13px; border-radius:999px; border:2px solid #fff;
    box-shadow:var(--sh-badge); white-space:nowrap;
  }
  .badge.handmade { background:var(--mint);   color:#2f7d57; }
  .badge.summer   { background:var(--lav);    color:#6f54a8; }
  .badge.butter   { background:var(--butter); color:#8a6a16; }

  .ph {
    position:relative; display:grid; place-items:center; border-radius:3px;
    box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.5);
  }
  .ph.pink   { background:repeating-linear-gradient(135deg, var(--pink100) 0 11px, var(--pink200) 11px 22px); }
  .ph.lav    { background:repeating-linear-gradient(135deg, #e9ddf7 0 11px, #d8c4f1 11px 22px); }
  .ph.mint   { background:repeating-linear-gradient(135deg, #d7f0e3 0 11px, #bfe7d2 11px 22px); }
  .ph.butter { background:repeating-linear-gradient(135deg, #fdecb8 0 11px, #f7dd92 11px 22px); }
  .ph .ph-lbl {
    font-family:var(--mono); font-size:10px; color:var(--ink); opacity:.55;
    background:rgba(255,255,255,.7); padding:3px 9px; border-radius:999px;
    letter-spacing:.04em;
  }

  .kw-link { transition:transform .18s cubic-bezier(.2,.8,.3,1); }
  .kw-link:hover  { transform:translateY(-3px) scale(1.012); }
  .kw-link:active { transform:translateY(-1px) scale(.995); }
  .kw-chip { transition:transform .18s cubic-bezier(.2,.8,.3,1); }
  .kw-chip:hover { transform:translateY(-3px) rotate(-4deg); }

  .hdr { display:flex; align-items:center; justify-content:space-between; padding-top:24px; padding-bottom:18px; }
  .hdr-left { display:flex; align-items:center; gap:18px; }
  .wordmark { font-family:var(--serif); font-style:italic; font-weight:600; font-size:28px; color:var(--magenta); }
  .nav { display:flex; align-items:center; gap:28px; }
  .nav a { font-family:var(--body); font-weight:600; font-size:13px; letter-spacing:.06em; color:var(--inkSoft); }
  .nav a.active { color:var(--ink); }
  .nav .search { width:18px; height:18px; color:var(--ink); }
  .divider { height:1px; background:var(--line); }

  html { scroll-behavior:smooth; }
  section[id], footer[id] { scroll-margin-top:30px; }

  .sidenav {
    position:fixed; left:30px; top:50%; transform:translateY(-50%);
    z-index:40; display:flex; flex-direction:column; gap:24px; padding-left:22px;
  }
  .sidenav .sn-line {
    position:absolute; left:4px; top:4px; bottom:4px; width:2px;
    background:var(--line); border-radius:2px;
  }
  .sidenav .sn-dot {
    position:absolute; left:0; top:0; width:11px; height:11px; border-radius:50%;
    background:var(--hotpink); box-shadow:0 0 0 4px rgba(233,106,160,.18);
    transition:transform .45s cubic-bezier(.2,.8,.3,1); will-change:transform;
  }
  .sidenav a {
    font-family:var(--body); font-weight:600; font-size:12px; letter-spacing:.14em;
    text-transform:uppercase; color:var(--inkSoft); line-height:1;
    transition:color .25s ease, transform .25s cubic-bezier(.2,.8,.3,1);
  }
  .sidenav a:hover { color:var(--ink); }
  .sidenav a.active { color:var(--magenta); transform:translateX(4px); }

  @media (min-width:1181px) { .nav-mobile { display:none; } }
  @media (max-width:1180px) { .sidenav { display:none; } }

  .hero { position:relative; display:grid; grid-template-columns:1fr 430px; gap:60px; align-items:center; padding-top:34px; padding-bottom:30px; }
  .hero-decor { position:absolute; inset:0; pointer-events:none; z-index:0; }
  .hero-decor > * { position:absolute; }
  .hero-left, .hero-right { position:relative; z-index:1; }

  .eyebrow { font-family:var(--body); font-weight:700; font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--hotpink); margin-bottom:14px; }
  h1.hero-h1 { font-family:var(--serif); font-weight:600; font-size:68px; line-height:1; letter-spacing:-.01em; color:var(--ink); margin:0; }
  .hl { position:relative; font-style:italic; color:var(--magenta); }
  .hl::after { content:""; position:absolute; left:2px; right:2px; bottom:-4px; height:10px; background:var(--butter); border-radius:6px; z-index:-1; }
  .hero-p { font-family:var(--body); font-weight:500; font-size:17px; line-height:1.6; color:var(--inkSoft); max-width:440px; margin:22px 0 28px; }
  .cta-row { display:flex; align-items:center; gap:18px; }
  .btn { display:inline-block; font-family:var(--serif); font-weight:600; font-size:20px; background:var(--ink); color:#fff; padding:13px 34px; border-radius:4px; white-space:nowrap; }
  .since { font-family:var(--serif); font-style:italic; font-size:16px; color:var(--lavInk); transform:rotate(-5deg); }

  .polaroid-wrap { position:relative; justify-self:center; transform:rotate(-4.5deg); }
  .polaroid-mat { position:absolute; inset:-3px; background:#f3ecfb; border-radius:6px; box-shadow:var(--sh-mat); }
  .polaroid { position:relative; background:#fff; padding:14px 14px 18px; border-radius:4px; box-shadow:var(--sh-photo); }
  .polaroid .ph { height:360px; width:360px; border-radius:2px; }
  .polaroid-img { display:block; width:360px; height:360px; object-fit:cover; border-radius:2px; }
  .polaroid-logo { background:var(--pink050); }
  .polaroid-logo-img { display:block; width:260px; height:260px; object-fit:contain; padding:10px; border-radius:2px; }
  .polaroid-cap { font-family:var(--serif); font-style:italic; font-size:19px; color:var(--ink); text-align:center; margin-top:16px; }
  .polaroid .star-tl { position:absolute; top:-18px; left:-18px; z-index:3; }
  .polaroid .heart-sprite { position:absolute; top:-29.7px; right:-25.9px; transform:rotate(12deg); z-index:5; pointer-events:none; }
  .polaroid .heart-br { position:absolute; bottom:14px; right:-10px; transform:rotate(10deg); }

  .showcase { padding-top:12px; position:relative; }
  .showcase .col-decor { position:absolute; pointer-events:none; }
  .sec-head { display:flex; flex-direction:column; align-items:flex-start; gap:6px; margin-bottom:18px; }
  .sec-head-row { display:flex; align-items:center; gap:14px; }
  h2.sec-title { font-family:var(--serif); font-style:italic; font-weight:600; font-size:42px; color:var(--ink); white-space:nowrap; margin:0; }
  .sec-note { font-family:var(--body); font-weight:500; font-size:14px; color:var(--inkSoft); }

  .gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:36px; align-items:start; padding-top:14px; }
  .art { position:relative; }
  .art-mat { position:absolute; inset:-7px; border-radius:8px; box-shadow:var(--sh-mat); }
  .art-frame { position:relative; background:#fff; padding:14px 14px 0; border-radius:6px; box-shadow:var(--sh-card); }
  .art .ph { height:300px; border-radius:3px; }
  .art .art-img { display:block; width:100%; height:auto; object-fit:unset; border-radius:3px; }
  .art-cap { font-family:var(--serif); font-style:italic; font-size:18px; color:var(--ink); text-align:center; padding:14px 6px 16px; }
  .art .deco { position:absolute; z-index:4; }
  .art .heart-sprite { position:absolute; top:-19.8px; right:-17.3px; transform:rotate(12deg); z-index:5; pointer-events:none; }

  .art:nth-child(1) { transform:rotate(-2.4deg); }
  .art:nth-child(2) { transform:rotate(1.8deg); }
  .art:nth-child(3) { transform:rotate(-1.6deg); }
  .art:nth-child(4) { transform:rotate(2.2deg); }
  .art:nth-child(5) { transform:rotate(-2deg); }
  .art:nth-child(6) { transform:rotate(1.4deg); }
  .art:nth-child(1) .art-mat { background:#fdf0f4; }
  .art:nth-child(2) .art-mat { background:#fdf8ea; }
  .art:nth-child(3) .art-mat { background:#eef8f2; }
  .art:nth-child(4) .art-mat { background:#f5f0fc; }
  .art:nth-child(5) .art-mat { background:#fdf0f4; }
  .art:nth-child(6) .art-mat { background:#eef8f2; }

  .gallery-more { margin-top:36px; }
  .gallery-more[hidden] { display:none; }
  .gallery-more > .art { opacity:0; transition:opacity .5s ease; }
  .gallery-more.shown > .art { opacity:1; }
  .more-row { display:flex; justify-content:center; margin-top:32px; }
  .view-all {
    font-family:var(--round); font-weight:700; font-size:15px; color:var(--magenta);
    background:#fff; border:2px solid var(--pink150); padding:10px 28px; border-radius:999px;
    box-shadow:var(--sh-plain); cursor:pointer;
    transition:transform .18s cubic-bezier(.2,.8,.3,1), box-shadow .25s ease, color .2s ease;
  }
  .view-all:hover  { transform:translateY(-3px); box-shadow:var(--sh-card); color:var(--hotpink); }
  .view-all:active { transform:translateY(-1px); }

  .nav-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; padding-top:14px; }
  .nav-card {
    position:relative; display:flex; flex-direction:row; align-items:center; background:#fff;
    border-radius:14px; overflow:hidden; box-shadow:var(--sh-card);
    transition:transform .4s cubic-bezier(.2,.8,.3,1), box-shadow .4s ease;
  }
  .nav-card:hover { transform:translateY(-7px) scale(1.012); box-shadow:var(--sh-photo); }
  .nav-card-media { height:210px; overflow:hidden; background:var(--pink050); }
  .nav-card-media img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s cubic-bezier(.2,.8,.3,1); }
  .nav-card:hover .nav-card-media img { transform:scale(1.06); }
  .nav-card-icon {
    flex-shrink:0; width:90px; align-self:stretch; display:flex; align-items:center; justify-content:center;
    background:linear-gradient(135deg, var(--pink100) 0%, var(--lav) 100%);
    position:relative; overflow:hidden;
  }
  .nav-card-icon > i:first-child { font-size:44px; color:var(--magenta); opacity:.9; transition:transform .4s cubic-bezier(.2,.8,.3,1); }
  .nav-card:hover .nav-card-icon > i:first-child { transform:scale(1.12) rotate(-6deg); }
  .nav-card-icon-accent { font-size:20px !important; color:var(--hotpink) !important; opacity:.7; position:absolute; top:14px; right:18px; transition:transform .4s cubic-bezier(.2,.8,.3,1) !important; }
  .nav-card:hover .nav-card-icon-accent { transform:scale(1.2) rotate(20deg) !important; opacity:1 !important; }
  .nav-card-body { padding:14px 20px 18px; }
  .nav-card-title { font-family:var(--serif); font-weight:600; font-size:27px; color:var(--magenta); margin-bottom:5px; line-height:1.1; }
  .nav-card-desc { font-family:var(--body); font-weight:500; font-size:14.5px; color:var(--inkSoft); line-height:1.5; }
  .nav-card-go {
    display:inline-block; margin-top:15px; font-family:var(--round); font-weight:700;
    font-size:13px; letter-spacing:.05em; color:var(--hotpink); transition:transform .25s ease;
  }
  .nav-card:hover .nav-card-go { transform:translateX(5px); }

  .backlink {
    display:inline-flex; align-items:center; gap:7px; font-family:var(--round);
    font-weight:700; font-size:13px; letter-spacing:.05em; text-transform:uppercase;
    color:var(--inkSoft); margin-top:26px; transition:color .2s ease, transform .2s ease;
  }
  .backlink:hover { color:var(--magenta); transform:translateX(-3px); }
  .page-head { padding-top:14px; padding-bottom:6px; position:relative; }
  .page-eyebrow { font-family:var(--body); font-weight:700; font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--hotpink); margin-bottom:12px; }
  h1.page-title { font-family:var(--serif); font-weight:600; font-size:56px; line-height:1.02; color:var(--ink); margin:0; }
  .page-intro { font-family:var(--body); font-weight:500; font-size:16px; color:var(--inkSoft); max-width:560px; margin:14px 0 28px; line-height:1.6; }
  .page-section { padding-bottom:36px; position:relative; }

  .timeline { background:transparent; margin-top:44px; padding:38px 0; position:relative; overflow:hidden; }
  .timeline .d-star { position:absolute; top:18px; right:40px; }
  .timeline .d-spark { position:absolute; bottom:18px; left:40px; }
  .tl-head { display:flex; align-items:center; gap:14px; margin-bottom:14px; }
  h2.tl-title { font-family:var(--serif); font-style:italic; font-weight:600; font-size:42px; color:var(--ink); white-space:nowrap; margin:0; }
  .tl-intro { font-family:var(--body); font-weight:500; font-size:15px; color:var(--inkSoft); max-width:520px; margin-bottom:30px; }
  .tl-track { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; position:relative; z-index:1; }
  .tl-track::before {
    content:""; position:absolute; left:6%; right:6%; top:34px; height:2px;
    background:repeating-linear-gradient(90deg, var(--rose) 0 8px, transparent 8px 16px);
    z-index:0;
  }
  .tl-card { position:relative; background:#fff; border-radius:8px; padding:24px 24px 22px; box-shadow:var(--sh-itin); }
  .tl-card:nth-child(1) { transform:rotate(-1.4deg); }
  .tl-card:nth-child(2) { transform:rotate(1.2deg); }
  .tl-card:nth-child(3) { transform:rotate(1deg); }
  .tl-stage {
    display:inline-block; font-family:var(--round); font-weight:700; font-size:11px;
    letter-spacing:.1em; text-transform:uppercase; padding:5px 12px; border-radius:999px;
    border:2px solid #fff; box-shadow:var(--sh-badge); margin-bottom:14px;
  }
  .tl-stage.now    { background:var(--hotpink); color:#fff; }
  .tl-stage.next   { background:var(--lav);     color:#6f54a8; }
  .tl-stage.someday{ background:var(--mint);    color:#2f7d57; }
  .tl-title2 { font-family:var(--serif); font-weight:600; font-size:23px; color:var(--magenta); margin-bottom:7px; line-height:1.1; }
  .tl-desc { font-family:var(--body); font-weight:500; font-size:13.5px; line-height:1.55; color:var(--inkSoft); }

  .events { padding-top:44px; position:relative; }
  .events .col-decor { position:absolute; pointer-events:none; }

  .ev-group { margin-top:32px; }
  .ev-group:first-of-type { margin-top:18px; }
  .ev-group-head { display:flex; align-items:center; gap:14px; margin-bottom:16px; }
  .ev-group-head .line { flex:1; height:1px; background:var(--line); }
  .ev-status {
    display:inline-flex; align-items:center; gap:6px; font-family:var(--round); font-weight:700;
    font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; padding:5px 13px; border-radius:999px;
    border:2px solid #fff; box-shadow:var(--sh-badge); white-space:nowrap;
  }
  .ev-status .n { opacity:.7; font-size:10.5px; }
  .ev-status.upcoming { background:var(--hotpink); color:#fff; }
  .ev-status.applied  { background:var(--lav);     color:#6f54a8; }
  .ev-status.wishlist { background:var(--butter);  color:#8a6a16; }
  .ev-status.past     { background:#ece7ea;        color:#8a757e; }

  .ev-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
  .ev-card {
    position:relative; background:#fff; border-radius:8px; padding:18px 22px;
    box-shadow:var(--sh-card); border-left:5px solid transparent;
  }
  .g-upcoming .ev-card { border-left-color:var(--hotpink); }
  .g-applied  .ev-card { border-left-color:var(--lavInk); }
  .g-wishlist .ev-card { border-left-color:var(--butterInk); }
  .g-past     .ev-card { border-left-color:#d9d2d6; opacity:.72; }
  .ev-see-all { font-family:var(--round); font-weight:700; font-size:11.5px; letter-spacing:.06em; color:var(--hotpink); white-space:nowrap; transition:transform .2s ease; }
  .ev-see-all:hover { transform:translateX(3px); }
  .ev-empty { font-family:var(--body); font-size:13.5px; color:var(--inkSoft); font-style:italic; padding:14px 2px 6px; }
  .ev-grid-row { display:flex; align-items:center; gap:18px; }
  .ev-grid-row .ev-grid { flex:1; }
  .ev-more-btn {
    flex-shrink:0; align-self:stretch; display:flex; align-items:center; justify-content:center;
    min-width:90px; padding:0 18px; border-radius:10px;
    font-family:var(--round); font-weight:700; font-size:13px; letter-spacing:.04em;
    color:var(--hotpink); background:var(--pink050); border:2px solid var(--pink150);
    white-space:nowrap; transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
  }
  .ev-more-btn:hover { transform:translateX(4px); background:#fff; box-shadow:var(--sh-plain); }
  .ev-date { font-family:var(--serif); font-weight:600; font-size:20px; color:var(--magenta); margin-bottom:4px; }
  .ev-name { font-family:var(--serif); font-weight:600; font-size:17px; color:var(--ink); }
  .ev-venue { font-family:var(--body); font-size:13px; color:var(--inkSoft); margin-top:3px; }

  .ftr { text-align:center; padding:30px 0; }
  .star-strip { display:flex; justify-content:center; align-items:center; gap:22px; margin-bottom:22px; }
  .socials { display:flex; justify-content:center; gap:12px; margin-bottom:14px; }
  .chip { width:46px; height:46px; border-radius:999px; background:#fff; display:grid; place-items:center; box-shadow:var(--sh-social); color:var(--magenta); }
  .chip svg { width:20px; height:20px; }
  .handle { font-family:var(--serif); font-style:italic; font-size:18px; color:var(--magenta); }

  @media (prefers-reduced-motion: no-preference) {
    @keyframes kw-float  { 0%,100%{ transform:translateY(0); }            50%{ transform:translateY(-9px); } }
    @keyframes kw-float2 { 0%,100%{ transform:translateY(0) rotate(-6deg); } 50%{ transform:translateY(-14px) rotate(6deg); } }
    @keyframes kw-drift  { 0%,100%{ transform:translate(0,0) rotate(0); }  33%{ transform:translate(7px,-10px) rotate(8deg); } 66%{ transform:translate(-6px,-5px) rotate(-6deg); } }
    @keyframes kw-bob    { 0%,100%{ transform:translateY(0) rotate(-12deg); } 50%{ transform:translateY(-6px) rotate(-12deg); } }
    @keyframes kw-tw     { 0%,100%{ opacity:.55; transform:scale(.8) rotate(0); }  50%{ opacity:1; transform:scale(1.12) rotate(25deg); } }
    @keyframes kw-spin   { 0%{ transform:rotate(0); } 100%{ transform:rotate(360deg); } }

    .kw-float  { animation:kw-float  5.5s ease-in-out infinite; }
    .kw-float2 { animation:kw-float2 7s   ease-in-out infinite; }
    .kw-drift  { animation:kw-drift  9s   ease-in-out infinite; }
    .kw-bob    { animation:kw-bob    4.5s ease-in-out infinite; }
    .kw-tw     { animation:kw-tw     3.4s ease-in-out infinite; }
    .kw-spin   { animation:kw-spin   16s  linear      infinite; }

    .d2 { animation-delay:-1.4s; }
    .d3 { animation-delay:-2.8s; }
    .d4 { animation-delay:-4.2s; }

    @keyframes kw-loft1 { 0%,100%{ transform:translateY(0px);   } 50%{ transform:translateY(-6px); } }
    @keyframes kw-loft2 { 0%,100%{ transform:translateY(0px);   } 50%{ transform:translateY(-7px); } }
    @keyframes kw-loft3 { 0%,100%{ transform:translateY(-2px);  } 50%{ transform:translateY(-8px); } }

    .art-frame { animation:kw-loft1 3s  ease-in-out infinite; }
    .art:nth-child(2) .art-frame { animation-name:kw-loft2; animation-duration:3.5s; animation-delay:-0.8s; }
    .art:nth-child(3) .art-frame { animation-name:kw-loft3; animation-duration:2.8s; animation-delay:-1.4s; }
    .art:nth-child(4) .art-frame { animation-name:kw-loft1; animation-duration:3.2s; animation-delay:-0.5s; }
    .art:nth-child(5) .art-frame { animation-name:kw-loft2; animation-duration:4s;   animation-delay:-2s; }
    .art:nth-child(6) .art-frame { animation-name:kw-loft3; animation-duration:3.3s; animation-delay:-1s; }

    @keyframes kw-sway1 { 0%,100%{ transform:rotate(-1.4deg) translateY(0);    } 50%{ transform:rotate(-2deg) translateY(-6px); } }
    @keyframes kw-sway2 { 0%,100%{ transform:rotate( 1.2deg) translateY(0);    } 50%{ transform:rotate( 1.8deg) translateY(-6px); } }
    @keyframes kw-sway3 { 0%,100%{ transform:rotate( 1.0deg) translateY(-4px); } 50%{ transform:rotate( 1.6deg) translateY(-8px); } }
    .tl-card:nth-child(1) { animation:kw-sway1 3s   ease-in-out infinite; }
    .tl-card:nth-child(2) { animation:kw-sway2 3.5s ease-in-out infinite; animation-delay:-0.8s; }
    .tl-card:nth-child(3) { animation:kw-sway3 2.8s ease-in-out infinite; animation-delay:-1.6s; }

    .ev-card { animation:kw-loft2 3s ease-in-out infinite; }
    .ev-group:nth-child(1) .ev-card:nth-child(1) { animation-duration:3.1s; animation-delay:-0.3s; }
    .ev-group:nth-child(1) .ev-card:nth-child(2) { animation-duration:3.4s; animation-delay:-1.2s; }
    .ev-group:nth-child(2) .ev-card:nth-child(1) { animation-duration:2.9s; animation-delay:-0.6s; }
    .ev-group:nth-child(3) .ev-card:nth-child(1) { animation-duration:3.6s; animation-delay:-0.9s; }
    .ev-group:nth-child(3) .ev-card:nth-child(2) { animation-duration:3.2s; animation-delay:-1.8s; }
    .ev-group:nth-child(4) .ev-card:nth-child(1) { animation-duration:3.3s; animation-delay:-1.4s; }
    .ev-group:nth-child(4) .ev-card:nth-child(2) { animation-duration:3.7s; animation-delay:-0.4s; }

    @keyframes kw-polaloft { 0%,100%{ transform:rotate(-4.5deg) translateY(0); } 50%{ transform:rotate(-4.5deg) translateY(-7px); } }
    .polaroid-wrap { animation:kw-polaloft 3s ease-in-out infinite; }

    @keyframes kw-pulse { 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.02); } }
    .tl-stage { animation:kw-pulse 7s ease-in-out infinite; }
    .tl-card:nth-child(2) .tl-stage { animation-delay:-2.3s; }
    .tl-card:nth-child(3) .tl-stage { animation-delay:-4.7s; }
    .ev-status { animation:kw-pulse 8s ease-in-out infinite; }
    .ev-group:nth-child(2) .ev-status { animation-delay:-2.5s; }
    .ev-group:nth-child(3) .ev-status { animation-delay:-5s; }
    .ev-group:nth-child(4) .ev-status { animation-delay:-1.2s; }

    @keyframes kw-wobble { 0%,100%{ transform:rotate(-4deg); } 50%{ transform:rotate(-5deg) scale(1.015); } }
    .badge.handmade { animation:kw-wobble 6s ease-in-out infinite; }

    @keyframes kw-fadein { from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:translateY(0); } }
    .hdr      { animation:kw-fadein .7s .00s both cubic-bezier(.2,.8,.3,1); }
    .eyebrow  { animation:kw-fadein .7s .10s both cubic-bezier(.2,.8,.3,1); }
    h1.hero-h1{ animation:kw-fadein .7s .20s both cubic-bezier(.2,.8,.3,1); }
    .hero-p   { animation:kw-fadein .7s .35s both cubic-bezier(.2,.8,.3,1); }
    .cta-row  { animation:kw-fadein .7s .50s both cubic-bezier(.2,.8,.3,1); }
    .ftr      { animation:kw-fadein .7s .10s both cubic-bezier(.2,.8,.3,1); }

    .backlink    { animation:kw-fadein .7s .00s both cubic-bezier(.2,.8,.3,1); }
    .page-eyebrow{ animation:kw-fadein .7s .08s both cubic-bezier(.2,.8,.3,1); }
    h1.page-title{ animation:kw-fadein .7s .16s both cubic-bezier(.2,.8,.3,1); }
    .page-intro  { animation:kw-fadein .7s .28s both cubic-bezier(.2,.8,.3,1); }

    @keyframes kw-glow { 0%,100%{ opacity:1; } 50%{ opacity:.6; } }
    .handle { animation:kw-glow 5s ease-in-out infinite; }
  }

  .reveal {
    opacity:0; transform:translateY(28px);
    transition:opacity .65s cubic-bezier(.2,.8,.3,1), transform .65s cubic-bezier(.2,.8,.3,1);
  }
  .reveal.visible { opacity:1; transform:translateY(0); }

  .reveal-children > * {
    opacity:0; transform:translateY(22px);
    transition:opacity .55s cubic-bezier(.2,.8,.3,1), transform .55s cubic-bezier(.2,.8,.3,1);
  }
  .reveal-children.visible > *:nth-child(1) { opacity:1; transform:translateY(0); transition-delay:.05s; }
  .reveal-children.visible > *:nth-child(2) { opacity:1; transform:translateY(0); transition-delay:.13s; }
  .reveal-children.visible > *:nth-child(3) { opacity:1; transform:translateY(0); transition-delay:.21s; }
  .reveal-children.visible > *:nth-child(4) { opacity:1; transform:translateY(0); transition-delay:.29s; }
  .reveal-children.visible > *:nth-child(5) { opacity:1; transform:translateY(0); transition-delay:.37s; }
  .reveal-children.visible > *:nth-child(6) { opacity:1; transform:translateY(0); transition-delay:.45s; }
  .reveal-children.visible > *:nth-child(7) { opacity:1; transform:translateY(0); transition-delay:.53s; }
  .reveal-children.visible > *:nth-child(8) { opacity:1; transform:translateY(0); transition-delay:.61s; }
  .reveal-children.visible > *:nth-child(9) { opacity:1; transform:translateY(0); transition-delay:.69s; }
  .reveal-children.visible > *:nth-child(10) { opacity:1; transform:translateY(0); transition-delay:.77s; }
  .reveal-children.visible > *:nth-child(11) { opacity:1; transform:translateY(0); transition-delay:.85s; }
  .reveal-children.visible > *:nth-child(12) { opacity:1; transform:translateY(0); transition-delay:.93s; }

  .art, .ev-card, .tl-card {
    transition:transform .4s cubic-bezier(.2,.8,.3,1), box-shadow .4s ease;
  }
  .art:hover     { transform:translateY(-7px) rotate(0deg) scale(1.018); box-shadow:var(--sh-photo); z-index:3; }
  .ev-card:hover { transform:translateY(-5px) !important; box-shadow:var(--sh-photo); animation-play-state:paused !important; }
  .g-past .ev-card:hover { opacity:1; }
  .tl-card:hover { transform:translateY(-6px) rotate(0deg) !important; animation-play-state:paused !important; box-shadow:0 14px 30px rgba(214,71,140,.16); }

  .polaroid-wrap:hover { transform:rotate(-3deg) translateY(-6px) scale(1.015) !important; animation-play-state:paused !important; }

  .btn { transition:transform .18s cubic-bezier(.2,.8,.3,1), box-shadow .25s ease; }
  .btn:hover { box-shadow:0 10px 22px rgba(75,58,65,.22); }

  .wordmark-logo { display:inline-flex; align-items:center; gap:10px; transition:transform .3s cubic-bezier(.2,.8,.3,1); }
  .wordmark-logo:hover { transform:scale(1.04) rotate(-1.5deg); }
  .logo-img { height:52px; width:auto; display:block; }
  .wordmark-logo .wordmark { font-family:var(--serif); font-style:italic; font-weight:600; font-size:28px; color:var(--magenta); }
  .wordmark { transition:transform .3s cubic-bezier(.2,.8,.3,1), color .25s ease; display:inline-block; }
  .wordmark:hover { transform:scale(1.04) rotate(-1.5deg); color:var(--hotpink); }

  .nav a { position:relative; transition:color .2s ease; }
  .nav a:not([aria-label]):not(.active):hover { color:var(--ink); }
  .nav a::after {
    content:""; position:absolute; left:0; right:100%; bottom:-5px; height:1.5px;
    background:var(--hotpink); transition:right .28s cubic-bezier(.2,.8,.3,1);
  }
  .nav a:hover::after { right:0; }

  .chip svg { transition:transform .25s ease; }
  .chip:hover svg { transform:scale(1.12); }

  .sec-note { transition:color .2s ease; }

  @media (max-width:880px) {
    .wrap { padding-left:40px; padding-right:40px; }
    .hero { grid-template-columns:1fr; gap:36px; }
    .hero-right { order:-1; }
    h1.hero-h1 { font-size:40px; }
    h1.page-title { font-size:40px; }
    .polaroid .ph, .polaroid-img { width:min(360px,80vw); height:min(360px,80vw); }
    .polaroid-logo-img { width:min(260px,70vw); height:min(260px,70vw); }
    .polaroid-wrap { transform:rotate(-2deg); }
    .gallery { grid-template-columns:repeat(2,1fr); }
    .ev-grid { grid-template-columns:repeat(2,1fr); }
    .tl-track { grid-template-columns:1fr; }
    .tl-track::before { display:none; }
  }
  @media (max-width:560px) {
    .wrap { padding-left:22px; padding-right:22px; }
    .nav { gap:16px; }
    .gallery { grid-template-columns:1fr; }
    .nav-cards { grid-template-columns:1fr; }
    .ev-grid { grid-template-columns:1fr; }
    .ev-card { transform:none !important; }
    .art { transform:none !important; }
    .art .heart-sprite, .art .deco { display:none; }
    .sec-note { display:none; }
  }
