/*
Theme Name:   QuickComply Child
Theme URI:    https://www.quickcomply.com.au
Description:  Divi child theme for QuickComply — ISO Management System Consulting & Auditing
Author:       QuickComply Pty Ltd
Author URI:   https://www.quickcomply.com.au
Template:     Divi
Version:      1.0.0
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  quickcomply-child
*/

/* ============================================================
   BRAND TOKENS
   ============================================================ */
:root {
  --qc-cyan:        #335b74;
  --qc-cyan-dark:   #254a60;
  --qc-cyan-light:  #e8f0f5;
  --qc-cyan-mid:    #c2d6e2;
  --qc-slate:       #454b4f;
  --qc-slate-light: #f0f1f2;
  --qc-green:       #47ba5b;
  --qc-green-dark:  #2e8c3f;
  --qc-green-light: #eaf8ec;
  --qc-white:       #ffffff;
  --qc-text:        #454b4f;
  --qc-text-muted:  #6b7280;
  --qc-border:      #e2e8ed;
  --qc-radius:      6px;
  --qc-radius-lg:   10px;
}

/* ============================================================
   GLOBAL RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
}

body {
  font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--qc-text);
  background: #ffffff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  color: var(--qc-slate);
  font-weight: 600;
  line-height: 1.25;
}

h1 { font-size: 2.25rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.05rem; }

p {
  color: var(--qc-text-muted);
  line-height: 1.75;
  margin-bottom: 1rem;
}

a {
  color: var(--qc-green);
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: var(--qc-green-dark);
  text-decoration: underline;
}

/* ============================================================
   DIVI OVERRIDES — GLOBAL
   ============================================================ */

/* Primary button */
.et_pb_button,
.et_pb_button_module_wrapper .et_pb_button {
  background-color: var(--qc-cyan) !important;
  border-color: var(--qc-cyan) !important;
  color: #fff !important;
  border-radius: var(--qc-radius) !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  padding: 0.75rem 1.75rem !important;
  letter-spacing: 0.02em;
  transition: background-color 0.2s ease, border-color 0.2s ease !important;
}

.et_pb_button:hover,
.et_pb_button_module_wrapper .et_pb_button:hover {
  background-color: var(--qc-cyan-dark) !important;
  border-color: var(--qc-cyan-dark) !important;
}

/* Green accent button variant — add CSS class "qc-btn-green" in Divi */
.qc-btn-green .et_pb_button,
.et_pb_button.qc-btn-green {
  background-color: var(--qc-green) !important;
  border-color: var(--qc-green) !important;
}
.qc-btn-green .et_pb_button:hover,
.et_pb_button.qc-btn-green:hover {
  background-color: var(--qc-green-dark) !important;
  border-color: var(--qc-green-dark) !important;
}

/* Ghost / outline button — add CSS class "qc-btn-outline" in Divi */
.qc-btn-outline .et_pb_button,
.et_pb_button.qc-btn-outline {
  background-color: transparent !important;
  border-color: var(--qc-cyan) !important;
  color: var(--qc-cyan) !important;
}
.qc-btn-outline .et_pb_button:hover,
.et_pb_button.qc-btn-outline:hover {
  background-color: var(--qc-cyan-light) !important;
}

/* ============================================================
   DIVI HEADER
   ============================================================ */
#main-header,
.et-fixed-header {
  background-color: #ffffff !important;
  box-shadow: 0 1px 0 var(--qc-border) !important;
}

#main-header .et_pb_menu a,
#main-header .nav li a {
  color: var(--qc-slate) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  transition: color 0.2s ease !important;
}

#main-header .et_pb_menu a:hover,
#main-header .nav li a:hover,
#main-header .nav li.current-menu-item > a {
  color: var(--qc-cyan) !important;
}

/* Logo sizing */
#main-header .logo_container img,
#main-header #logo {
  max-height: 48px !important;
  width: auto !important;
}

/* ============================================================
   ACCENT BAR — add class "qc-accent-top" to a section
   ============================================================ */
.qc-accent-top {
  border-top: 3px solid transparent;
  border-image: linear-gradient(90deg, var(--qc-cyan) 0%, var(--qc-green) 100%) 1;
}

/* ============================================================
   SECTION HELPERS
   ============================================================ */

/* Light cyan tint background */
.qc-bg-cyan-light {
  background-color: var(--qc-cyan-light) !important;
}

/* Slate dark background (for CTA band) */
.qc-bg-slate {
  background-color: var(--qc-slate) !important;
}
.qc-bg-slate h1,
.qc-bg-slate h2,
.qc-bg-slate h3,
.qc-bg-slate p,
.qc-bg-slate .et_pb_text_inner {
  color: #fff !important;
}

/* Cyan dark background (for standards strip) */
.qc-bg-cyan {
  background-color: var(--qc-cyan) !important;
}
.qc-bg-cyan h1,
.qc-bg-cyan h2,
.qc-bg-cyan h3,
.qc-bg-cyan p,
.qc-bg-cyan .et_pb_text_inner {
  color: rgba(255,255,255,0.9) !important;
}

/* ============================================================
   SECTION LABELS (eyebrow text above headings)
   ============================================================ */
.qc-eyebrow {
  display: inline-block;
  font-size: 0.6875rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  color: var(--qc-green-dark) !important;
  margin-bottom: 0.375rem !important;
}

/* ============================================================
   STANDARD PILLS (tag-style badges)
   ============================================================ */
.qc-pill {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 4px 14px;
  border-radius: 20px;
  background: rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.92);
  border: 0.5px solid rgba(255,255,255,0.28);
  margin: 3px;
}

.qc-pill-green {
  background: var(--qc-green);
  color: #fff;
  border-color: var(--qc-green);
}

/* ============================================================
   SERVICE CARDS
   ============================================================ */
.qc-service-card {
  background: #fff;
  border: 1px solid var(--qc-border);
  border-radius: var(--qc-radius-lg);
  padding: 1.5rem;
  transition: border-color 0.2s ease, transform 0.2s ease;
  height: 100%;
}

.qc-service-card:hover {
  border-color: var(--qc-cyan);
  transform: translateY(-2px);
}

.qc-service-icon {
  width: 42px;
  height: 42px;
  background: var(--qc-cyan-light);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  font-size: 1.25rem;
  color: var(--qc-cyan);
}

.qc-service-card h3 {
  font-size: 1rem;
  margin-bottom: 0.5rem;
  color: var(--qc-slate);
}

.qc-service-card p {
  font-size: 0.8125rem;
  line-height: 1.65;
  margin-bottom: 0.75rem;
}

.qc-service-card a {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--qc-green);
}

/* ============================================================
   STANDARDS CARDS (left-border accent)
   ============================================================ */
.qc-std-card {
  background: #fff;
  border: 1px solid var(--qc-border);
  border-left: 3px solid var(--qc-cyan);
  border-radius: var(--qc-radius);
  padding: 1rem 1.125rem;
  transition: border-color 0.2s ease;
  height: 100%;
}

.qc-std-card:hover {
  border-color: var(--qc-cyan);
  border-left-color: var(--qc-green);
}

.qc-std-code {
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--qc-cyan);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 0.25rem;
}

.qc-std-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--qc-slate);
  margin-bottom: 0.375rem;
}

.qc-std-desc {
  font-size: 0.75rem;
  color: var(--qc-text-muted);
  line-height: 1.55;
}

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.qc-step {
  display: flex;
  gap: 1rem;
  padding: 1.125rem 0;
  border-bottom: 1px solid var(--qc-border);
}

.qc-step:last-child {
  border-bottom: none;
}

.qc-step-num {
  width: 34px;
  height: 34px;
  min-width: 34px;
  border-radius: 50%;
  background: var(--qc-cyan);
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}

.qc-step h4 {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--qc-slate);
  margin-bottom: 0.25rem;
}

.qc-step p {
  font-size: 0.8125rem;
  margin-bottom: 0;
  line-height: 1.65;
}

/* ============================================================
   WHY US CARDS
   ============================================================ */
.qc-why-card {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: 1rem;
  background: #fff;
  border: 1px solid var(--qc-border);
  border-radius: var(--qc-radius);
  height: 100%;
}

.qc-why-icon {
  width: 32px;
  min-width: 32px;
  height: 32px;
  background: var(--qc-green-light);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--qc-green-dark);
}

.qc-why-card h4 {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.2rem;
  color: var(--qc-slate);
}

.qc-why-card p {
  font-size: 0.75rem;
  margin-bottom: 0;
  line-height: 1.55;
}

/* ============================================================
   TRUST CHIPS (hero)
   ============================================================ */
.qc-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 2rem;
}

.qc-trust-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: var(--qc-text-muted);
  background: var(--qc-slate-light);
  border: 1px solid var(--qc-border);
  border-radius: 20px;
  padding: 5px 14px;
}

.qc-trust-chip .tick {
  color: var(--qc-green);
  font-weight: 700;
  font-size: 0.875rem;
}

/* ============================================================
   CONTACT SECTION
   ============================================================ */
.qc-contact-detail {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-size: 0.875rem;
  color: var(--qc-text-muted);
  margin-bottom: 0.75rem;
}

.qc-contact-note {
  margin-top: 1.25rem;
  padding: 1rem;
  background: var(--qc-cyan-light);
  border-left: 3px solid var(--qc-cyan);
  border-radius: 0 var(--qc-radius) var(--qc-radius) 0;
  font-size: 0.75rem;
  line-height: 1.65;
  color: var(--qc-slate);
}

/* Divi contact form overrides */
.et_pb_contact_form_container input,
.et_pb_contact_form_container textarea,
.et_pb_contact_form_container select {
  border: 1px solid var(--qc-border) !important;
  border-radius: var(--qc-radius) !important;
  font-size: 0.875rem !important;
  padding: 0.625rem 0.875rem !important;
}

.et_pb_contact_form_container input:focus,
.et_pb_contact_form_container textarea:focus {
  border-color: var(--qc-cyan) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(51, 91, 116, 0.12) !important;
}

.et_pb_contact_submit {
  background-color: var(--qc-cyan) !important;
  border-color: var(--qc-cyan) !important;
  color: #fff !important;
  border-radius: var(--qc-radius) !important;
  font-weight: 600 !important;
}

.et_pb_contact_submit:hover {
  background-color: var(--qc-cyan-dark) !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
#main-footer {
  background-color: var(--qc-slate) !important;
}

#main-footer .footer-widget h4,
#main-footer .footer-widget .widget-title,
#main-footer .et_pb_widget h4 {
  color: #fff !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 1rem !important;
}

#main-footer .footer-widget li,
#main-footer .footer-widget p,
#main-footer .et_pb_widget li,
#main-footer .et_pb_widget p {
  color: rgba(255,255,255,0.65) !important;
  font-size: 0.8125rem !important;
}

#main-footer .footer-widget a,
#main-footer .et_pb_widget a {
  color: rgba(255,255,255,0.65) !important;
  transition: color 0.2s ease !important;
}

#main-footer .footer-widget a:hover,
#main-footer .et_pb_widget a:hover {
  color: var(--qc-green) !important;
  text-decoration: none !important;
}

#et-footer-nav {
  background-color: #333a3e !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
}

#et-footer-nav .bottom-nav a {
  color: rgba(255,255,255,0.5) !important;
  font-size: 0.75rem !important;
}

#et-footer-nav .bottom-nav a:hover {
  color: var(--qc-green) !important;
}

/* ============================================================
   GRADIENT ACCENT BAR UTILITY
   ============================================================ */
.qc-gradient-bar {
  height: 3px;
  background: linear-gradient(90deg, var(--qc-cyan) 0%, var(--qc-green) 100%);
  width: 100%;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  h1 { font-size: 1.875rem; }
  h2 { font-size: 1.5rem; }

  .qc-trust-row {
    gap: 0.375rem;
  }
}

@media (max-width: 767px) {
  h1 { font-size: 1.625rem; }
  h2 { font-size: 1.375rem; }

  .qc-contact-detail {
    font-size: 0.8125rem;
  }
}
