/* ============================================================
   CITS Car Tools — Premium Page Layout  v2.0.0
   Per-tool landing page: hero + two-column body + sidebar
   ============================================================ */

/* ── Page wrap ────────────────────────────────────────────── */
.cits-page-wrap {
    font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif !important;
    -webkit-font-smoothing: antialiased !important;
    color: #1e293b !important;
    margin: -20px -20px 0 !important; /* bleed past theme content padding */
}
.cits-page-wrap *,
.cits-page-wrap *::before,
.cits-page-wrap *::after { box-sizing: border-box !important; }

/* ── HERO ─────────────────────────────────────────────────── */
.cits-hero {
    position: relative !important;
    background: linear-gradient(135deg, #0f172a 0%, #1a2744 50%, #0f172a 100%) !important;
    padding: 52px 40px 52px !important;
    overflow: hidden !important;
}

/* Decorative radial glow */
.cits-hero-glow {
    position: absolute !important;
    top: -80px !important;
    right: -80px !important;
    width: 420px !important;
    height: 420px !important;
    background: radial-gradient(circle, rgba(230,57,70,.18) 0%, transparent 65%) !important;
    pointer-events: none !important;
}

.cits-hero-inner {
    max-width: 1140px !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 28px !important;
    position: relative !important;
    z-index: 1 !important;
}

/* Icon box */
.cits-hero-icon-box {
    width: 80px !important;
    height: 80px !important;
    min-width: 80px !important;
    background: linear-gradient(145deg, #e63946, #b81c28) !important;
    border-radius: 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 8px 32px rgba(230,57,70,.45), inset 0 1px 0 rgba(255,255,255,.2) !important;
    flex-shrink: 0 !important;
}
.cits-hero-svg {
    width: 40px !important;
    height: 40px !important;
    color: #fff !important;
    display: block !important;
}

/* Badges */
.cits-hero-badges {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    margin-bottom: 12px !important;
    align-items: center !important;
}
.cits-hero-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 4px 11px !important;
    border-radius: 100px !important;
    letter-spacing: .4px !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
}
.cits-badge-svg {
    width: 12px !important;
    height: 12px !important;
    display: block !important;
}
.cits-hero-badge-green {
    background: rgba(16,185,129,.18) !important;
    color: #6ee7b7 !important;
    border: 1px solid rgba(16,185,129,.3) !important;
}
.cits-hero-badge-blue {
    background: rgba(99,102,241,.18) !important;
    color: #a5b4fc !important;
    border: 1px solid rgba(99,102,241,.3) !important;
}
.cits-hero-badge-halal {
    background: rgba(5,150,105,.18) !important;
    color: #6ee7b7 !important;
    border: 1px solid rgba(5,150,105,.3) !important;
}

/* Hero title */
.cits-hero-title {
    font-size: clamp(24px, 3.5vw, 36px) !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 8px !important;
    line-height: 1.15 !important;
    letter-spacing: -.5px !important;
    padding: 0 !important;
    border: none !important;
}
.cits-hero-tagline {
    font-size: 16px !important;
    color: rgba(255,255,255,.6) !important;
    margin: 0 !important;
    line-height: 1.55 !important;
    font-weight: 400 !important;
    max-width: 600px !important;
}

/* ── Page body (two-column) ───────────────────────────────── */
.cits-page-body {
    display: flex !important;
    gap: 32px !important;
    align-items: flex-start !important;
    max-width: 1140px !important;
    margin: 0 auto !important;
    padding: 32px 24px 48px !important;
}

/* Main content column */
.cits-page-content {
    flex: 1 1 0 !important;
    min-width: 0 !important;
}

/* Sidebar */
.cits-page-sidebar {
    width: 300px !important;
    flex-shrink: 0 !important;
}
.cits-sidebar-sticky {
    position: sticky !important;
    top: 80px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
    align-items: center !important;
}

/* ── Breadcrumb ───────────────────────────────────────────── */
.cits-breadcrumb {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    font-size: 12.5px !important;
    color: #94a3b8 !important;
    margin-bottom: 20px !important;
    padding: 0 !important;
    list-style: none !important;
}
.cits-breadcrumb a {
    color: #64748b !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: color .15s !important;
}
.cits-breadcrumb a:hover { color: #e63946 !important; }
.cits-breadcrumb span[aria-current="page"] {
    color: #1e293b !important;
    font-weight: 600 !important;
}

/* ── Ad units ─────────────────────────────────────────────── */
.cits-ad-unit {
    text-align: center !important;
    margin: 20px auto !important;
    display: block !important;
}
.cits-ad-placeholder {
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    background: #f8fafc !important;
    border: 2px dashed #e2e8f0 !important;
    border-radius: 8px !important;
    color: #94a3b8 !important;
    gap: 4px !important;
    max-width: 100% !important;
}
.cits-ad-placeholder span {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #cbd5e1 !important;
    font-family: monospace !important;
}
.cits-ad-placeholder small {
    font-size: 10px !important;
    color: #e2e8f0 !important;
}

/* ── Intro text ───────────────────────────────────────────── */
.cits-page-intro {
    margin-bottom: 24px !important;
    padding: 20px 24px !important;
    background: #f8fafc !important;
    border-left: 3px solid #e63946 !important;
    border-radius: 0 10px 10px 0 !important;
}
.cits-page-intro-p {
    font-size: 15px !important;
    line-height: 1.78 !important;
    color: #475569 !important;
    margin: 0 0 12px !important;
    padding: 0 !important;
}
.cits-page-intro-p:last-child { margin-bottom: 0 !important; }

/* ── Tool embed ───────────────────────────────────────────── */
.cits-tool-embed { margin-bottom: 8px !important; }

/* ── Sections ─────────────────────────────────────────────── */
.cits-page-section {
    margin: 36px 0 !important;
    padding: 28px !important;
    background: #fff !important;
    border: 1px solid rgba(15,23,42,.08) !important;
    border-radius: 16px !important;
    box-shadow: 0 1px 3px rgba(15,23,42,.05), 0 4px 16px rgba(15,23,42,.04) !important;
}

/* Section H2 with left bar */
.cits-page-h2 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    margin: 0 0 20px !important;
    padding: 0 0 0 14px !important;
    border: none !important;
    border-left: 4px solid #e63946 !important;
    line-height: 1.3 !important;
    letter-spacing: -.2px !important;
    display: block !important;
}

/* ── How to use steps ─────────────────────────────────────── */
.cits-page-steps {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 20px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}
.cits-page-steps li {
    display: flex !important;
    align-items: flex-start !important;
    gap: 14px !important;
    font-size: 14.5px !important;
    line-height: 1.65 !important;
    color: #374151 !important;
}
.cits-step-num {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    background: linear-gradient(145deg, #e63946, #b81c28) !important;
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    border-radius: 50% !important;
    margin-top: 1px !important;
    box-shadow: 0 2px 8px rgba(230,57,70,.3) !important;
    flex-shrink: 0 !important;
}

/* Tip box */
.cits-page-tip {
    display: flex !important;
    gap: 14px !important;
    align-items: flex-start !important;
    background: linear-gradient(135deg, #fffdf0, #fff9e6) !important;
    border: 1px solid #fde68a !important;
    border-radius: 10px !important;
    padding: 16px 18px !important;
    margin-top: 4px !important;
}
.cits-page-tip-icon {
    flex-shrink: 0 !important;
    margin-top: 2px !important;
}
.cits-tip-svg {
    width: 20px !important;
    height: 20px !important;
    color: #d97706 !important;
    display: block !important;
}
.cits-page-tip strong {
    display: block !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #92400e !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    margin-bottom: 4px !important;
}
.cits-page-tip p {
    font-size: 13.5px !important;
    line-height: 1.7 !important;
    color: #78350f !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── FAQ ──────────────────────────────────────────────────── */
.cits-faq-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}
.cits-faq-item {
    border: 1px solid rgba(15,23,42,.08) !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    transition: border-color .2s, box-shadow .2s !important;
    background: #fff !important;
}
.cits-faq-item[open] {
    border-color: rgba(230,57,70,.3) !important;
    box-shadow: 0 2px 12px rgba(230,57,70,.07) !important;
}
.cits-faq-q {
    cursor: pointer !important;
    padding: 15px 18px !important;
    font-size: 14.5px !important;
    font-weight: 600 !important;
    color: #1e293b !important;
    list-style: none !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 12px !important;
    user-select: none !important;
    margin: 0 !important;
    background: none !important;
    border: none !important;
    transition: color .15s !important;
}
.cits-faq-q::-webkit-details-marker,
.cits-faq-q::marker { display: none !important; }
.cits-faq-q::after {
    content: '+' !important;
    font-size: 20px !important;
    color: #e63946 !important;
    font-weight: 300 !important;
    flex-shrink: 0 !important;
    line-height: 1 !important;
    width: 20px !important;
    text-align: center !important;
}
.cits-faq-item[open] .cits-faq-q { color: #e63946 !important; }
.cits-faq-item[open] .cits-faq-q::after { content: '−' !important; }
.cits-faq-a-wrap {
    padding: 0 18px 16px !important;
    border-top: 1px solid rgba(15,23,42,.06) !important;
}
.cits-faq-a {
    font-size: 14px !important;
    line-height: 1.75 !important;
    color: #475569 !important;
    margin: 14px 0 0 !important;
    padding: 0 !important;
}

/* ── Related tools ────────────────────────────────────────── */
.cits-page-related { margin: 36px 0 !important; }
.cits-related-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 14px !important;
}
.cits-related-card {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 16px !important;
    background: #fff !important;
    border: 1px solid rgba(15,23,42,.08) !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    color: inherit !important;
    transition: all .2s !important;
    box-shadow: 0 1px 3px rgba(15,23,42,.04) !important;
}
.cits-related-card:hover {
    border-color: rgba(230,57,70,.3) !important;
    box-shadow: 0 4px 20px rgba(230,57,70,.1) !important;
    transform: translateY(-2px) !important;
    text-decoration: none !important;
    color: inherit !important;
}
.cits-related-icon {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    background: linear-gradient(145deg, #e63946, #b81c28) !important;
    border-radius: 12px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 3px 10px rgba(230,57,70,.28) !important;
    flex-shrink: 0 !important;
    transition: box-shadow .2s !important;
}
.cits-related-card:hover .cits-related-icon {
    box-shadow: 0 5px 18px rgba(230,57,70,.42) !important;
}
.cits-related-svg {
    width: 22px !important;
    height: 22px !important;
    color: #fff !important;
    display: block !important;
}
.cits-related-card strong {
    font-size: 13.5px !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    display: block !important;
    margin-bottom: 3px !important;
    line-height: 1.3 !important;
}
.cits-related-card p {
    font-size: 12px !important;
    color: #64748b !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.45 !important;
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 960px) {
    .cits-page-wrap { margin: -20px -12px 0 !important; }
    .cits-hero { padding: 36px 24px !important; }
    .cits-page-body {
        flex-direction: column !important;
        gap: 24px !important;
        padding: 24px 16px 40px !important;
    }
    .cits-page-sidebar {
        width: 100% !important;
        order: 10 !important;
    }
    .cits-sidebar-sticky {
        position: static !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
    }
    .cits-related-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 600px) {
    .cits-hero { padding: 28px 18px !important; }
    .cits-hero-inner { gap: 16px !important; }
    .cits-hero-icon-box { width: 60px !important; height: 60px !important; min-width: 60px !important; border-radius: 16px !important; }
    .cits-hero-svg { width: 30px !important; height: 30px !important; }
    .cits-hero-title { font-size: 22px !important; }
    .cits-hero-tagline { font-size: 14px !important; display: none !important; }
    .cits-page-section { padding: 20px 16px !important; border-radius: 12px !important; }
    .cits-related-grid { grid-template-columns: 1fr !important; }
    .cits-page-steps li { gap: 10px !important; }
    .cits-ad-placeholder { max-width: 100% !important; }
    .cits-faq-q { font-size: 13.5px !important; padding: 13px 14px !important; }
}

@media print {
    .cits-page-sidebar, .cits-ad-unit, .cits-page-related,
    .cits-hero-glow { display: none !important; }
    .cits-hero { background: #f8f8f8 !important; padding: 20px !important; }
    .cits-hero-title { color: #000 !important; }
    .cits-page-body { flex-direction: column !important; }
    .cits-page-content { width: 100% !important; }
}

/* ============================================================
   Hub Page — /car-tools/ tool showcase
   ============================================================ */

/* ── Hub hero ──────────────────────────────────────────────── */
.cits-hub-hero {
    text-align: center !important;
    padding: 72px 40px 80px !important;
    background: linear-gradient(135deg, #0a0f1e 0%, #111827 40%, #1a0a0e 100%) !important;
}

/* Dot-grid texture overlay */
.cits-hub-hero::after {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background-image: radial-gradient(rgba(255,255,255,.055) 1px, transparent 1px) !important;
    background-size: 28px 28px !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

/* Two large glows for depth */
.cits-hub-hero-glow2 {
    position: absolute !important;
    bottom: -40px !important;
    left: -60px !important;
    width: 480px !important;
    height: 480px !important;
    background: radial-gradient(circle, rgba(230,57,70,.14) 0%, transparent 65%) !important;
    pointer-events: none !important;
    z-index: 0 !important;
}
.cits-hub-hero .cits-hero-glow {
    width: 560px !important;
    height: 560px !important;
    top: -120px !important;
    right: -100px !important;
    background: radial-gradient(circle, rgba(230,57,70,.22) 0%, transparent 60%) !important;
}

.cits-hub-hero-inner {
    max-width: 720px !important;
    margin: 0 auto !important;
    position: relative !important;
    z-index: 1 !important;
}

/* Eyebrow: small pill badge */
.cits-hub-eyebrow {
    display: inline-block !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    color: rgba(255,255,255,.55) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 100px !important;
    padding: 4px 14px !important;
    margin: 0 0 22px !important;
    background: rgba(255,255,255,.04) !important;
}

.cits-hub-title {
    font-size: clamp(30px, 4.5vw, 54px) !important;
    font-weight: 900 !important;
    color: #fff !important;
    line-height: 1.1 !important;
    margin: 0 0 18px !important;
    letter-spacing: -.8px !important;
    /* Subtle gradient on text */
    background: linear-gradient(180deg, #ffffff 60%, rgba(255,255,255,.75) 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
.cits-hub-sub {
    font-size: 17px !important;
    color: rgba(255,255,255,.55) !important;
    max-width: 560px !important;
    margin: 0 auto 32px !important;
    line-height: 1.7 !important;
}

/* Hero badges row */
.cits-hub-hero .cits-hero-badges {
    display: flex !important;
    gap: 8px !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
}

/* ── Hub body ──────────────────────────────────────────────── */
.cits-hub-body {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 48px 24px 72px !important;
}

/* 4-column grid */
.cits-hub-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 20px !important;
}

/* ── Card ──────────────────────────────────────────────────── */
.cits-hub-card {
    display: flex !important;
    flex-direction: column !important;
    background: #fff !important;
    border: 1.5px solid #e8ecf0 !important;
    border-radius: 18px !important;
    padding: 26px 22px 22px !important;
    text-decoration: none !important;
    color: #1e293b !important;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
    position: relative !important;
    overflow: hidden !important;
}

/* Top accent line — revealed on hover */
.cits-hub-card::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    height: 3px !important;
    background: linear-gradient(90deg, #e63946, #ff6b6b) !important;
    opacity: 0 !important;
    transition: opacity .22s !important;
    border-radius: 18px 18px 0 0 !important;
}
.cits-hub-card::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(160deg, rgba(230,57,70,.03) 0%, transparent 55%) !important;
    opacity: 0 !important;
    transition: opacity .22s !important;
    pointer-events: none !important;
}
.cits-hub-card:hover {
    border-color: rgba(230,57,70,.28) !important;
    box-shadow: 0 12px 40px rgba(230,57,70,.1), 0 3px 10px rgba(0,0,0,.07) !important;
    transform: translateY(-5px) !important;
    text-decoration: none !important;
    color: #1e293b !important;
}
.cits-hub-card:hover::after  { opacity: 1 !important; }
.cits-hub-card:hover::before { opacity: 1 !important; }

/* Icon */
.cits-hub-card-icon {
    width: 54px !important;
    height: 54px !important;
    background: linear-gradient(145deg, #e63946, #b81c28) !important;
    border-radius: 15px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 18px !important;
    box-shadow: 0 4px 18px rgba(230,57,70,.35), inset 0 1px 0 rgba(255,255,255,.18) !important;
    flex-shrink: 0 !important;
}
.cits-hub-icon-svg { width: 26px !important; height: 26px !important; color: #fff !important; }

/* Text */
.cits-hub-card-body { flex: 1 !important; }
.cits-hub-card-title {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin: 0 0 8px !important;
    line-height: 1.3 !important;
}
.cits-hub-card-desc {
    font-size: 13px !important;
    color: #64748b !important;
    line-height: 1.6 !important;
    margin: 0 !important;
}

/* CTA button — text + arrow */
.cits-hub-card-cta {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    margin-top: 20px !important;
    padding: 9px 16px !important;
    border-radius: 10px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #e63946 !important;
    background: rgba(230,57,70,.06) !important;
    border: 1.5px solid rgba(230,57,70,.18) !important;
    transition: all .22s ease !important;
}
.cits-hub-card:hover .cits-hub-card-cta {
    background: #e63946 !important;
    color: #fff !important;
    border-color: #e63946 !important;
    gap: 11px !important;
}
.cits-hub-cta-text { line-height: 1 !important; }
.cits-hub-cta-arrow {
    width: 14px !important;
    height: 14px !important;
    flex-shrink: 0 !important;
    transition: transform .22s !important;
}
.cits-hub-card:hover .cits-hub-cta-arrow { transform: translateX(3px) !important; }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1100px) {
    .cits-hub-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
}
@media (max-width: 600px) {
    .cits-hub-hero { padding: 52px 20px 60px !important; }
    .cits-hub-title { letter-spacing: -.4px !important; }
    .cits-hub-sub { font-size: 15px !important; }
    .cits-hub-grid { grid-template-columns: 1fr !important; gap: 12px !important; }
    .cits-hub-body { padding: 28px 16px 48px !important; }
    .cits-hub-card { flex-direction: row !important; align-items: flex-start !important; gap: 14px !important; padding: 16px !important; }
    .cits-hub-card-icon { margin-bottom: 0 !important; }
    .cits-hub-card-cta { display: none !important; }
}
