/* Counsellor.com.au V1 upgrade. Keeps the original header/left menu but removes the old postcode/type search. */
.counsellor-site { background:#eef6f7; }
.counsellor-site a { color:#076d7d; }
.counsellor-site a:hover { color:#034c57; }
.ap-main-content { line-height:1.58; }
.ap-main-content h1, .ap-main-content h2 { color:#076d7d; }
.ap-main-content h1 { font-size:30px; line-height:1.15; margin:0 0 16px; }
.ap-main-content h2 { margin-top:26px; }
.ap-main-content h3 { color:#2f5961; }
.ap-main-content p { margin:0 0 14px; }
#sidebar2.ap-side-panel { background:transparent; width:250px; margin-right:33px; }
.side-card { background:#fff; border:1px solid #d7e8ea; border-radius:12px; padding:14px; margin:0 0 14px; box-shadow:0 2px 8px rgba(0,0,0,.05); }
.side-card h3 { margin:0 0 8px; color:#076d7d; font-size:18px; }
.side-card p { margin:0 0 10px; color:#555; font-size:13px; line-height:1.45; }
.side-primary { background:#e7f6f8; border-color:#a9d8dd; }
.soft-warning { background:#fff9ec; border-color:#efd8a1; }
.side-button, .button-link, .cta-button { display:inline-block; background:#076d7d; color:#fff !important; text-decoration:none; padding:10px 13px; border-radius:8px; font-weight:bold; }
.side-button:hover, .button-link:hover, .cta-button:hover { background:#034c57; color:#fff !important; }
.new-nav-block { margin-top:18px; width:237px; background:#f6fbfc; border:1px solid #d7e8ea; border-radius:12px; overflow:hidden; }
.new-nav-block h3 { margin:0; padding:12px; background:#076d7d; color:#fff; font-size:17px; }
.new-nav-block a { display:block; padding:10px 12px; border-top:1px solid #d7e8ea; text-decoration:none; color:#034c57; background:#fff; }
.new-nav-block a:hover { background:#e7f6f8; }
.hero-panel { background:linear-gradient(180deg,#e7f6f8,#fff); border:1px solid #c6e1e5; border-radius:16px; padding:20px; margin:0 0 22px; }
.hero-panel .eyebrow { text-transform:uppercase; letter-spacing:.08em; color:#50777e; font-size:12px; font-weight:bold; }
.feature-grid, .topic-grid, .location-grid, .guide-grid, .seminar-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; margin:18px 0; }
.feature-card, .topic-card, .location-card, .guide-card, .seminar-card, .profile-card { background:#fff; border:1px solid #d7e8ea; border-radius:14px; padding:16px; box-shadow:0 2px 8px rgba(0,0,0,.04); }
.feature-card h3, .topic-card h3, .location-card h3, .guide-card h3, .seminar-card h3, .profile-card h3 { margin-top:0; color:#076d7d; }
.notice-box { background:#fff9ec; border:1px solid #efd8a1; border-radius:12px; padding:14px; margin:18px 0; }
.ok-box { background:#ecf9f2; border:1px solid #b8dfc7; border-radius:12px; padding:14px; margin:18px 0; }
.form-panel { background:#fff; border:1px solid #d7e8ea; border-radius:14px; padding:18px; margin:18px 0; }
.form-row { margin-bottom:12px; }
.form-row label { display:block; font-weight:bold; color:#2f5961; margin-bottom:5px; }
.form-row input, .form-row select, .form-row textarea { width:96%; max-width:520px; padding:10px; border:1px solid #bed5d9; border-radius:8px; font-size:15px; }
.form-row textarea { min-height:120px; }
button.primary-submit { background:#076d7d; color:#fff; border:0; padding:11px 17px; border-radius:8px; font-weight:bold; cursor:pointer; }
button.primary-submit:hover { background:#034c57; }
.ai-chat-shell { background:#fff; border:1px solid #c6e1e5; border-radius:16px; overflow:hidden; margin:18px 0; }
.ai-toolbar { display:flex; gap:8px; flex-wrap:wrap; align-items:center; padding:12px; background:#e7f6f8; border-bottom:1px solid #c6e1e5; }
.ai-toolbar select, .ai-toolbar button { padding:8px 10px; border-radius:8px; border:1px solid #b8d7dc; }
.ai-messages { min-height:260px; max-height:420px; overflow:auto; padding:14px; background:#fbfefe; }
.ai-msg { margin:0 0 12px; padding:10px 12px; border-radius:12px; max-width:92%; white-space:pre-wrap; }
.ai-user { margin-left:auto; background:#e5f1ff; border:1px solid #c7dff8; }
.ai-bot { background:#f2f6f7; border:1px solid #dbe9eb; }
.ai-input { display:flex; gap:8px; padding:12px; border-top:1px solid #c6e1e5; }
.ai-input textarea { flex:1; min-height:52px; border:1px solid #b8d7dc; border-radius:8px; padding:10px; }
.ai-input button { background:#076d7d; color:#fff; border:0; border-radius:8px; padding:0 14px; font-weight:bold; }
.avatar-row { display:flex; gap:12px; flex-wrap:wrap; }
.avatar-card { width:130px; background:#fff; border:1px solid #d7e8ea; border-radius:14px; padding:10px; text-align:center; cursor:pointer; }
.avatar-card img { width:70px; height:70px; border-radius:50%; display:block; margin:0 auto 6px; }
.avatar-card.active { outline:3px solid #88cbd4; }
.directory-filter { display:flex; gap:8px; flex-wrap:wrap; margin:14px 0; }
.directory-filter input, .directory-filter select { padding:9px; border:1px solid #bed5d9; border-radius:8px; }
.profile-meta { color:#666; font-size:13px; }
.breadcrumb { color:#777; font-size:13px; }
.footer-small { font-size:12px; color:#555; }
@media (max-width: 900px) {
  .twoColFixLtHdr #container, .twoColFixLtHdr #header, .twoColFixLtHdr #footer, #foot { width:100%; }
  .twoColFixLtHdr #sidebar1, #sidebar2.ap-side-panel { float:none; width:auto; margin:0 12px 12px; padding-left:0; }
  .twoColFixLtHdr #mainContent { margin:0; padding:20px 14px; background:#fff; }
  .legacy-nav, .new-nav-block { width:100%; max-width:237px; margin-left:auto; margin-right:auto; }
  .feature-grid, .topic-grid, .location-grid, .guide-grid, .seminar-grid { grid-template-columns:1fr; }
  .footer-tiles { display:none; }
}


/* Counsellor.com.au V2 additions: state-first location flow, tighter left-menu new section links, and improved AI operator presentation. */
.new-nav-inline { width:237px; background:#f6fbfc; border-left:1px solid #d7e8ea; border-right:1px solid #d7e8ea; border-bottom:1px solid #d7e8ea; box-sizing:border-box; }
.new-nav-inline h3 { margin:0; padding:11px 12px; background:#076d7d; color:#fff; font-size:16px; line-height:1.1; }
.new-nav-inline a { display:block; padding:9px 12px; border-top:1px solid #d7e8ea; text-decoration:none; color:#034c57; background:#fff; font-size:13px; line-height:1.25; }
.new-nav-inline a:hover { background:#e7f6f8; }
.location-state-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; margin:18px 0; }
.state-card { background:#fff; border:1px solid #cfe3e7; border-radius:16px; padding:18px; box-shadow:0 2px 8px rgba(0,0,0,.04); }
.state-card h2, .state-card h3 { margin-top:0; color:#076d7d; }
.state-card .state-count { display:inline-block; background:#e7f6f8; border:1px solid #b8d7dc; border-radius:999px; padding:5px 10px; font-size:12px; color:#2f5961; margin-bottom:10px; }
.city-pill-list { display:flex; gap:8px; flex-wrap:wrap; margin:12px 0; }
.city-pill-list a { display:inline-block; padding:7px 10px; border-radius:999px; background:#eef6f7; border:1px solid #cfe3e7; text-decoration:none; font-size:13px; color:#034c57; }
.city-pill-list a:hover { background:#dff0f3; }
.location-actions { display:flex; gap:8px; flex-wrap:wrap; margin:12px 0 0; }
.location-actions a { display:inline-block; padding:9px 11px; border-radius:8px; background:#076d7d; color:#fff !important; text-decoration:none; font-weight:bold; font-size:13px; }
.location-actions a.secondary { background:#3f737b; }
.selector-panel { background:#fff; border:1px solid #d7e8ea; border-radius:14px; padding:16px; margin:18px 0; }
.selector-panel .form-row select { width:98%; }
.service-link-panel { background:#f6fbfc; border:1px solid #d7e8ea; border-radius:14px; padding:16px; margin:18px 0; }
.service-link-panel h3 { margin-top:0; }
.service-link-panel ul { columns:2; padding-left:20px; }
.avatar-card { transition:transform .12s ease, box-shadow .12s ease; }
.avatar-card:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.08); }
.avatar-card img { background:#e7f6f8; object-fit:cover; }
.voice-note { font-size:13px; color:#4f686d; }
.form-help { color:#60777c; font-size:13px; margin-top:4px; }
@media (max-width: 900px) {
  .location-state-grid { grid-template-columns:1fr; }
  .service-link-panel ul { columns:1; }
  .new-nav-inline { width:100%; max-width:237px; margin-left:auto; margin-right:auto; }
}
