:root{
  --paper:#f5f0e7;
  --paper-2:#ece3d3;
  --paper-3:#e6dcc8;
  --ink:#473726;
  --ink-soft:#6f5d47;
  --brown:#7a5a36;
  --brown-deep:#5a3f1d;
  --gold:#b08a4f;
  --line:#d8cbb1;
  --card:#fcf9f2;
  --shadow:0 22px 60px -28px rgba(74,59,42,.5);
  --shadow-sm:0 10px 30px -16px rgba(74,59,42,.45);
  --serif:"Cormorant Garamond",Georgia,serif;
  --script:"Dancing Script",cursive;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--serif);color:var(--ink);
  background-color:var(--paper);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E");
  font-size:18px;line-height:1.65;
}
img{max-width:100%;display:block}

/* ---------- reveal-on-scroll ---------- */
.reveal{opacity:0;transform:translateY(46px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none}}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:14px 30px;background:rgba(245,240,231,.78);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-brand{font-family:var(--script);font-size:1.8rem;color:var(--brown-deep);text-decoration:none;font-weight:700}
.nav-links{display:flex;gap:28px}
.nav-links a{position:relative;text-decoration:none;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:600}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--gold);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--brown)}
.nav-links a:hover::after{width:100%}
.lang-toggle{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--card)}
.lang-btn{border:0;background:transparent;cursor:pointer;padding:6px 13px;font-size:.7rem;letter-spacing:.12em;font-weight:700;color:var(--ink-soft);transition:background .3s,color .3s}
.lang-btn.is-active{background:var(--brown);color:#fff}

/* ---------- shared ---------- */
.section{position:relative;max-width:1060px;margin:0 auto;padding:118px 24px;text-align:center}
/* kraft cactus divider — the scrapbook motif, in the invitation's tones */
.section::before{
  content:"";position:absolute;top:48px;left:50%;transform:translateX(-50%) rotate(-4deg);
  width:42px;height:38px;opacity:.92;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21V5M12 14H8V10M12 16H16V11' stroke='%23a4814f' stroke-width='5'/%3E%3Cpath d='M12 21V5M12 14H8V10M12 16H16V11' stroke='%23c2a06f' stroke-width='3.4'/%3E%3C/svg%3E");
  filter:drop-shadow(0 3px 4px rgba(74,59,42,.2));
}
.kicker{display:inline-block;text-transform:uppercase;letter-spacing:.34em;font-size:.72rem;font-weight:600;color:var(--gold);margin-bottom:14px}
.section-title{font-size:clamp(2.1rem,5.4vw,3.4rem);font-weight:500;color:var(--brown-deep);line-height:1.08;margin-bottom:18px}
.section-lead{max-width:660px;margin:0 auto 40px;color:var(--ink-soft);font-size:1.2rem}
.btn{display:inline-block;cursor:pointer;border:1.5px solid transparent;text-decoration:none;text-transform:uppercase;letter-spacing:.16em;font-size:.76rem;font-weight:600;padding:14px 30px;border-radius:999px;transition:transform .2s var(--ease),box-shadow .25s,background .25s,color .25s;font-family:var(--serif)}
.btn-solid{background:var(--brown);color:#fff;box-shadow:var(--shadow-sm)}
.btn-solid:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.btn-outline{background:transparent;border-color:var(--brown);color:var(--brown)}
.btn-outline:hover{background:var(--brown);color:#fff;transform:translateY(-3px)}
.btn-pinterest{display:inline-flex;align-items:center;gap:10px;background:var(--card);border-color:var(--line);color:var(--brown-deep);box-shadow:var(--shadow-sm)}
.btn-pinterest:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--brown)}
.pin-ico{width:18px;height:18px;color:#c8453f;flex:0 0 auto}
.img-missing{min-height:240px;background:repeating-linear-gradient(45deg,#e7ddca,#e7ddca 12px,#efe7d6 12px,#efe7d6 24px)}

/* ---------- HERO ---------- */
.hero{position:relative;text-align:center;padding:64px 24px 110px;background:linear-gradient(180deg,var(--paper-2),var(--paper));border-bottom:1px solid var(--line);overflow:hidden}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(180deg,transparent,var(--paper))}
.hero-inner{position:relative;max-width:780px;margin:0 auto;z-index:2}
.eyebrow{text-transform:uppercase;letter-spacing:.36em;font-size:.8rem;color:var(--ink-soft);font-weight:600}
.script-title{font-family:var(--script);font-weight:700;color:var(--brown-deep);font-size:clamp(3.6rem,12vw,7.2rem);line-height:1;margin:4px 0 26px;animation:floatIn 1.1s var(--ease) both}
/* two-photo childhood collage */
.hero-collage{position:relative;display:flex;justify-content:center;align-items:center;margin:26px auto 46px;max-width:620px;animation:photoIn 1.2s var(--ease) .15s both}
.collage-photo{position:relative;width:46%;border:11px solid #fff;border-radius:3px;box-shadow:var(--shadow);background:#fff;overflow:hidden;transition:transform .5s var(--ease)}
.collage-photo img{width:100%;height:330px;object-fit:cover;display:block;border-radius:1px}
.collage-left{transform:rotate(-3deg);z-index:1}
.collage-right{transform:rotate(3deg);margin-left:-6px;z-index:1}
.collage-photo:hover{transform:rotate(0deg) scale(1.02);z-index:4}
/* kraft tape at each photo's top outer corner */
.collage-photo::before{
  content:"";position:absolute;top:-16px;width:88px;height:30px;z-index:5;
  background:linear-gradient(180deg,rgba(202,170,120,.78),rgba(184,150,98,.7));
  box-shadow:0 3px 8px rgba(74,59,42,.18);
  mask:linear-gradient(90deg,transparent 0,#000 6px,#000 calc(100% - 6px),transparent 100%);
}
.collage-left::before{left:8%;transform:rotate(-8deg)}
.collage-right::before{right:8%;transform:rotate(7deg)}
/* kraft cardboard heart joining them */
.collage-heart{
  position:absolute;left:50%;top:54%;transform:translate(-50%,-50%) rotate(-5deg);
  width:92px;height:84px;z-index:6;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42 38'%3E%3Cpath d='M21 36C2 22 0 13 5 7c5-6 13-3 16 3 3-6 11-9 16-3 5 6 3 15-16 29z' fill='%23c2a06f' stroke='%23a4814f' stroke-width='1.1'/%3E%3C/svg%3E");
  filter:drop-shadow(0 4px 6px rgba(74,59,42,.28));
}
@media(max-width:540px){.collage-photo img{height:240px}.collage-heart{width:64px;height:58px}}
.hero-welcome{font-size:1.4rem;color:var(--ink);font-style:italic;margin-bottom:24px;animation:fadeUp 1s var(--ease) .35s both}
.hero-date{display:inline-flex;flex-wrap:wrap;justify-content:center;gap:12px;align-items:center;text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;font-weight:600;color:var(--brown);margin-bottom:34px;animation:fadeUp 1s var(--ease) .5s both}
.hero-date .dot{color:var(--gold)}
.hero .btn-solid{animation:fadeUp 1s var(--ease) .65s both}
@keyframes floatIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes photoIn{from{opacity:0;transform:rotate(-1.4deg) translateY(40px) scale(.96)}to{opacity:1;transform:rotate(-1.4deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ---------- ABOUT ---------- */
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:26px}
.about-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:6px;padding:42px 22px 34px;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s}
.about-card:nth-child(odd){transform:rotate(-1.2deg)}
.about-card:nth-child(even){transform:rotate(1deg)}
.about-card:hover{transform:translateY(-8px) rotate(0deg);box-shadow:var(--shadow)}
/* washi tape strip at the top of each card */
.about-card::before,.place-card::before{
  content:"";position:absolute;top:-12px;left:50%;width:96px;height:26px;
  transform:translateX(-50%) rotate(-2.5deg);z-index:4;
  background:linear-gradient(180deg,rgba(202,170,120,.7),rgba(184,150,98,.62));
  box-shadow:0 2px 6px rgba(74,59,42,.14);
  mask:linear-gradient(90deg,transparent 0,#000 5px,#000 calc(100% - 5px),transparent 100%);
}
.about-label{text-transform:uppercase;letter-spacing:.24em;font-size:.7rem;color:var(--gold);font-weight:600}
.about-big{font-size:4.6rem;font-weight:600;color:var(--brown-deep);line-height:1;margin:8px 0}
.about-mid{font-family:var(--script);font-size:2.1rem;color:var(--brown-deep);margin:14px 0 8px}
.about-sub{color:var(--ink-soft);font-size:1.04rem}
.about-note{margin-top:44px;font-style:italic;color:var(--ink-soft)}

/* ---------- ATTIRE ---------- */
.attire{background:linear-gradient(180deg,transparent,var(--paper-2) 50%,transparent)}
.attire-toggle{display:inline-flex;gap:6px;margin-bottom:40px;background:var(--card);border:1px solid var(--line);padding:6px;border-radius:999px;box-shadow:var(--shadow-sm)}
.pill{border:0;background:transparent;cursor:pointer;padding:10px 22px;border-radius:999px;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:600;color:var(--ink-soft);font-family:var(--serif);transition:all .3s var(--ease)}
.pill.is-active{background:var(--brown);color:#fff;box-shadow:var(--shadow-sm)}
.carousel{position:relative;display:flex;align-items:center;justify-content:center;gap:8px}
.car-track{display:flex;align-items:center;justify-content:center;gap:18px;perspective:1300px;min-height:460px;width:100%}
.car-slide{flex:0 0 auto;width:220px;height:310px;border-radius:10px;overflow:hidden;border:9px solid #fff;box-shadow:var(--shadow);transition:transform .5s var(--ease),opacity .5s var(--ease),filter .5s var(--ease);opacity:.5;filter:saturate(.85) brightness(.95);cursor:pointer}
.car-slide img{width:100%;height:100%;object-fit:cover}
.car-slide.is-center{transform:scale(1.36);opacity:1;filter:none;z-index:3}
.car-slide.is-near{transform:scale(1.02);opacity:.78;z-index:2}
.car-arrow{flex:0 0 auto;width:48px;height:48px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--brown);font-size:1.6rem;line-height:1;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),background .25s,color .25s;z-index:4}
.car-arrow:hover{transform:scale(1.12);background:var(--brown);color:#fff}
.attire-hint,.map-hint{font-size:.82rem;color:var(--ink-soft);opacity:.7;margin-top:20px;font-style:italic}

/* ---------- STAY ---------- */
.showcase{display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:center;text-align:left;margin:14px 0 46px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow-sm)}
.showcase-media{position:relative;border:10px solid #fff;border-radius:3px;box-shadow:var(--shadow);min-height:300px;transform:rotate(-1.2deg)}
.showcase-media img{width:100%;height:100%;object-fit:cover;display:block}
.showcase-media::before{
  content:"";position:absolute;top:-16px;left:50%;width:120px;height:30px;
  transform:translateX(-50%) rotate(-3deg);z-index:5;
  background:linear-gradient(180deg,rgba(202,170,120,.76),rgba(184,150,98,.68));
  box-shadow:0 3px 8px rgba(74,59,42,.16);
  mask:linear-gradient(90deg,transparent 0,#000 6px,#000 calc(100% - 6px),transparent 100%);
}
.showcase-media .map-hint{position:absolute;inset:auto 0 12px;text-align:center;margin:0}
.showcase-body{padding:14px 22px}
.showcase-h{font-family:var(--script);font-size:2.2rem;color:var(--brown-deep);margin-bottom:12px;font-weight:600;line-height:1.1}
.showcase-body p{color:var(--ink-soft);margin-bottom:24px}
.cta-row{display:flex;flex-wrap:wrap;gap:14px}
.places-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;text-align:left}
.place-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:6px;padding:34px 30px 28px;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s}
.place-card:nth-child(odd){transform:rotate(-.9deg)}
.place-card:nth-child(even){transform:rotate(.9deg)}
.place-card:hover{transform:translateY(-6px) rotate(0deg);box-shadow:var(--shadow)}
.place-card h3{font-family:var(--script);font-size:2rem;color:var(--brown-deep);margin-bottom:8px;font-weight:600}
.place-card p{color:var(--ink-soft);font-size:1.05rem}

/* ---------- GIFTS ---------- */
.gift{max-width:780px}
.gift-text{font-size:1.35rem;font-style:italic;color:var(--ink);line-height:1.75}

/* ---------- RSVP ---------- */
.rsvp{background:linear-gradient(180deg,transparent,var(--paper-2))}
.rsvp-form{max-width:640px;margin:0 auto;text-align:left;display:grid;grid-template-columns:1fr 1fr;gap:18px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:38px;box-shadow:var(--shadow)}
.field{display:flex;flex-direction:column;gap:6px}
.field-full{grid-column:1 / -1}
.rsvp-form .btn-solid{grid-column:1 / -1;justify-self:center;margin-top:6px}
.field label{text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;font-weight:600;color:var(--ink-soft)}
.field input,.field select,.field textarea{font-family:var(--serif);font-size:1.05rem;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:12px 14px;transition:border-color .25s,box-shadow .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,138,79,.18)}
.hidden-field{display:none}
.form-status{grid-column:1 / -1;text-align:center;font-style:italic;min-height:1.2em;transition:opacity .3s}
.form-status.ok{color:#3f7d4f}
.form-status.err{color:#a8492f}

/* ---------- FOOTER ---------- */
.footer{text-align:center;padding:64px 24px;border-top:1px solid var(--line);color:var(--ink-soft)}
.script-foot{font-family:var(--script);font-size:2.6rem;color:var(--brown-deep);margin-bottom:6px}

/* ---------- scroll-to-top ---------- */
.to-top{position:fixed;right:22px;bottom:22px;width:50px;height:50px;border-radius:50%;border:1px solid var(--line);background:var(--brown);color:#fff;font-size:1.3rem;cursor:pointer;box-shadow:var(--shadow);opacity:0;transform:translateY(20px) scale(.8);pointer-events:none;transition:opacity .4s var(--ease),transform .4s var(--ease);z-index:60}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{transform:translateY(-3px)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:820px){
  .nav-links{display:none}
  .about-grid,.places-grid,.rsvp-form,.showcase{grid-template-columns:1fr}
  .showcase-media{min-height:220px}
  .car-slide{width:150px;height:220px}
  .car-slide.is-center{transform:scale(1.22)}
}
