/* ============================================================
   Thảo Điền Spa — CSS riêng cho TRANG LIÊN HỆ (contact.php)
   Hero meta, Contact + Form, Map, FAQ
   ============================================================ */

/* Hero meta phụ */
.page-hero-meta{display:flex;gap:32px;margin-top:38px;flex-wrap:wrap}
.page-hero-meta .pm{display:flex;align-items:center;gap:10px;font-size:.84rem;color:rgba(255,255,255,.7)}
.page-hero-meta .pm svg{width:16px;height:16px;color:var(--gold);flex:none}
.page-hero-meta .pm strong{color:#fff;font-weight:500}

/* Layout liên hệ */
.contact-page{background:var(--paper);padding:80px 0}
.contact-page .wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:start}
@media(max-width:900px){.contact-page .wrap{grid-template-columns:1fr;gap:50px}}

/* Cột thông tin */
.ci-block h2{font-size:clamp(1.9rem,3.2vw,2.6rem);color:var(--leaf-dark);margin:14px 0 22px}
.ci-block p.intro{color:var(--ink-soft);margin-bottom:32px;max-width:42ch}
.social-row{display:flex;gap:10px;margin-top:4px}
.social-row a{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:40px;
  font-size:.8rem;font-weight:500;letter-spacing:.04em;
  border:1px solid var(--line);color:var(--ink-soft);
  transition:background .25s,color .25s,border-color .25s,transform .25s;
}
.social-row a svg{width:15px;height:15px}
.social-row a:hover{background:var(--leaf-deep);color:#fff;border-color:transparent;transform:translateY(-2px)}

/* Cột form đặt lịch */
.form-card{
  background:var(--cream);
  border-radius:22px;
  border:1px solid var(--line);
  padding:40px 36px;
  box-shadow:0 20px 50px -30px rgba(44,74,31,.18);
}
.form-card h3{font-size:1.8rem;color:var(--leaf-dark);margin-bottom:6px}
.form-card p.form-sub{font-size:.88rem;color:var(--ink-soft);margin-bottom:28px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--line);
  border-radius:10px;
  background:var(--paper);
  font-family:var(--sans);font-size:.9rem;color:var(--ink);
  outline:none;
  transition:border-color .25s,box-shadow .25s;
  -webkit-appearance:none;
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-soft);opacity:.6}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--leaf-deep);
  box-shadow:0 0 0 3px rgba(63,107,44,.12);
}
.field textarea{resize:vertical;min-height:100px;line-height:1.6}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%235a6450' stroke-width='2'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.submit-btn{
  width:100%;margin-top:8px;
  padding:15px;border:none;border-radius:40px;cursor:pointer;
  font-family:var(--sans);font-size:.88rem;font-weight:600;letter-spacing:.06em;
  background:linear-gradient(135deg,var(--leaf-deep),var(--leaf-dark));
  color:#fff;
  box-shadow:0 14px 28px -12px rgba(44,74,31,.6);
  transition:transform .25s,box-shadow .25s;
}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 20px 34px -14px rgba(44,74,31,.7)}
.form-note{
  text-align:center;font-size:.76rem;color:var(--ink-soft);margin-top:12px;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.form-note svg{width:13px;height:13px;color:var(--leaf);flex:none}
.form-success{
  display:none;
  flex-direction:column;align-items:center;text-align:center;
  padding:24px 0;gap:14px;
}
.form-success .tick{
  width:60px;height:60px;border-radius:50%;
  background:rgba(124,179,66,.15);
  display:grid;place-items:center;
}
.form-success .tick svg{width:28px;height:28px;color:var(--leaf-deep)}
.form-success h4{font-family:var(--serif);font-size:1.5rem;color:var(--leaf-dark)}
.form-success p{font-size:.88rem;color:var(--ink-soft);max-width:34ch}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}.form-card{padding:28px 22px}}

/* Bản đồ */
.map-section{padding:0 0 80px;background:var(--paper)}
.map-section .wrap{display:grid;grid-template-columns:1fr 1.6fr;gap:0;border-radius:22px;overflow:hidden;
  box-shadow:var(--shadow);border:1px solid var(--line)}
.map-sidebar{background:var(--leaf-dark);color:var(--text-on-leaf);padding:48px 36px;display:flex;flex-direction:column;gap:28px}
.map-sidebar h3{font-size:1.6rem;color:#fff;margin-bottom:4px}
.map-sidebar p{font-size:.88rem;color:rgba(255,255,255,.65);max-width:28ch;line-height:1.65}
.map-dir .d-item{display:flex;gap:12px;align-items:flex-start;font-size:.84rem;color:rgba(255,255,255,.75);margin-bottom:14px}
.map-dir .d-item svg{width:16px;height:16px;color:var(--gold);flex:none;margin-top:3px}
.map-dir strong{color:#fff;display:block;margin-bottom:2px;font-weight:500}
.map-a{
  display:inline-flex;align-items:center;gap:8px;margin-top:8px;
  padding:11px 20px;border-radius:40px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  font-size:.8rem;font-weight:500;color:#fff;
  transition:background .25s,transform .25s;
}
.map-a:hover{background:var(--gold);border-color:var(--gold);color:var(--text-on-gold);transform:translateY(-2px)}
.map-a svg{width:14px;height:14px}
.map-embed{min-height:420px}
.map-embed iframe{width:100%;height:100%;min-height:420px;border:0;filter:saturate(.92)}
@media(max-width:880px){
  .map-section .wrap{grid-template-columns:1fr}
  .map-sidebar{padding:36px 26px}
  .map-embed{min-height:320px}
  .map-embed iframe{min-height:320px}
}

/* FAQ */
.faq-section{padding:80px 0;background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.faq-section .sec-head{text-align:center;max-width:600px;margin:0 auto 48px}
.faq-section .sec-head h2{font-size:clamp(2rem,3.6vw,2.8rem);color:var(--leaf-dark);margin:14px 0 12px}
.faq-section .sec-head p{color:var(--ink-soft)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-item{
  background:var(--paper);border-radius:14px;padding:24px 26px;
  border:1px solid var(--line);
  transition:box-shadow .3s,transform .3s;
}
.faq-item:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.faq-item h4{font-family:var(--serif);font-size:1.2rem;color:var(--leaf-dark);margin-bottom:8px;font-weight:500}
.faq-item p{font-size:.88rem;color:var(--ink-soft);line-height:1.65}
@media(max-width:700px){.faq-grid{grid-template-columns:1fr}}
