/* ============================================================
   SHACK STATION — RESERVATION PAGE STYLESHEET
   Heritage forest + gold palette; matches index.php design.
   ============================================================ */

:root{
  --forest-deep:#1f3327;
  --forest:#2d4a35;
  --forest-light:#4a6b50;
  --cream:#faf6ee;
  --cream-dark:#efe7d4;
  --paper-soft:#f4eede;
  --white:#fdfbf6;
  --charcoal:#1a1a18;
  --charcoal-light:#262622;
  --gold:#c4a064;
  --gold-light:#d9bd86;
  --gold-pale:#ecdab2;
  --gold-dark:#9c7e48;
  --text:#2a2a28;
  --text-light:#6b6b65;
  --line:rgba(196,160,100,.32);
  --line-light:rgba(196,160,100,.18);
  --line-soft:rgba(26,26,24,.08);
  --danger:#c0392b;
  --danger-deep:#922b1b;
  --success:#3a8a4f;
  --success-deep:#1f5f2e;
  --shadow-sm:0 2px 8px rgba(13,13,11,.04);
  --shadow-md:0 12px 32px rgba(13,13,11,.08);
  --shadow-lg:0 28px 80px rgba(13,13,11,.14);
  --shadow-gold:0 20px 50px rgba(196,160,100,.32);
  --ease:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:'Montserrat',sans-serif;
  background:var(--cream);
  color:var(--text);
  line-height:1.65;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none;transition:color .35s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;color:inherit}
::selection{background:var(--gold);color:#fff}

/* LANG VISIBILITY */
.lang-en [data-lang="fr"]{display:none}
.lang-fr [data-lang="en"]{display:none}

/* UTILITY ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
.fade-in{animation:fadeUp .55s var(--ease) forwards}
.spinner{display:inline-block;animation:spin .8s linear infinite}
.icon-spin{animation:spin 1s linear infinite}
.icon-sm{width:14px;height:14px;flex-shrink:0}
.icon-tiny{width:12px;height:12px;flex-shrink:0}

/* ============================================================
   NAV
   ============================================================ */
nav{
  position:sticky;top:0;left:0;right:0;z-index:100;
  padding:18px 56px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(250,246,238,.94);
  backdrop-filter:saturate(180%) blur(24px);
  -webkit-backdrop-filter:saturate(180%) blur(24px);
  border-bottom:1px solid rgba(196,160,100,.18);
}

/* WORDMARK */
.wordmark{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px;line-height:1;color:var(--charcoal)}
.wordmark-name{font-family:'Playfair Display',serif;font-size:28px;font-weight:500;letter-spacing:.02em;line-height:1}
.wordmark-name em{font-style:italic;color:var(--gold);font-weight:500}
.wordmark-sub{font-family:'Montserrat',sans-serif;font-size:9px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--text-light);margin-top:5px}

.nav-right{display:flex;align-items:center;gap:24px}

.nav-back{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-light);transition:color .3s var(--ease);
}
.nav-back:hover{color:var(--gold-dark)}
.nav-back svg{width:14px;height:14px}

/* LANG TOGGLE */
.lang-toggle{display:inline-flex;align-items:center;gap:14px;background:transparent;border:none;padding:0}
.lang-btn{
  font-family:'Playfair Display',serif;
  font-size:17px;font-weight:600;letter-spacing:.04em;font-style:italic;
  color:var(--text-light);background:transparent;border:none;
  padding:6px 0;cursor:pointer;transition:color .35s var(--ease);
  position:relative;
}
.lang-btn:hover{color:var(--charcoal)}
.lang-btn.active{color:var(--gold)}
.lang-btn.active::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--gold);border-radius:1px;
}
.lang-toggle::before{content:'/';color:var(--text-light);font-family:'Playfair Display',serif;font-style:italic;order:1;align-self:center}
.lang-toggle .lang-btn:first-of-type{order:0}
.lang-toggle .lang-btn:last-of-type{order:2}

/* ============================================================
   CITQ TRUST STRIP
   ============================================================ */
.citq-bar{
  background:var(--forest-deep);
  padding:32px 56px;
  border-bottom:1px solid rgba(196,160,100,.18);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  gap:28px;flex-wrap:wrap;
  color:#fff;
}
.citq-bar::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(196,160,100,.10) 0%,transparent 70%);
  pointer-events:none;
}
.citq-shield{
  width:48px;height:48px;flex-shrink:0;
  border:1.5px solid var(--gold);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(196,160,100,.06);
  position:relative;
}
.citq-shield svg{width:24px;height:24px;color:var(--gold-light)}
.citq-text{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(250,246,238,.78);font-weight:500;
  position:relative;
}
.citq-num{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:26px;color:#fff;font-weight:600;letter-spacing:.04em;
  position:relative;
}
.citq-num::before{
  content:'';display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--gold);margin-right:14px;vertical-align:middle;
}
.citq-div{width:1px;height:28px;background:rgba(196,160,100,.32);position:relative}

/* ============================================================
   PAGE TABS
   ============================================================ */
.page-tabs{
  display:flex;justify-content:center;gap:6px;
  padding:32px 56px 0;max-width:1240px;margin:0 auto;
}
.page-tab{
  padding:14px 28px;
  font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-light);background:transparent;
  border:1px solid var(--line-light);border-radius:100px;
  transition:all .35s var(--ease);
}
.page-tab.active{
  background:var(--forest);color:#fff;
  border-color:var(--forest);
  box-shadow:var(--shadow-sm);
}
.page-tab:hover:not(.active){color:var(--charcoal);border-color:var(--gold)}

/* ============================================================
   TAB CONTENT WRAPPER
   ============================================================ */
.tab-content{display:none;max-width:1240px;margin:0 auto;padding:60px 56px 100px}
.tab-content.active{display:block}

/* ============================================================
   STEPS BAR
   ============================================================ */
.steps{display:flex;align-items:center;gap:0;margin-bottom:48px}
.steps-mb-40{margin-bottom:40px}
.step{
  display:flex;align-items:center;gap:12px;
  font-size:12px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-light);transition:color .35s var(--ease);
}
.step-num{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-style:italic;font-size:15px;font-weight:600;
  background:var(--cream-dark);color:var(--text-light);
  border:1px solid var(--line-light);
  transition:all .35s var(--ease);
}
.step.active .step-num{
  background:var(--forest);color:#fff;border-color:var(--forest);
  box-shadow:0 4px 14px rgba(45,74,53,.25);
}
.step.active{color:var(--charcoal)}
.step.done .step-num{
  background:var(--gold);color:#fff;border-color:var(--gold);
}
.step.done{color:var(--gold-dark)}
.step-line{flex:1;height:1px;background:var(--line-light);margin:0 16px}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-label{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold);margin-bottom:22px;
}
.section-label::before{
  content:'';width:28px;height:1px;background:var(--gold);
}
.section-title{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(34px,5vw,54px);
  font-weight:200;line-height:1.06;letter-spacing:-.025em;
  color:var(--charcoal);
  margin-bottom:42px;
}
.section-title em{
  font-family:'Playfair Display',serif;
  font-weight:400;font-style:italic;color:var(--gold);
  font-size:1.04em;
}
.section-title-flush{margin-bottom:0}

/* ============================================================
   FORM ELEMENTS
   ============================================================ */
.form-step-hidden{display:none}

.form-group{margin-bottom:22px}
.form-group-mt{margin-top:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

.form-group label{
  display:block;
  font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;
  color:var(--text-light);margin-bottom:9px;
}

.form-group input,
.form-group select,
.form-group textarea{
  width:100%;padding:15px 18px;
  background:#fff;
  border:1px solid var(--line-soft);border-radius:8px;
  font-size:15px;font-weight:400;color:var(--charcoal);
  transition:all .3s var(--ease);
  font-family:inherit;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(196,160,100,.12);
}
.form-group textarea{resize:vertical;min-height:96px}
.form-group select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239c7e48' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;background-size:16px;
  padding-right:42px;
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--text-light);opacity:.55}

.form-actions{
  display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;align-items:center;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 32px;
  font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  border-radius:100px;border:1px solid transparent;
  transition:all .4s var(--ease);
  cursor:pointer;
  position:relative;overflow:hidden;
}
.btn-primary{background:var(--forest);color:#fff;border-color:var(--forest)}
.btn-primary:hover{
  background:var(--gold);border-color:var(--gold);color:#fff;
  transform:translateY(-2px);box-shadow:var(--shadow-gold);
}
.btn-primary:disabled{
  opacity:.45;cursor:not-allowed;transform:none;box-shadow:none;
  background:var(--text-light);border-color:var(--text-light);
}
.btn-outline{
  background:transparent;color:var(--charcoal);
  border-color:var(--line);
}
.btn-outline:hover{
  border-color:var(--forest);color:var(--forest);
  background:rgba(45,74,53,.04);
}
.btn-success{
  background:transparent;color:var(--success-deep);
  border-color:rgba(58,138,79,.4);
}
.btn-success:hover{background:var(--success);color:#fff;border-color:var(--success)}
.btn-danger{
  background:transparent;color:var(--danger-deep);
  border-color:rgba(192,57,43,.4);
}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-full{width:100%}
.btn-mini{padding:8px 16px;font-size:10px;letter-spacing:.18em}

.btn-back,.btn-next{}

/* ============================================================
   BOOKING LAYOUT (calendar + summary)
   ============================================================ */
.booking-layout{
  display:grid;grid-template-columns:1.45fr 1fr;gap:36px;
  align-items:flex-start;
}

/* ============================================================
   CALENDAR
   ============================================================ */
.calendar-wrap{
  background:#fff;
  border:1px solid var(--line-light);border-radius:14px;
  padding:30px 32px;
  box-shadow:var(--shadow-sm);
}
.cal-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:22px;padding-bottom:18px;
  border-bottom:1px solid var(--line-light);
}
.cal-month{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:24px;font-weight:500;color:var(--charcoal);letter-spacing:.01em;
}
.cal-nav{display:flex;gap:8px}
.cal-nav-btn{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--cream-dark);color:var(--charcoal);
  border:1px solid transparent;
  transition:all .3s var(--ease);
}
.cal-nav-btn:hover{
  background:var(--forest);color:#fff;
  transform:translateY(-1px);
}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-day-name{
  font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-light);text-align:center;padding:6px 0 12px;
}
.cal-day{
  aspect-ratio:1;
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:15px;font-weight:500;
  color:var(--charcoal);
  border-radius:8px;
  background:var(--cream);
  cursor:pointer;
  transition:all .25s var(--ease);
  position:relative;
}
.cal-day:hover:not(.blocked):not(.past):not(.empty){
  background:var(--gold-pale);color:var(--charcoal);
  transform:translateY(-1px);
}
.cal-day.empty{cursor:default;background:transparent}
.cal-day.past{
  color:var(--text-light);opacity:.35;cursor:not-allowed;background:transparent;
}
.cal-day.blocked{
  background:var(--forest);color:rgba(255,255,255,.55);
  cursor:not-allowed;
  position:relative;
}
.cal-day.blocked::after{
  content:'';position:absolute;left:30%;right:30%;top:50%;height:1px;
  background:rgba(255,255,255,.45);transform:rotate(-15deg);
}
.cal-day.selected-start,.cal-day.selected-end{
  background:var(--gold);color:#fff;font-weight:700;
  box-shadow:0 6px 20px rgba(196,160,100,.42);
  transform:scale(1.04);
}
.cal-day.in-range{
  background:var(--gold-pale);color:var(--charcoal);
}
.cal-day.today{
  border:1px solid var(--gold);position:relative;
}
.cal-day.today::before{
  content:'';position:absolute;bottom:5px;left:50%;
  width:4px;height:4px;border-radius:50%;
  background:var(--gold);transform:translateX(-50%);
}
.cal-day.today.selected-start::before,
.cal-day.today.selected-end::before{background:#fff}

.cal-legend{
  display:flex;gap:22px;flex-wrap:wrap;
  margin-top:24px;padding-top:20px;
  border-top:1px solid var(--line-light);
  font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.04em;
}
.cal-legend-item{display:inline-flex;align-items:center;gap:8px}
.cal-legend-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0}
.cal-legend-dot-selected{background:var(--gold)}
.cal-legend-dot-blocked{background:var(--forest);opacity:.7}
.cal-legend-dot-range{background:var(--gold-pale);border:1px solid var(--gold)}

.ical-status{
  display:inline-flex;align-items:center;gap:9px;
  margin-top:18px;padding:10px 16px;
  background:var(--cream);border-radius:100px;
  font-size:11px;color:var(--text-light);font-weight:500;letter-spacing:.06em;
}
.ical-status svg{width:13px;height:13px;color:var(--gold-dark)}
.ical-status.synced{background:rgba(58,138,79,.08);color:var(--success-deep)}
.ical-status.synced svg{color:var(--success)}
.ical-status.error{background:rgba(192,57,43,.08);color:var(--danger-deep)}
.ical-status.error svg{color:var(--danger)}

/* ============================================================
   BOOKING FORM CARD (right column)
   ============================================================ */
.booking-form-wrap{
  background:#fff;
  border:1px solid var(--line-light);border-radius:14px;
  position:sticky;top:120px;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.booking-form-top{
  padding:28px 32px 22px;
  background:linear-gradient(180deg,var(--cream) 0%,#fff 100%);
  border-bottom:1px solid var(--line-light);
}
.booking-form-title{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:24px;font-weight:500;color:var(--charcoal);
  margin-bottom:6px;
}
.booking-form-sub{font-size:13px;color:var(--text-light);font-weight:400}
.booking-form-body{padding:26px 32px 30px}

.dates-display{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
  margin-bottom:24px;
}
.date-box{
  padding:14px 16px;
  background:var(--cream);
  border:1px solid var(--line-light);border-radius:10px;
}
.date-box-label{
  font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-light);margin-bottom:6px;
}
.date-box-val{
  font-family:'Playfair Display',serif;font-size:16px;font-weight:500;
  color:var(--charcoal);line-height:1.3;
}
.date-box-val.empty{
  color:var(--text-light);font-style:italic;font-weight:400;font-size:13px;
}

/* ============================================================
   PRICE SUMMARY
   ============================================================ */
.price-summary{
  margin:18px 0 22px;padding:18px 0;
  border-top:1px solid var(--line-light);
  border-bottom:1px solid var(--line-light);
}
.price-summary-payment{margin-top:8px;border-top:none;padding-top:0}
.payment-total-num{font-family:'Playfair Display',serif;font-style:italic;font-size:30px;color:var(--gold-dark)}
.price-row{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:14px;color:var(--text-light);font-weight:400;
  padding:6px 0;
}
.price-row span:last-child{color:var(--charcoal);font-weight:500}
.price-row.total{
  margin-top:10px;padding-top:14px;
  border-top:1px solid var(--line-light);
  font-family:'Playfair Display',serif;font-size:18px;font-weight:600;
  color:var(--charcoal);
}
.price-row.total span:last-child{
  font-size:22px;font-style:italic;color:var(--gold-dark);
}

/* ============================================================
   RECAP CARD (left column on steps 2-3)
   ============================================================ */
.recap-card{
  background:#fff;
  border:1px solid var(--line-light);border-radius:14px;
  padding:32px 36px;
  box-shadow:var(--shadow-sm);
}

.info-note{
  display:flex;align-items:flex-start;gap:10px;
  padding:14px 16px;margin-top:18px;
  background:var(--cream);border:1px solid var(--line-light);border-radius:10px;
  font-size:12.5px;color:var(--text-light);line-height:1.55;
}
.info-note svg{color:var(--gold-dark);margin-top:2px;flex-shrink:0}

.confirmation-note{
  margin-top:18px;padding:14px 16px;
  background:rgba(58,138,79,.06);border:1px solid rgba(58,138,79,.18);border-radius:10px;
  font-size:12.5px;color:var(--success-deep);line-height:1.55;font-weight:500;
}

/* ============================================================
   STRIPE / PAYMENT
   ============================================================ */
.stripe-info{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;margin-bottom:18px;
  background:var(--cream);border:1px solid var(--line-light);border-radius:10px;
  font-size:12px;color:var(--text-light);font-weight:500;letter-spacing:.04em;
}
.stripe-info svg{width:14px;height:14px;flex-shrink:0;color:var(--gold-dark)}
.stripe-card-demo-fields{display:flex;flex-direction:column;gap:12px}
.stripe-card-demo-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input.demo-card-input{
  width:100%;padding:15px 18px;
  background:#fff;border:1px solid var(--line-soft);border-radius:8px;
  font-size:15px;font-family:'Playfair Display',serif;letter-spacing:.06em;
  color:var(--charcoal);transition:all .3s var(--ease);
}
.stripe-card-demo-row input{
  width:100%;padding:14px 16px;
  background:#fff;border:1px solid var(--line-soft);border-radius:8px;
  font-size:14px;color:var(--charcoal);
}
input.demo-card-input:focus,
.stripe-card-demo-row input:focus{
  outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(196,160,100,.12);
}

/* ============================================================
   CONFIRMATION (step 4)
   ============================================================ */
.confirmation-box{
  text-align:center;max-width:680px;margin:0 auto;
  padding:60px 48px;
  background:#fff;border:1px solid var(--line-light);border-radius:18px;
  box-shadow:var(--shadow-md);
}
.confirmation-icon{
  width:72px;height:72px;border-radius:50%;
  background:var(--forest);color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 28px;
  box-shadow:0 14px 40px rgba(45,74,53,.32);
}
.confirmation-title{
  font-family:'Montserrat',sans-serif;font-weight:200;font-size:42px;letter-spacing:-.02em;
  color:var(--charcoal);margin-bottom:14px;line-height:1.1;
}
.confirmation-sub{
  font-size:15px;color:var(--text-light);line-height:1.7;
  margin-bottom:36px;
}
.confirmation-sub strong{color:var(--charcoal);font-weight:600}
.confirmation-details{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
  margin-bottom:36px;text-align:left;
}
.conf-detail{
  padding:18px 22px;
  background:var(--cream);border:1px solid var(--line-light);border-radius:10px;
}
.conf-detail-label{
  font-size:10px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;
  color:var(--text-light);margin-bottom:6px;
}
.conf-detail-val{
  font-family:'Playfair Display',serif;font-size:18px;font-weight:600;
  color:var(--charcoal);
}

/* ============================================================
   TOAST
   ============================================================ */
.toast{
  position:fixed;bottom:32px;right:32px;z-index:200;
  padding:16px 22px;
  background:#fff;border:1px solid var(--line-light);border-radius:10px;
  box-shadow:var(--shadow-lg);
  font-size:13px;font-weight:500;color:var(--charcoal);
  transform:translateY(20px);opacity:0;
  transition:all .35s var(--ease);
  pointer-events:none;max-width:340px;
}
.toast.show{transform:translateY(0);opacity:1;pointer-events:auto}
.toast.success{border-color:rgba(58,138,79,.4);color:var(--success-deep);background:rgba(58,138,79,.04)}
.toast.error{border-color:rgba(192,57,43,.4);color:var(--danger-deep);background:rgba(192,57,43,.04)}

/* ============================================================
   ADMIN
   ============================================================ */
.admin-login{
  max-width:460px;margin:60px auto;
  padding:48px 44px;
  background:#fff;border:1px solid var(--line-light);border-radius:14px;
  text-align:center;box-shadow:var(--shadow-sm);
}
.admin-login-title{
  font-family:'Montserrat',sans-serif;font-weight:200;font-size:34px;
  color:var(--charcoal);margin-bottom:8px;letter-spacing:-.02em;
}
.admin-login-sub{
  font-size:13.5px;color:var(--text-light);margin-bottom:8px;
}
.btn-login{margin-top:8px}

.admin-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  margin:36px 0 40px;
}
.admin-stat{
  padding:24px 26px;
  background:#fff;border:1px solid var(--line-light);border-radius:12px;
  transition:all .3s var(--ease);
}
.admin-stat:hover{
  transform:translateY(-2px);
  border-color:var(--gold);box-shadow:var(--shadow-md);
}
.admin-stat-num{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:600;
  font-size:36px;color:var(--gold-dark);line-height:1;margin-bottom:8px;
}
.admin-stat-label{
  font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;
  color:var(--text-light);
}

.admin-dashboard-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  flex-wrap:wrap;gap:18px;margin-bottom:8px;
}

.table-wrap{
  background:#fff;border:1px solid var(--line-light);border-radius:14px;
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.table-header{
  padding:24px 30px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  border-bottom:1px solid var(--line-light);
  background:var(--cream);
}
.admin-table-h3{
  font-family:'Playfair Display',serif;font-style:italic;font-size:22px;font-weight:500;
  color:var(--charcoal);
}
.table-filter{display:flex;gap:6px;flex-wrap:wrap}
.filter-btn{
  padding:8px 16px;
  font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-light);background:transparent;border:1px solid transparent;border-radius:100px;
  transition:all .3s var(--ease);
}
.filter-btn.active{background:var(--forest);color:#fff;border-color:var(--forest)}
.filter-btn:not(.active):hover{color:var(--charcoal);border-color:var(--line)}

.admin-table-scroll{overflow-x:auto}
.bookings-table{width:100%;border-collapse:collapse}
.bookings-table th{
  padding:14px 18px;text-align:left;
  font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-light);background:var(--cream);
  border-bottom:1px solid var(--line-light);
}
.bookings-table td{
  padding:16px 18px;font-size:13.5px;color:var(--charcoal);
  border-bottom:1px solid var(--line-soft);
}
.bookings-table tr:hover td{background:var(--cream)}
.bookings-empty-cell{padding:48px 0;text-align:center;color:var(--text-light);font-style:italic}
.bookings-id{color:var(--gold-dark);font-family:'Playfair Display',serif;font-style:italic;font-weight:600}
.bookings-name{font-weight:500;color:var(--charcoal)}
.bookings-email{font-size:11.5px;color:var(--text-light);margin-top:2px}
.bookings-nights{text-align:center}
.bookings-total{font-family:'Playfair Display',serif;font-weight:600;color:var(--gold-dark)}

.status-badge{
  display:inline-flex;align-items:center;
  padding:5px 12px;border-radius:100px;
  font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
}
.status-pending{background:rgba(196,160,100,.16);color:var(--gold-dark)}
.status-confirmed{background:rgba(58,138,79,.14);color:var(--success-deep)}
.status-cancelled{background:rgba(192,57,43,.12);color:var(--danger-deep)}

.admin-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:300;
  background:rgba(13,13,11,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  align-items:center;justify-content:center;padding:24px;
}
.modal-overlay.open{display:flex}
.modal{
  background:#fff;border-radius:16px;
  max-width:680px;width:100%;
  padding:40px 44px;position:relative;
  box-shadow:var(--shadow-xl,var(--shadow-lg));
  max-height:90vh;overflow-y:auto;
}
.modal-close{
  position:absolute;top:18px;right:22px;
  font-size:22px;color:var(--text-light);
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease);
}
.modal-close:hover{background:var(--cream);color:var(--charcoal)}
.modal-title{
  font-family:'Playfair Display',serif;font-style:italic;font-size:26px;font-weight:600;
  color:var(--charcoal);margin-bottom:24px;letter-spacing:-.005em;
}
.modal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px}
.modal-info-item{
  padding:14px 16px;
  background:var(--cream);border:1px solid var(--line-light);border-radius:10px;
}
.modal-info-label{
  font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-light);margin-bottom:6px;
}
.modal-info-val{font-size:14px;color:var(--charcoal);font-weight:500}
.modal-actions{display:flex;gap:12px;flex-wrap:wrap}

/* ============================================================
   FOOTER (matches index.php footer style)
   ============================================================ */
footer{
  background:var(--charcoal);color:rgba(250,246,238,.55);
  padding:72px 56px 32px;text-align:center;position:relative;
}
footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.footer-wordmark{
  display:inline-flex;flex-direction:column;align-items:center;gap:5px;
  margin-bottom:18px;color:#fff;
}
.footer-wordmark .wordmark-name{font-size:30px}
.footer-wordmark .wordmark-name em{color:var(--gold-light)}
.footer-wordmark .wordmark-sub{color:rgba(250,246,238,.4)}
.footer-tag{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:16px;color:rgba(250,246,238,.55);margin-bottom:28px;
}
.footer-citq{
  display:inline-flex;align-items:center;gap:12px;
  padding:11px 22px;border:1px solid rgba(196,160,100,.32);border-radius:100px;
  margin-bottom:30px;
}
.footer-citq svg{width:18px;height:18px}
.footer-citq-text{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(250,246,238,.5);font-weight:500;
}
.footer-citq-num{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:15px;color:var(--gold-light);font-weight:500;
}
.footer-links{
  display:flex;gap:26px;justify-content:center;margin:22px 0;flex-wrap:wrap;list-style:none;
}
.footer-links a{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(250,246,238,.42);transition:color .3s var(--ease);
}
.footer-links a:hover{color:var(--gold-light)}
.footer-copy{
  font-size:10.5px;letter-spacing:.1em;margin-top:22px;
  color:rgba(250,246,238,.28);padding-top:22px;
  border-top:1px solid rgba(196,160,100,.12);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  nav{padding:14px 32px}
  .citq-bar{padding:24px 32px;gap:18px}
  .page-tabs{padding-left:32px;padding-right:32px;padding-top:24px}
  .tab-content{padding:40px 32px 80px}
  .booking-layout{grid-template-columns:1fr;gap:24px}
  .booking-form-wrap{position:static}
  .admin-stats{grid-template-columns:1fr 1fr}
  footer{padding:56px 32px 28px}
}
@media(max-width:680px){
  nav{padding:14px 22px;flex-wrap:wrap;gap:14px}
  .nav-right{gap:14px}
  .nav-back span{display:none}
  .citq-bar{padding:20px 22px;gap:14px;flex-direction:column}
  .citq-div{display:none}
  .citq-num{font-size:22px}
  .page-tabs{padding-left:22px;padding-right:22px;padding-top:22px}
  .page-tab{padding:11px 18px;font-size:10px;letter-spacing:.16em}
  .tab-content{padding:30px 22px 70px}
  .step span{display:none}
  .step{font-size:12px}
  .step-line{display:none;margin:0 4px}
  .step-num{width:28px;height:28px;font-size:13px}
  .calendar-wrap{padding:22px 18px}
  .cal-month{font-size:20px}
  .cal-day{font-size:13px;border-radius:6px}
  .booking-form-top,.booking-form-body{padding:22px 22px}
  .recap-card{padding:24px 22px}
  .form-row{grid-template-columns:1fr}
  .admin-stats{grid-template-columns:1fr 1fr;gap:12px}
  .admin-stat{padding:18px 20px}
  .admin-stat-num{font-size:28px}
  .modal-info-grid{grid-template-columns:1fr}
  .confirmation-details{grid-template-columns:1fr}
  .confirmation-box{padding:42px 26px}
  .confirmation-title{font-size:32px}
  .modal{padding:30px 24px}
  .table-wrap{margin:0 -22px;border-radius:0;border-left:none;border-right:none}
  .bookings-table th,.bookings-table td{padding:12px 14px;font-size:12.5px}
  footer{padding:52px 22px 28px}
}
