/* Phantom Studio — Colorful Editorial One‑Pager */
:root{
  --bg:#ffffff;
  --ink:#101114;
  --muted:#5b6370;
  --brand:#e4572e;       /* coral/orange */
  --brand-2:hwb(204 23% 7%);     /* purple */
  --brand-3:#0f766e;     /* teal */
  --chip:#f3f4f6;
  --card:#ffffff;
  --ring: #3acfed59;
  --shadow: 0 10px 30px rgba(0,0,0,.08), 0 4px 10px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html,body{height:60%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.wrap{max-width:1100px;margin:0 auto;padding:0 20px}

.site-header{
  position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid #eee
}
.site-header .wrap{
  display:flex;align-items:center;justify-content:space-between;height:64px
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;font-weight:700}
.logo{width:28px;height:28px}
.site-header nav{display:flex;gap:16px;align-items:center}
.site-header nav a{color:#222;text-decoration:none;font-weight:600}
.site-header nav a.btn-primary{color:#fff}

.hero{padding:56px 0;background:linear-gradient(135deg, rgba(228,87,46,.06), rgba(124,58,237,.06) 40%, rgba(15,118,110,.06))}
.hero-in{display:grid;grid-template-columns: 1.2fr .8fr;gap:28px;align-items:center}
.hero-copy h1{
  font-family:Poppins, Inter, sans-serif;
  font-size: clamp(28px, 4vw, 46px);
  line-height:1.1;
  margin:0 0 12px;
}
.hero-copy p{margin:0 0 20px;color:var(--muted);max-width:60ch}
.underline{background:linear-gradient(90deg,var(--brand),var(--brand-2),var(--brand-3));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-art{display:grid;gap:16px;grid-template-columns:1fr 1fr}
.color-card{height:150px;border-radius:18px;box-shadow:var(--shadow)}
.cc1{background:linear-gradient(135deg,#fff1ec,#ffd9cf)}
.cc2{background:linear-gradient(135deg,#efe6ff,#e3d8ff)}
.cc3{background:linear-gradient(135deg,#e1faf7,#d4f5ef)}

.btn-primary,.btn-outline,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 16px;border-radius:999px;font-weight:700;text-decoration:none;border:2px solid transparent;transition:.2s
}
.btn-primary{background:var(--brand-2);border-color:var(--brand-2);color:#fff;box-shadow:0 2px 8px rgba(124,58,237,.25)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-outline{border-color:#d1d5db;color:#111;background:#fff}
.btn-outline:hover{border-color:#9ca3af}
.btn-ghost{background:transparent;color:#111}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}

.section{padding:64px 0}
.section.alt{background:#fafafa}
.section-title{font-family:Poppins, Inter, sans-serif;font-size: clamp(22px,3vw,32px);margin:0 0 8px}
.section-sub{color:var(--muted);margin-top:0}

.masonry{columns: 3 280px; column-gap:12px}
.tile{display:block;margin:0 0 12px;border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.tile img{display:block;width:100%;height:auto}

.chips{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 16px}
.chip{border:none;background:var(--chip);padding:8px 12px;border-radius:999px;font-weight:600;cursor:pointer}
.chip.active{background:#fff;border:2px solid var(--brand-2);box-shadow:0 0 0 4px var(--ring)}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.card{background:var(--card);border:1px solid #eee;border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.card h3{margin:0 0 6px}
.card .muted{color:var(--muted);margin:0 0 10px}
.price{font-weight:800;font-size:20px}

.list{margin:0;padding:0 0 0 18px}
.list li{margin:8px 0}

.tab-panels{margin-top:10px}
.tab-panel.show{display:block}
.tab-panel[hidden]{display:none}

.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
blockquote{margin:0;padding:16px;border-radius:14px;border:1px solid #eee;background:#fff;box-shadow:var(--shadow)}
blockquote p{margin:0 0 8px}
blockquote cite{color:var(--muted);font-style:normal}

.booking-form .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.booking-form label{display:flex;flex-direction:column;gap:6px;font-weight:600}
.booking-form input, .booking-form select, .booking-form textarea{
  padding:12px;border-radius:12px;border:1px solid #d1d5db;background:#fff;font:inherit;outline:none
}
.booking-form input:focus, .booking-form select:focus, .booking-form textarea:focus{
  border-color:var(--brand-2); box-shadow:0 0 0 4px var(--ring)
}
.booking-form label.full{grid-column:1 / -1}

.contact .contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.contact-list{margin:0;padding:0;list-style:none}
.contact-list li{margin:6px 0}
.social{margin:0;padding-left:18px}
/* Location other field hint */
.hint{
  display:block;
  color:var(--muted);
  font-weight:400;
  margin-top:6px;
  font-size:12px;
}

/* Ensure selects match inputs */
.booking-form select{
  padding:12px;
  border-radius:12px;
  border:1px solid #d1d5db;
  background:#fff;
  font:inherit;
  outline:none;
}
.booking-form select:focus{
  border-color:var(--brand-2);
  box-shadow:0 0 0 4px var(--ring);
}


.site-footer{border-top:1px solid #eee;padding:20px 0}
.site-footer .wrap{display:flex;align-items:center;justify-content:space-between}
.to-top{border:1px solid #e5e7eb;border-radius:999px;padding:6px 10px;text-decoration:none;color:#111}

@media (max-width: 800px){
  .hero-in{grid-template-columns:1fr}
}
/* Location “Other” hint + select focus */
.hint{display:block;color:var(--muted);font-weight:400;margin-top:6px;font-size:12px}
.booking-form select{padding:12px;border-radius:12px;border:1px solid #d1d5db;background:#fff;font:inherit;outline:none}
.booking-form select:focus{border-color:var(--brand-2);box-shadow:0 0 0 4px var(--ring)}
/* --- Booking form padding upgrade --- */
.booking-form .grid{
  gap:16px;                 /* more space between fields (was 12px) */
}

.booking-form label{
  padding:6px 0;            /* a little vertical breathing room per row */
}

.booking-form input,
.booking-form select,
.booking-form textarea{
  padding:14px 16px;        /* inner padding (was ~12px) */
  border-radius:14px;       /* slightly rounder for comfort */
}

.booking-form textarea{
  min-height: 160px;        /* taller message box */
}

/* Optional: bigger buttons in that section */
#booking .btn-primary,
#booking .btn-outline{
  padding:14px 18px;
}

/* Mobile tweak: reduce just a bit so it doesn't feel cramped */
@media (max-width: 520px){
  .booking-form input,
  .booking-form select,
  .booking-form textarea{ padding:13px 14px; }
}

