*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#1C1A17;--paper:#FAF8F4;--cream:#F2EDE4;
  --pine:#1A1C22;--pine-light:#343942;--pine-mist:#e8eef3;
  --rust:#6e1b1b;--rust-light:#8B2323;--rust-mist:#FAF0EB;
  --gold:#A07820;--gold-light:#D4A830;--gold-mist:#FDF6E3;
  --slate:#4A5568;--border:rgba(28,26,23,0.12);
  --radius:12px;
}

html{background:var(--pine);scroll-behavior:smooth;}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--paper);color:var(--ink);min-height:100vh}

/* NAV — matches site header: deep teal → charcoal → black */
.nav{
  background:linear-gradient(90deg,#051a24 0%,var(--pine) 42%,#0a0c0f 100%);
  padding:0 clamp(1rem,3vw,2rem);display:flex;align-items:center;justify-content:space-between;
  min-height:64px;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.nav-logo{
  font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.05rem,2.4vw,1.3rem);color:#fff;text-decoration:none;
  font-style:italic;font-weight:400;letter-spacing:-0.02em;
}
.nav-right{display:flex;align-items:center;gap:1rem 1.25rem;flex-wrap:wrap;justify-content:flex-end;}
.nav-links{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1.25rem;justify-content:flex-end;}
.nav-links a{color:rgba(255,255,255,0.78);text-decoration:none;font-size:14px;font-weight:500;transition:color .15s;}
.nav-links a:hover{color:#fff;}
.nav-book{
  background:var(--rust-light);color:#fff !important;padding:8px 18px;border-radius:999px;font-weight:700;font-size:14px;
  transition:background .15s,filter .15s;
}
.nav-book:hover{background:var(--rust);filter:brightness(1.05);}

/* HAMBURGER */
.nav-hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  background:none;border:none;cursor:pointer;padding:6px;
  width:36px;height:36px;
}
.nav-hamburger span{
  display:block;width:22px;height:2px;background:#fff;border-radius:2px;
  transition:transform .25s,opacity .25s;
}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.nav-mobile-drawer{
  display:none;flex-direction:column;
  background:linear-gradient(180deg,#051a24 0%,var(--pine) 100%);
  padding:1rem 1.5rem 1.5rem;gap:.75rem;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.nav-mobile-drawer a{
  color:rgba(255,255,255,0.85);text-decoration:none;font-size:15px;font-weight:500;
  padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,0.07);
}
.nav-mobile-drawer a:last-child{border-bottom:none;}
.nav-mobile-drawer a:hover{color:#fff;}
.nav-book--drawer{
  margin-top:.5rem;text-align:center;
  background:var(--rust-light) !important;
  padding:10px 18px !important;border-radius:999px !important;
  font-weight:700 !important;font-size:14px !important;
  border-bottom:none !important;color:#fff !important;
}

/* HEADER */
.header{
  background:linear-gradient(165deg,#051a24 0%,var(--pine) 38%,#12151c 100%);
  padding:4rem 2rem 3rem;
  position:relative;overflow:hidden;
  text-align:center;
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.header::before{content:'';position:absolute;top:-80px;right:-80px;width:350px;height:350px;border-radius:50%;background:rgba(255,255,255,0.04);}
.header::after{content:'';position:absolute;bottom:-50px;left:10%;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,0.03);}
.header-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:.75rem;}
.header h1{font-family:'Playfair Display',Georgia,serif;font-size:clamp(2rem,5vw,3rem);font-weight:400;color:#fff;line-height:1.15;margin-bottom:.75rem;}
.header h1 em{font-style:italic;color:#e8b4b4;}
.header p{font-size:16px;color:rgba(255,255,255,0.65);max-width:500px;margin:0 auto;}

/* FORM */
.form-section{background:var(--cream);border-bottom:1px solid var(--border);padding:2rem;}
.form-inner{max-width:860px;margin:0 auto;width:100%;}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:1.25rem;}
.form-grid .field{min-width:0;}
.field input[type="date"]{min-width:0;width:100%;}
.field label{display:block;font-size:11px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--slate);margin-bottom:5px;}
.field input,.field select{
  width:100%;padding:10px 14px;
  border:1px solid var(--border);border-radius:8px;
  font-family:inherit;font-size:14px;
  background:#fff;color:var(--ink);outline:none;
  transition:border-color .15s;
}
.field input:focus,.field select:focus{border-color:rgba(139,35,35,0.55);box-shadow:0 0 0 3px rgba(139,35,35,0.08);}

.vibe-section{margin-bottom:1.25rem;}
.vibe-section-label{font-size:11px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--slate);margin-bottom:.6rem;display:block;}
.vibe-row{display:flex;gap:8px;flex-wrap:wrap;}
.vibe-chip{padding:6px 16px;border-radius:20px;border:1px solid var(--border);background:#fff;font-size:13px;font-family:inherit;cursor:pointer;color:var(--slate);transition:all .15s;}
.vibe-chip:hover{border-color:rgba(139,35,35,0.45);color:var(--pine);}
.vibe-chip.on{background:var(--pine);border-color:var(--pine);color:#fff;}

.generate-btn{
  width:100%;padding:16px;
  background:var(--rust-light);border:none;border-radius:var(--radius);
  font-family:'Playfair Display',Georgia,serif;font-size:18px;font-style:italic;
  color:#fff;cursor:pointer;transition:background .2s,transform .1s;
  letter-spacing:.02em;
}
.generate-btn:hover{background:var(--rust);transform:translateY(-1px);filter:brightness(1.03);}
.generate-btn:disabled{background:#bbb;transform:none;cursor:not-allowed;}

/* FORD AMPHITHEATER — live feed */
/* Optional CMS intro above event feeds */
.events-page-intro{
  background:var(--cream);
  border-bottom:1px solid var(--border);
  padding:1.25rem 1.5rem;
}
.events-page-intro__inner{
  max-width:860px;margin:0 auto;
  font-size:15px;line-height:1.65;color:var(--slate);
}
.events-page-intro__inner p{margin:0 0 .75rem;}
.events-page-intro__inner p:last-child{margin-bottom:0;}

.ford-section{
  background:#fff;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:1.25rem 1.5rem;
}
.ford-inner{max-width:860px;margin:0 auto;}
.ford-heading{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(1.1rem,2.5vw,1.35rem);
  font-weight:400;
  color:var(--pine);
  margin-bottom:.2rem;
}
.ford-lead{font-size:12px;color:var(--slate);margin-bottom:.75rem;line-height:1.4;}
.ford-lead a{color:var(--rust-light);text-decoration:none;font-weight:500;}
.ford-lead a:hover{text-decoration:underline;}

.ford-list{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:6px;}
.ford-item{
  display:flex;gap:10px;align-items:center;
  padding:7px 10px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--cream);
}
.ford-thumb{width:64px;height:auto;border-radius:4px;flex-shrink:0;object-fit:cover;}
.ford-meta{min-width:0;flex:1;}
.ford-title{
  font-size:13px;font-weight:600;color:var(--pine);
  text-decoration:none;display:block;line-height:1.3;
}
.ford-title:hover{color:var(--rust-light);}
.ford-when{font-size:11px;color:var(--slate);margin-top:2px;}
.ford-empty{font-size:13px;color:var(--slate);line-height:1.6;max-width:42rem;}
.ford-empty a{color:var(--rust-light);font-weight:500;}

.peak-radar-section{border-top:none;}
.pr-month{margin-bottom:.5rem;}
.pr-month-summary{
  display:flex;align-items:center;gap:.5rem;
  font-family:'Playfair Display',Georgia,serif;font-size:1rem;font-weight:400;
  color:var(--pine);cursor:pointer;
  padding:.45rem .5rem;border-radius:6px;
  list-style:none;user-select:none;
}
.pr-month-summary::-webkit-details-marker{display:none;}
.pr-month-summary::before{
  content:'▶';font-size:.6rem;color:var(--slate);
  transition:transform .2s;display:inline-block;
}
.pr-month[open] .pr-month-summary::before{transform:rotate(90deg);}
.pr-month-summary:hover{background:var(--cream);}
.pr-month-count{font-family:'DM Sans',system-ui,sans-serif;font-size:11px;color:var(--slate);font-weight:400;}
.pr-month-list{margin:.35rem 0 .5rem;}
.ford-item--text-only{background:var(--cream);}
.ford-title--plain{color:var(--pine);cursor:default;}
.ford-loc{font-size:11px;color:var(--slate);margin-top:2px;line-height:1.3;}

/* OUTPUT */
.output-section{padding:2.5rem 2rem;min-height:300px;}
.output-inner{max-width:860px;margin:0 auto;}

.thinking{display:flex;align-items:center;gap:14px;padding:2rem;color:var(--slate);font-size:15px;}
.dots span{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--rust-light);margin:0 2px;animation:bounce .9s ease-in-out infinite;}
.dots span:nth-child(2){animation-delay:.15s;}
.dots span:nth-child(3){animation-delay:.3s;}
@keyframes bounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-8px)}}

.itinerary-header{margin-bottom:2rem;border-bottom:1px solid var(--border);padding-bottom:1.5rem;}
.itinerary-header h2{font-family:'Playfair Display',Georgia,serif;font-size:2rem;font-weight:400;color:#1A1C22;margin-bottom:.5rem;}
.itinerary-meta{font-size:14px;color:var(--slate);}

.day-block{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem;animation:fadeUp .4s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

.day-header{display:flex;align-items:center;gap:16px;padding:1.25rem 1.5rem;background:var(--pine);color:#fff;}
.day-num{font-family:'Playfair Display',Georgia,serif;font-size:2.5rem;font-weight:400;font-style:italic;color:rgba(255,255,255,0.35);line-height:1;min-width:40px;}
.day-title{font-size:16px;font-weight:500;}
.day-subtitle{font-size:13px;color:rgba(255,255,255,0.6);margin-top:3px;}

.time-blocks{padding:0 1.5rem;}
.time-block{display:flex;gap:16px;padding:1.1rem 0;border-bottom:1px solid var(--border);}
.time-block:last-child{border-bottom:none;}
.time-tag{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);min-width:70px;padding-top:3px;flex-shrink:0;}
.time-content h4{font-size:15px;font-weight:500;color:var(--ink);margin-bottom:4px;}
.time-content p{font-size:14px;color:var(--slate);line-height:1.6;}
.time-content .tip{font-size:12px;margin-top:6px;background:var(--gold-mist);color:var(--gold);display:inline-block;padding:3px 10px;border-radius:12px;}

.day-note{padding:1rem 1.5rem;background:var(--pine-mist);font-size:13px;color:#1A1C22;border-top:1px solid rgba(26,28,34,0.12);}

.action-row{display:flex;gap:12px;margin-top:2rem;flex-wrap:wrap;}
.action-btn{padding:12px 24px;border-radius:8px;font-family:inherit;font-size:14px;cursor:pointer;transition:all .15s;border:1px solid var(--border);text-decoration:none;display:inline-block;}
.btn-book{background:var(--rust-light);color:#fff;border-color:var(--rust-light);}
.btn-book:hover{background:var(--rust);border-color:var(--rust);}
.btn-print{background:#fff;color:var(--ink);}
.btn-print:hover{background:var(--cream);}
.btn-planner{background:var(--rust-light);color:#fff;border-color:var(--rust-light);}
.btn-planner:hover{background:var(--rust);}

.error-msg{padding:1.5rem;border-radius:var(--radius);background:#fdf2f2;color:#6e1b1b;font-size:14px;border:1px solid rgba(139,35,35,0.25);}

.placeholder{text-align:center;padding:4rem 1rem;color:var(--slate);}
.placeholder-icon{font-size:56px;margin-bottom:1.5rem;opacity:0.35;}
.placeholder h3{font-family:'Playfair Display',Georgia,serif;font-size:1.5rem;font-weight:400;color:var(--ink);margin-bottom:.75rem;}
.placeholder p{font-size:14px;max-width:360px;margin:0 auto;line-height:1.7;}

/* FOOTER */
/* Site footer: partials/site_footer.html + site-footer.css */
.site-footer{margin-top:2rem;}

@media(max-width:640px){
  .nav-links{display:none;}
  .nav-hamburger{display:flex;}
  .nav-mobile-drawer.open{display:flex;}
  .header{padding:3rem 1.5rem 2.5rem;}
  .form-section{padding:1.25rem 1rem;}
  .form-grid{grid-template-columns:1fr 1fr;gap:8px;}
  .field input,.field select{padding:8px 8px;font-size:16px;height:42px;box-sizing:border-box;}
  .field input[type="date"]{line-height:1;}
  .ford-section{padding:1rem 1rem;}
  .ford-list{grid-template-columns:1fr;}
  .ford-item{flex-direction:row;}
  .ford-thumb{width:56px;}
  .time-block{flex-direction:column;gap:4px;}
  .time-tag{min-width:auto;}
}

/* phones — single column so iOS date inputs never overflow */
@media(max-width:480px){
  .form-section{padding:1.25rem 1.25rem;}
  .form-grid{grid-template-columns:1fr;gap:8px;}
  .field input,.field select{height:44px;}
}

@media print{
  .nav,.form-section,.site-footer,.action-row{display:none;}
  .header{padding:1rem;}
  body{background:#fff;}
}
