/* ════════════════════════════════════════════
   BN Contact & Booking – bnct-style.css v1.0.0
════════════════════════════════════════════ */
.bnct-wrap {
    --bn-primary:   #0d2b5e;
    --bn-primary-d: #091f45;
    --bn-accent:    #2ecc71;
    --bn-accent-d:  #27ae60;
    --bn-blue:      #1d6fc4;
    --bn-text:      #1a1a2e;
    --bn-muted:     #5a6a7a;
    --bn-border:    #e2e8f0;
    --bn-bg:        #ffffff;
    --bn-bg-alt:    #f4f7fb;
    --bn-hero:      linear-gradient(135deg,#0d2b5e 0%,#1d6fc4 60%,#0d7c4e 100%);
    --bn-radius:    12px;
    --bn-font:      'Segoe UI',system-ui,-apple-system,sans-serif;
    font-family: var(--bn-font);
    color: var(--bn-text);
    box-sizing: border-box;
    /* Full bleed */
    display: block !important;
    margin: 0 !important; padding: 0 !important;
    position: relative;
    left: 50%; right: 50%;
    margin-left: -50vw !important; margin-right: -50vw !important;
    width: 100vw !important; max-width: 100vw !important;
}
.bnct-wrap *, .bnct-wrap *::before, .bnct-wrap *::after { box-sizing: inherit; }

/* ── HERO ─────────────────────────────────── */
.bnct-hero { background: var(--bn-hero); padding: 64px 20px 52px; text-align: center; position: relative; overflow: hidden; }
.bnct-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 70% 40%,rgba(46,204,113,.18) 0%,transparent 65%); pointer-events:none; }
.bnct-hero-booking { background: linear-gradient(135deg,#0d2b5e 0%,#0d5098 55%,#0d7c4e 100%); }
.bnct-hero-inner { max-width:700px; margin:0 auto; position:relative; z-index:1; }
.bnct-badge { display:inline-block; background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.3); color:#fff; font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; padding:5px 14px; border-radius:30px; margin-bottom:16px; }
.bnct-hero-title { font-size:clamp(26px,5vw,44px); font-weight:800; color:#fff; margin:0 0 12px; line-height:1.15; letter-spacing:-.4px; }
.bnct-hero-sub { font-size:clamp(14px,2vw,17px); color:rgba(255,255,255,.82); margin:0 0 28px; line-height:1.6; }
.bnct-hero-quick { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.bnct-quick-btn { display:inline-flex; align-items:center; gap:8px; padding:12px 22px; border-radius:8px; font-size:14px; font-weight:700; text-decoration:none; transition:all .18s; white-space:nowrap; }
.bnct-quick-btn svg { width:18px; height:18px; flex-shrink:0; }
.bnct-quick-call { background:rgba(255,255,255,.15); color:#fff; border:1.5px solid rgba(255,255,255,.4); }
.bnct-quick-call:hover { background:rgba(255,255,255,.25); }
.bnct-quick-wa { background:#25d366; color:#fff; border:1.5px solid #25d366; }
.bnct-quick-wa:hover { background:#1aad55; }

/* Hero fee pills */
.bnct-hero-fees { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:20px; }
.bnct-fee-pill { display:flex; flex-direction:column; align-items:center; background:rgba(255,255,255,.13); border:1.5px solid rgba(255,255,255,.25); border-radius:10px; padding:12px 24px; }
.bnct-fee-type { font-size:12px; color:rgba(255,255,255,.75); font-weight:600; text-transform:uppercase; letter-spacing:.5px; }
.bnct-fee-amt { font-size:22px; font-weight:800; color:#fff; margin-top:2px; }
.bnct-fee-online-pill .bnct-fee-amt { color:var(--bn-accent); }

/* ── MAIN LAYOUT ──────────────────────────── */
.bnct-main { max-width:1200px; margin:0 auto; padding:40px 20px 60px; }
.bnct-contact-layout { display:grid; grid-template-columns:320px 1fr; gap:32px; align-items:start; }
.bnct-booking-layout { display:grid; grid-template-columns:1fr 360px; gap:32px; align-items:start; }

/* ── INFO CARDS ───────────────────────────── */
.bnct-info-card { display:flex; gap:14px; align-items:flex-start; background:var(--bn-bg); border:1.5px solid var(--bn-border); border-radius:var(--bn-radius); padding:18px; margin-bottom:14px; transition:box-shadow .2s; }
.bnct-info-card:hover { box-shadow:0 4px 20px rgba(13,43,94,.08); }
.bnct-info-icon { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.bnct-info-icon svg { width:22px; height:22px; }
.bnct-icon-phone { background:rgba(13,43,94,.08); color:var(--bn-primary); }
.bnct-icon-email { background:rgba(29,111,196,.1); color:var(--bn-blue); }
.bnct-icon-loc   { background:rgba(46,204,113,.1); color:var(--bn-accent-d); }
.bnct-icon-hours { background:rgba(231,76,60,.1); color:#e74c3c; }
.bnct-info-body h3 { font-size:13px; font-weight:700; color:var(--bn-muted); text-transform:uppercase; letter-spacing:.5px; margin:0 0 4px; }
.bnct-info-body a { display:block; color:var(--bn-primary); font-weight:600; text-decoration:none; font-size:14px; line-height:1.6; }
.bnct-info-body a:hover { color:var(--bn-blue); }
.bnct-info-body p { margin:2px 0; font-size:14px; color:var(--bn-text); line-height:1.5; }
.bnct-closed { color:#e74c3c !important; }
.bnct-map-link { color:var(--bn-blue) !important; font-size:13px !important; }
.bnct-book-cta-card { display:flex; align-items:center; justify-content:space-between; background:var(--bn-primary); color:#fff; border-radius:var(--bn-radius); padding:16px 20px; font-weight:700; font-size:15px; text-decoration:none; transition:background .18s; }
.bnct-book-cta-card:hover { background:var(--bn-primary-d); color:#fff; }

/* ── FORM CARD ────────────────────────────── */
.bnct-form-card { background:var(--bn-bg); border:1.5px solid var(--bn-border); border-radius:var(--bn-radius); padding:32px; }
.bnct-form-title { font-size:22px; font-weight:800; color:var(--bn-primary); margin:0 0 6px; }
.bnct-form-sub { font-size:14px; color:var(--bn-muted); margin:0 0 24px; }

/* ── FORM FIELDS ──────────────────────────── */
.bnct-form { display:flex; flex-direction:column; gap:16px; }
.bnct-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.bnct-field { display:flex; flex-direction:column; gap:5px; }
.bnct-field-full { grid-column:1/-1; }
.bnct-field label { font-size:13px; font-weight:600; color:var(--bn-text); }
.bnct-req { color:#e74c3c; }
.bnct-field input,
.bnct-field select,
.bnct-field textarea { padding:11px 14px; border:1.5px solid var(--bn-border); border-radius:8px; font-size:14px; font-family:var(--bn-font); color:var(--bn-text); background:var(--bn-bg); outline:none; transition:border-color .18s, box-shadow .18s; width:100%; }
.bnct-field input:focus,
.bnct-field select:focus,
.bnct-field textarea:focus { border-color:var(--bn-blue); box-shadow:0 0 0 3px rgba(29,111,196,.12); }
.bnct-field input.bnct-error,
.bnct-field select.bnct-error,
.bnct-field textarea.bnct-error { border-color:#e74c3c; box-shadow:0 0 0 3px rgba(231,76,60,.1); }
.bnct-field-hint { font-size:12px; color:var(--bn-muted); margin-top:2px; }

/* ── BUTTONS ──────────────────────────────── */
.bnct-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:13px 24px; border-radius:8px; font-size:14px; font-weight:700; text-decoration:none; cursor:pointer; border:2px solid transparent; font-family:var(--bn-font); transition:all .18s; white-space:nowrap; }
.bnct-btn:active { transform:scale(.97); }
.bnct-btn-primary { background:var(--bn-accent); color:#fff; border-color:var(--bn-accent); }
.bnct-btn-primary:hover { background:var(--bn-accent-d); border-color:var(--bn-accent-d); }
.bnct-btn-outline { background:transparent; color:var(--bn-primary); border-color:var(--bn-primary); }
.bnct-btn-outline:hover { background:var(--bn-primary); color:#fff; }
.bnct-btn-outline-dark { background:transparent; color:var(--bn-primary); border-color:var(--bn-border); width:100%; justify-content:center; }
.bnct-btn-outline-dark:hover { border-color:var(--bn-primary); }
.bnct-btn-whatsapp { background:#25d366; color:#fff; border-color:#25d366; width:100%; justify-content:center; }
.bnct-btn-whatsapp:hover { background:#1aad55; }

/* Spinner */
@keyframes bnct-spin { to { transform: rotate(360deg); } }
.bnct-spin { animation: bnct-spin .7s linear infinite; }
.bnct-spin { display:inline-block; width:18px; height:18px; }

/* ── NOTICE ───────────────────────────────── */
.bnct-notice { padding:14px 18px; border-radius:8px; font-size:14px; font-weight:600; margin-bottom:16px; }
.bnct-notice-success { background:#d4edda; color:#155724; border:1.5px solid #c3e6cb; }
.bnct-notice-error   { background:#f8d7da; color:#721c24; border:1.5px solid #f5c6cb; }

/* ── MAP ──────────────────────────────────── */
.bnct-map-wrap { width:100%; overflow:hidden; line-height:0; }
.bnct-map-wrap iframe { display:block; width:100%; border:none; }

/* ── BOOKING WIZARD STEPS ─────────────────── */
.bnct-steps { display:flex; align-items:center; margin-bottom:28px; }
.bnct-step { display:flex; align-items:center; gap:8px; }
.bnct-step-num { width:30px; height:30px; border-radius:50%; background:var(--bn-border); color:var(--bn-muted); font-size:13px; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .2s; }
.bnct-step-lbl { font-size:13px; font-weight:600; color:var(--bn-muted); white-space:nowrap; }
.bnct-step-active .bnct-step-num { background:var(--bn-primary); color:#fff; }
.bnct-step-active .bnct-step-lbl { color:var(--bn-primary); }
.bnct-step-done .bnct-step-num { background:var(--bn-accent); color:#fff; }
.bnct-step-line { flex:1; height:2px; background:var(--bn-border); margin:0 8px; }

.bnct-panel-title { font-size:18px; font-weight:700; color:var(--bn-primary); margin:0 0 20px; padding-bottom:12px; border-bottom:1.5px solid var(--bn-border); }
.bnct-step-nav { display:flex; gap:12px; justify-content:flex-end; margin-top:8px; }
.bnct-step-panel[hidden] { display:none; }

/* Consultation type cards */
.bnct-consult-type-wrap { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:20px; }
.bnct-type-card { border:2px solid var(--bn-border); border-radius:10px; padding:16px; cursor:pointer; display:flex; flex-direction:column; align-items:center; gap:4px; transition:all .18s; text-align:center; }
.bnct-type-card input[type=radio] { position:absolute; opacity:0; pointer-events:none; }
.bnct-type-card.bnct-type-active { border-color:var(--bn-primary); background:rgba(13,43,94,.04); }
.bnct-type-icon { font-size:28px; }
.bnct-type-name { font-size:14px; font-weight:700; color:var(--bn-text); }
.bnct-type-loc  { font-size:12px; color:var(--bn-muted); }
.bnct-type-fee  { font-size:15px; font-weight:800; color:var(--bn-primary); margin-top:4px; }

/* Time slots grid */
.bnct-slots-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-top:8px; }
.bnct-slot-btn { padding:10px 6px; border:1.5px solid var(--bn-border); border-radius:8px; background:var(--bn-bg); color:var(--bn-text); font-size:13px; font-weight:600; cursor:pointer; transition:all .15s; text-align:center; font-family:var(--bn-font); }
.bnct-slot-btn:hover { border-color:var(--bn-primary); color:var(--bn-primary); background:var(--bn-bg-alt); }
.bnct-slot-btn.bnct-slot-selected { background:var(--bn-primary); color:#fff; border-color:var(--bn-primary); }
.bnct-slot-btn.bnct-slot-booked { background:var(--bn-bg-alt); color:var(--bn-muted); cursor:not-allowed; border-color:var(--bn-border); text-decoration:line-through; }
.bnct-slots-placeholder { color:var(--bn-muted); font-size:14px; grid-column:1/-1; text-align:center; padding:20px 0; }
.bnct-slots-loading { display:flex; align-items:center; gap:8px; color:var(--bn-muted); font-size:14px; padding:10px 0; }
.bnct-slots-loading .bnct-spin { width:20px; height:20px; }

/* Booking summary */
.bnct-summary { background:var(--bn-bg-alt); border:1.5px solid var(--bn-border); border-radius:10px; padding:20px; margin-bottom:20px; }
.bnct-summary-row { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid var(--bn-border); font-size:14px; }
.bnct-summary-row:last-child { border-bottom:none; }
.bnct-summary-label { color:var(--bn-muted); font-weight:600; }
.bnct-summary-value { color:var(--bn-text); font-weight:700; text-align:right; }
.bnct-summary-price { color:var(--bn-primary); font-size:18px; }
.bnct-checkbox-label {
    display:flex; align-items:center; gap:12px;
    font-size:14px; cursor:pointer; color:var(--bn-muted);
    background:var(--bn-bg-alt); border:1.5px solid var(--bn-border);
    border-radius:8px; padding:14px 16px; width:100%;
    transition:border-color .15s;
}
.bnct-checkbox-label:hover { border-color:var(--bn-primary); }
.bnct-checkbox-label input[type=checkbox] {
    width:20px; height:20px; flex-shrink:0;
    accent-color:var(--bn-primary); cursor:pointer;
}

/* Success panel */
.bnct-success-panel { text-align:center; padding:20px 0; }
.bnct-success-icon { font-size:56px; margin-bottom:12px; }
.bnct-success-panel h3 { font-size:24px; font-weight:800; color:var(--bn-primary); margin:0 0 10px; }
.bnct-success-panel p { color:var(--bn-muted); font-size:15px; margin:0 0 10px; }
.bnct-success-actions { display:flex; gap:12px; justify-content:center; margin-top:20px; flex-wrap:wrap; }

/* ── SIDEBAR ──────────────────────────────── */
.bnct-sidebar-card { background:var(--bn-bg); border:1.5px solid var(--bn-border); border-radius:var(--bn-radius); padding:22px; margin-bottom:16px; }
.bnct-sidebar-card h3 { font-size:16px; font-weight:700; color:var(--bn-primary); margin:0 0 14px; }
.bnct-why-list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.bnct-why-list li { display:flex; gap:10px; align-items:flex-start; font-size:14px; font-weight:500; color:var(--bn-text); }
.bnct-why-list span { font-size:18px; flex-shrink:0; }
.bnct-contact-sidebar p { font-size:14px; color:var(--bn-muted); margin:0 0 12px; }
.bnct-contact-sidebar .bnct-btn { margin-bottom:10px; }
.bnct-sidebar-email { text-align:center; margin-top:8px !important; }
.bnct-sidebar-email a { color:var(--bn-primary); font-size:13px; text-decoration:none; }
.bnct-hours-table { width:100%; border-collapse:collapse; font-size:14px; }
.bnct-hours-table td { padding:7px 0; border-bottom:1px solid var(--bn-border); }
.bnct-hours-table td:first-child { font-weight:600; color:var(--bn-text); }
.bnct-hours-table td:last-child { text-align:right; color:var(--bn-muted); }
.bnct-closed-row td { color:#e74c3c !important; }
.bnct-hours-table tr:last-child td { border-bottom:none; }

/* ── RESPONSIVE ───────────────────────────── */
@media (max-width:900px) {
    .bnct-contact-layout { grid-template-columns:1fr; }
    .bnct-booking-layout { grid-template-columns:1fr; }
    .bnct-booking-sidebar { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
    .bnct-booking-sidebar .bnct-sidebar-card { margin-bottom:0; }
}
@media (max-width:640px) {
    .bnct-hero { padding:44px 16px 36px; }
    .bnct-main { padding:24px 14px 48px; }
    .bnct-form-card { padding:20px; }
    .bnct-row { grid-template-columns:1fr; }
    .bnct-steps { gap:0; }
    .bnct-step-lbl { display:none; }
    .bnct-consult-type-wrap { grid-template-columns:1fr 1fr; }
    .bnct-slots-grid { grid-template-columns:repeat(3,1fr); }
    .bnct-booking-sidebar { grid-template-columns:1fr; }
    .bnct-step-nav { flex-direction:column; }
    .bnct-step-nav .bnct-btn { width:100%; }
}
@media (max-width:400px) {
    .bnct-slots-grid { grid-template-columns:repeat(2,1fr); }
    .bnct-hero-fees { flex-direction:column; align-items:center; }
}
