/* ===== Itinera — boutique itinerary planner ===== */
:root{
  --cream:#f4f0e6;
  --cream-2:#ece6d7;
  --paper:#faf8f1;
  --ink:#2c3326;
  --ink-soft:#55604c;
  --sage:#7a8c6f;
  --sage-deep:#566049;
  --amber:#c2702a;
  --amber-deep:#a85d1e;
  --hair:#cdcab8;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:"Asap",system-ui,sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Petrona",Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:-.01em;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--amber-deep);font-weight:600}
.hair{height:1px;background:var(--hair);border:0;width:100%}

/* ---- Header ---- */
.site-head{
  position:sticky;top:0;z-index:50;
  background:rgba(244,240,230,.86);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--hair);
}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 28px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:11px;font-family:"Petrona",serif;font-size:1.42rem;font-weight:600;letter-spacing:.01em}
.brand svg{width:30px;height:30px}
.brand span b{color:var(--amber-deep);font-weight:600}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-size:.92rem;color:var(--ink-soft);transition:color .2s}
.nav a:hover{color:var(--amber-deep)}
.lang{display:flex;align-items:center;gap:6px;border-left:1px solid var(--hair);padding-left:18px}
.lang button{
  font-family:inherit;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  background:none;border:0;color:var(--ink-soft);cursor:pointer;padding:4px 5px;border-radius:4px;transition:.18s;
}
.lang button:hover{color:var(--ink)}
.lang button.active{color:var(--amber-deep);font-weight:700}
.menu-btn{display:none}

/* ---- Hero ---- */
.hero{padding:84px 0 60px}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:end}
.hero-kicker{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.hero-kicker .rule{height:1px;width:64px;background:var(--amber)}
.hero h1{font-size:clamp(2.7rem,6vw,4.7rem);font-weight:700}
.hero h1 em{font-style:italic;color:var(--sage-deep)}
.hero p.lede{margin-top:26px;font-size:1.16rem;color:var(--ink-soft);max-width:34ch}
.hero-actions{margin-top:34px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.btn{
  display:inline-block;background:var(--amber);color:var(--paper);
  padding:14px 30px;border-radius:2px;font-weight:600;font-size:.95rem;letter-spacing:.02em;
  transition:.2s;border:1px solid var(--amber);
}
.btn:hover{background:var(--amber-deep);border-color:var(--amber-deep)}
.btn-ghost{display:inline-flex;align-items:center;gap:9px;font-weight:600;color:var(--sage-deep);font-size:.95rem}
.btn-ghost:hover{color:var(--amber-deep)}
.btn-ghost::after{content:"";width:26px;height:1px;background:currentColor;transition:width .2s}
.btn-ghost:hover::after{width:40px}
.hero-fig{position:relative}
.hero-fig img{width:100%;height:520px;object-fit:cover;border-radius:3px}
.hero-fig figcaption{
  position:absolute;left:-26px;bottom:30px;background:var(--paper);
  border:1px solid var(--hair);padding:14px 20px;max-width:230px;
  font-size:.82rem;color:var(--ink-soft);line-height:1.45;
}
.hero-fig figcaption b{display:block;font-family:"Petrona",serif;color:var(--ink);font-size:1.05rem;margin-bottom:3px}

/* ---- Section scaffolding ---- */
section{padding:74px 0}
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.85rem);margin-top:14px}
.sec-head p{margin-top:16px;color:var(--ink-soft);font-size:1.05rem}

/* ---- Day-by-day timeline ---- */
.itinerary{background:var(--paper);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.timeline{margin-top:48px;position:relative;border-left:1px solid var(--hair);margin-left:6px}
.day{position:relative;padding:0 0 46px 56px}
.day:last-child{padding-bottom:0}
.day::before{
  content:"";position:absolute;left:-5px;top:6px;width:9px;height:9px;border-radius:50%;
  background:var(--cream);border:2px solid var(--amber);
}
.day-num{
  position:absolute;left:-86px;top:-4px;width:64px;text-align:right;
  font-family:"Petrona",serif;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-deep);
}
.day-grid{display:grid;grid-template-columns:auto 1fr;gap:10px 26px;align-items:baseline}
.day h3{font-size:1.4rem}
.day .place{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-deep);font-weight:600;white-space:nowrap}
.day p{grid-column:1/-1;color:var(--ink-soft);max-width:64ch;margin-top:4px}
@media(min-width:760px){
  .timeline{margin-left:96px}
}

/* ---- Destination strip ---- */
.dest-strip{display:flex;gap:22px;overflow-x:auto;margin-top:44px;padding-bottom:14px;scroll-snap-type:x mandatory}
.dest{flex:0 0 270px;scroll-snap-align:start}
.dest img{width:100%;height:330px;object-fit:cover;border-radius:3px}
.dest .meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:13px;border-top:1px solid var(--hair);padding-top:11px}
.dest h3{font-size:1.22rem}
.dest .meta span{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage-deep)}
.dest p{font-size:.9rem;color:var(--ink-soft);margin-top:6px}
.dest-strip::-webkit-scrollbar{height:6px}
.dest-strip::-webkit-scrollbar-thumb{background:var(--hair);border-radius:3px}

/* ---- How we plan (numbered) ---- */
.plan{background:var(--cream-2)}
.plan-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:start}
.steps{margin-top:8px}
.step{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:26px 0;border-bottom:1px solid var(--hair)}
.step:first-child{border-top:1px solid var(--hair)}
.step .n{font-family:"Petrona",serif;font-size:1.55rem;color:var(--amber-deep);line-height:1}
.step h3{font-size:1.22rem;margin-bottom:6px}
.step p{color:var(--ink-soft);font-size:.97rem}
.plan-aside img{width:100%;height:430px;object-fit:cover;border-radius:3px}
.plan-aside .note{margin-top:18px;font-size:.9rem;color:var(--ink-soft);border-left:2px solid var(--amber);padding-left:16px}

/* ---- Promise / values inline ---- */
.promise{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:48px}
.promise .item{padding-top:18px;border-top:2px solid var(--sage)}
.promise h3{font-size:1.12rem;margin-bottom:8px}
.promise p{font-size:.95rem;color:var(--ink-soft)}

/* ---- Voices ---- */
.voices{background:var(--paper);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.voice{max-width:58ch;margin:0 auto;text-align:center}
.voice blockquote{font-family:"Petrona",serif;font-style:italic;font-size:clamp(1.5rem,3vw,2rem);line-height:1.4;color:var(--ink)}
.voice .who{margin-top:24px;font-size:.84rem;letter-spacing:.12em;text-transform:uppercase;color:var(--amber-deep)}

/* ---- Closing CTA ---- */
.cta{text-align:left}
.cta .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center}
.cta h2{font-size:clamp(2rem,4vw,3rem)}
.cta p{margin-top:18px;color:var(--ink-soft);font-size:1.08rem;max-width:44ch}
.cta-form{display:flex;flex-direction:column;gap:14px;background:var(--paper);border:1px solid var(--hair);padding:30px}
.cta-form label{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage-deep)}
.cta-form input,.cta-form select{
  font-family:inherit;font-size:1rem;padding:12px 14px;border:1px solid var(--hair);
  background:var(--cream);color:var(--ink);border-radius:2px;
}
.cta-form input:focus,.cta-form select:focus{outline:2px solid var(--amber);outline-offset:0}
.cta-form .btn{text-align:center;cursor:pointer;margin-top:6px}
.form-note{font-size:.78rem;color:var(--ink-soft);line-height:1.5}

/* ---- Footer ---- */
.site-foot{background:var(--sage-deep);color:#e7eadf;padding:60px 0 40px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.foot-brand{display:flex;align-items:center;gap:11px;font-family:"Petrona",serif;font-size:1.3rem;color:#fff}
.foot-brand svg{width:28px;height:28px}
.foot-links{display:flex;gap:26px;flex-wrap:wrap}
.foot-links a{font-size:.9rem;color:#dfe4d4;border-bottom:1px solid transparent;transition:.2s}
.foot-links a:hover{border-color:var(--amber)}
.site-foot .hair{background:rgba(255,255,255,.16);margin:34px 0 26px}
.legal{font-size:.86rem;line-height:1.85;color:#cdd4c0}
.legal strong{color:#fff;font-weight:600}
.legal .copy{margin-top:14px;display:block;color:#aeb89f}

/* ---- Legal pages ---- */
.legal-page{max-width:760px;margin:0 auto;padding:70px 28px 90px}
.legal-page .back{font-size:.86rem;color:var(--amber-deep);font-weight:600;display:inline-block;margin-bottom:30px}
.legal-page h1{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:8px}
.legal-page .updated{color:var(--ink-soft);font-size:.9rem;margin-bottom:36px}
.legal-page h2{font-size:1.3rem;margin:36px 0 12px}
.legal-page p,.legal-page li{color:var(--ink-soft);margin-bottom:12px}
.legal-page ul{padding-left:22px}
.legal-page a{color:var(--amber-deep);border-bottom:1px solid var(--hair)}

/* ---- Responsive ---- */
@media(max-width:900px){
  .hero .wrap,.plan-grid,.cta .wrap{grid-template-columns:1fr;gap:40px}
  .hero-fig img{height:380px}
  .hero-fig figcaption{left:14px}
  .promise{grid-template-columns:1fr;gap:26px}
}
@media(max-width:680px){
  body{font-size:16px}
  .nav a{display:none}
  .menu-btn{display:inline-flex;background:none;border:0;cursor:pointer}
  .day-num{position:static;text-align:left;width:auto;display:block;margin-bottom:6px}
  .timeline{margin-left:6px}
  .day{padding-left:34px}
  .day-grid{grid-template-columns:1fr}
  .day .place{margin-top:2px}
}
