/* ============================================================
   AOC IT — site.css
   Mobile-first. Bootstrap grid handles columns.
   Custom styles for brand elements only.
   ============================================================ */

:root {
  --aoc-blue:      #1D4ED8;
  --aoc-blue-dark: #1E3A8A;
  --aoc-blue-light:#EFF6FF;
  --aoc-border:    #E5E7EB;
  --aoc-text-muted:#6B7280;
}

/* ── Navbar ───────────────────────────────────────────────── */
.aoc-navbar {
    background: #fff;
    border-bottom: 1px solid var(--aoc-border);
    padding-top: .875rem;
    padding-bottom: .875rem;
}

    /* Nav links */
    .aoc-navbar .nav-link {
        font-size: .9375rem;
        font-weight: 600;
        color: #1F2937;
        padding: .5rem .875rem;
        letter-spacing: .01em;
        transition: color .15s;
    }

        .aoc-navbar .nav-link:hover,
        .aoc-navbar .nav-link:focus {
            color: var(--aoc-blue);
        }

        .aoc-navbar .nav-link.dropdown-toggle::after {
            margin-left: .35rem;
            vertical-align: .15em;
            border-top-width: .35em;
        }

    /* Dropdown menu */
    .aoc-navbar .dropdown-menu {
        border: 1px solid var(--aoc-border);
        border-radius: 10px;
        box-shadow: 0 8px 24px rgba(0,0,0,.1);
        padding: .5rem;
        margin-top: .5rem;
        min-width: 200px;
    }

    .aoc-navbar .dropdown-item {
        font-size: .9rem;
        font-weight: 500;
        color: #374151;
        padding: .5rem .875rem;
        border-radius: 6px;
        transition: background .12s, color .12s;
    }

        .aoc-navbar .dropdown-item:hover,
        .aoc-navbar .dropdown-item:focus {
            background: var(--aoc-blue-light);
            color: var(--aoc-blue);
        }

    /* CTA button in nav */
    .aoc-navbar .btn-primary {
        font-size: .9rem;
        font-weight: 600;
        padding: .5rem 1.25rem;
        letter-spacing: .01em;
    }

    /* Active page indicator */
    .aoc-navbar .nav-link.active {
        color: var(--aoc-blue);
    }

.aoc-brand {
  display: flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
}

.aoc-logo-mark {
  width: 32px; height: 32px;
  background: var(--aoc-blue);
  color: #fff;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 700;
  flex-shrink: 0;
}

.aoc-brand-name {
  font-weight: 600;
  color: #111827;
  font-size: 1.25rem;
  /* hide full name on very small screens, show logo mark only */
}

@media (max-width: 400px) {
  .aoc-brand-name { display: none; }
}

/* ── Eyebrow label ────────────────────────────────────────── */
.aoc-eyebrow {
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--aoc-blue);
  margin-bottom: .5rem;
}

/* ── Hero ─────────────────────────────────────────────────── */
.aoc-hero-full {
    position: relative;
    min-height: 620px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/hero-bg.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    padding: 6rem 0 4rem;
}

.aoc-hero-full__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient( 105deg, rgba(10, 22, 60, 0.88) 0%, rgba(10, 22, 60, 0.65) 60%, rgba(10, 22, 60, 0.30) 100% );
    z-index: 0;
}

.aoc-hero-full__content {
    position: relative;
    z-index: 1;
}

.aoc-hero-full__heading {
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.15;
    margin-bottom: 1.25rem;
    letter-spacing: -.01em;
}

.aoc-hero-full__heading-accent {
    color: #60A5FA;
    display: inline-block;
}

.aoc-hero-full__sub {
    font-size: 1.125rem;
    color: rgba(255, 255, 255, 0.85);
    max-width: 580px;
    line-height: 1.7;
    margin-bottom: 0;
}

.aoc-eyebrow--light {
    color: rgba(255, 255, 255, 0.7);
}

@media (max-width: 767px) {
    .aoc-hero-full {
        min-height: 520px;
        padding: 5rem 0 3rem;
    }

    .aoc-hero-full__overlay {
        background: rgba(10, 22, 60, 0.80);
    }
}

@media (max-width: 575px) {
    .aoc-hero-full__heading {
        font-size: 1.875rem;
    }

    .aoc-hero-full__sub {
        font-size: 1rem;
    }
}

/* ── Stat grid ────────────────────────────────────────────── */
/* Stats row inside hero */
.aoc-hero-full__stat {
    display: flex;
    flex-direction: column;
    gap: .375rem;
    padding: 1rem 0;
}

.aoc-hero-full__stat-num {
    font-size: 2rem;
    font-weight: 800;
    color: #fff;
    line-height: 1;
}

.aoc-hero-full__stat-label {
    font-size: .875rem;
    color: rgba(255, 255, 255, 0.85);
    font-weight: 400;
}

/* Outline light button fix */
.aoc-hero-full .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.7);
    color: #fff;
}

    .aoc-hero-full .btn-outline-light:hover {
        background: #fff;
        color: var(--aoc-blue);
        border-color: #fff;
    }

/* ── Tech partner badges ──────────────────────────────────── */
.aoc-partner-badge {
  font-size: .8rem;
  font-weight: 600;
  color: var(--aoc-text-muted);
  padding: .3rem .7rem;
  border: 1px solid var(--aoc-border);
  border-radius: 5px;
  text-decoration: none;
  white-space: nowrap;
  transition: border-color .15s, color .15s;
}
.aoc-partner-badge:hover {
  border-color: var(--aoc-blue);
  color: var(--aoc-blue);
}

/* ── Stars ────────────────────────────────────────────────── */
.aoc-stars { color: #F59E0B; font-size: .9375rem; }

/* ── CTA band ─────────────────────────────────────────────── */
/*.aoc-cta-band { background: var(--aoc-blue); }*/
.aoc-cta-band {
    background: #F9FAFB;
    background-image: url('/images/licensed/cta-bg.jpg');
    background-size: cover;
    background-position: center;
    border-bottom: 1px solid var(--aoc-border);
    padding: 4rem 0;
}

/* ── Page hero (sub-pages) ────────────────────────────────── */
.aoc-page-hero { background: #F9FAFB; border-bottom: 1px solid var(--aoc-border); }
.aoc-page-hero a { color: var(--aoc-blue); }

    .aoc-page-hero .btn-primary {
        background: var(--aoc-blue);
        border-color: var(--aoc-blue);
        color: #fff;
    }

        .aoc-page-hero .btn-primary:hover {
            background: var(--aoc-blue-dark);
            border-color: var(--aoc-blue-dark);
            color: #fff;
        }

@media (max-width: 767px) {
  .aoc-page-hero { padding-top: 2rem; padding-bottom: 2rem; }
  .aoc-page-hero h1 { font-size: 1.625rem; }
}

/* ── Article summary pull-quote ───────────────────────────── */
.aoc-article-summary {
  border-left: 3px solid var(--aoc-blue);
  padding-left: 1rem;
  font-size: 1.0625rem;
  color: var(--aoc-text-muted);
}

/* ── Admin sidebar nav ────────────────────────────────────── */
.aoc-admin-body { background: #F3F4F6; }

.aoc-admin-shell {
  display: flex;
  min-height: 100vh;
}

.aoc-admin-sidebar {
  width: 220px;
  flex-shrink: 0;
  background: #111827;
  color: #D1D5DB;
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}

.aoc-admin-sidebar__brand {
  display: flex;
  align-items: center;
  gap: .625rem;
  padding: 1.25rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
  font-weight: 600;
  font-size: .9375rem;
  color: #fff;
}

.aoc-admin-sidebar__menu {
  list-style: none;
  padding: .5rem 0;
  margin: 0;
  flex: 1;
}

.aoc-admin-sidebar__menu li a {
  display: flex;
  align-items: center;
  gap: .625rem;
  padding: .625rem 1rem;
  font-size: .875rem;
  color: #9CA3AF;
  text-decoration: none;
  transition: background .12s, color .12s;
}

.aoc-admin-sidebar__menu li a:hover { background: rgba(255,255,255,.06); color: #fff; }
.aoc-admin-sidebar__menu li a.active { background: rgba(29,78,216,.35); color: #93C5FD; border-left: 3px solid var(--aoc-blue); }

.aoc-admin-main { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.aoc-admin-topbar {
  background: #fff;
  border-bottom: 1px solid var(--aoc-border);
  padding: 1rem 1.5rem;
}

.aoc-admin-content { padding: 1.5rem; flex: 1; }

.aoc-admin-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}

.aoc-admin-stat {
  background: #fff;
  border: 1px solid var(--aoc-border);
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
}

.aoc-admin-stat--alert { border-color: #FCA5A5; background: #FFF5F5; }
.aoc-admin-stat__num   { font-size: 2rem; font-weight: 700; color: #111827; line-height: 1; display: block; }
.aoc-admin-stat--alert .aoc-admin-stat__num { color: #B91C1C; }
.aoc-admin-stat__label { font-size: .8125rem; color: var(--aoc-text-muted); }
.aoc-admin-stat__link  { font-size: .8125rem; color: var(--aoc-blue); font-weight: 500; display: block; margin-top: .5rem; text-decoration: none; }

/* ── Footer ───────────────────────────────────────────────── */
.aoc-footer {
  background: #F9FAFB;
  border-top: 1px solid var(--aoc-border);
  padding: 3rem 0 1.5rem;
}

.aoc-footer a { color: var(--aoc-text-muted); text-decoration: none; display: block; margin-bottom: .375rem; line-height: 1.6; }
.aoc-footer a:hover { color: var(--aoc-blue); }

.aoc-footer-social { display: flex; gap: .5rem; margin-top: .75rem; flex-wrap: wrap; }
.aoc-footer-social a {
  display: inline-block;
  font-size: .75rem; font-weight: 700;
  padding: .25rem .5rem;
  border: 1px solid var(--aoc-border);
  border-radius: 4px;
  margin-bottom: 0;
}

.aoc-solution-card {
    position: relative;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    border: none !important;
    overflow: hidden;
    min-height: 420px;
}

    /* Dark overlay so text stays readable over the photo */
    .aoc-solution-card::before {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.52);
        z-index: 0;
    }

    /* Push all card content above the overlay */
    .aoc-solution-card .card-body {
        position: relative;
        z-index: 1;
        padding: 2rem 1.5rem 1rem;
        margin-top: auto;
    }

    .aoc-solution-card .card-footer {
        position: relative;
        z-index: 1;
        padding: 0 1.5rem 1.5rem;
        background: transparent;
        border: none;
    }

    /* Text colors — white on dark overlay */
    .aoc-solution-card .card-title {
        color: #fff;
    }

    .aoc-solution-card .card-text {
        color: #d4d4d4;
        font-weight: 500;
        text-shadow: 0 1px 3px rgba(0,0,0,0.6);
    }

    .aoc-solution-card .badge {
        background: rgba(255,255,255,0.2) !important;
        color: #fff;
    }

    .aoc-solution-card .btn {
        border-color: #fff;
        color: #fff;
    }

        .aoc-solution-card .btn:hover {
            background: #fff;
            color: var(--aoc-blue);
        }

/* One image per card */
.aoc-solution-card-1 {
    background-image: url('/images/licensed/sol-order-process.jpg');
}

.aoc-solution-card-2 {
    background-image: url('/images/licensed/sol-inventory.jpg');
}

/*.aoc-service-card-custom {
    background: #EFF6FF;
    border: 1px solid #BFDBFE !important;
}*/
/* blue   - Custom Software */
/*.aoc-service-card-qb {
    background: #F0FDF4;
    border: 1px solid #A7F3D0 !important;
}*/
/* green  - QuickBooks */
/*.aoc-service-card-it {
    background: #FFF7ED;
    border: 1px solid #FED7AA !important;
}*/
/* amber  - IT Services */
/*.aoc-service-card-cloud {
    background: #F5F3FF;
    border: 1px solid #DDD6FE !important;
}*/
/* purple - Cloud */
/*.aoc-service-card-integration {
    background: #FFF1F2;
    border: 1px solid #FECDD3 !important;
}*/
/* rose - Integration */
.aoc-service-card {
    position: relative;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    border: none !important;
    overflow: hidden;
    min-height: 280px;
}

    /* Dark overlay for text readability */
    .aoc-service-card::before {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.52);
        z-index: 0;
    }

    /* Push content above overlay */
    .aoc-service-card .card-body {
        position: relative;
        z-index: 1;
        padding: 1.5rem 1.5rem 1rem;
        margin-top: auto;
    }

    .aoc-service-card .card-footer {
        position: relative;
        z-index: 1;
        padding: 0 1.5rem 1.5rem;
        background: transparent;
        border: none;
    }

    /* Text colors */
    .aoc-service-card .card-title {
        color: #fff;
    }

    .aoc-service-card .card-text {
        color: #fff;
        font-weight: 500;
        text-shadow: 0 1px 3px rgba(0,0,0,0.6);
    }

    .aoc-service-card .btn {
        border-color: #fff;
        color: #fff;
    }

        .aoc-service-card .btn:hover {
            background: #fff;
            color: var(--aoc-blue);
        }

/* One image per category */
.aoc-service-card-custom {
    background-image: url('/images/licensed/svc-custom-software.jpg');
}

.aoc-service-card-qb {
    background-image: url('/images/licensed/svc-quickbooks.jpg');
}

.aoc-service-card-it {
    background-image: url('/images/licensed/svc-it-services.jpg');
}

.aoc-service-card-cloud {
    background-image: url('/images/licensed/svc-cloud-services.jpg');
}

.aoc-service-card-integration {
    background-image: url('/images/licensed/svc-integration.jpg');
}

.aoc-page-hero {
    background: #F9FAFB;
    border-bottom: 1px solid var(--aoc-border);
}

.aoc-page-hero-about {
    background-image: url('/images/licensed/about-hero.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
}

    .aoc-page-hero-about::before {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.55);
        z-index: 0;
    }

    .aoc-page-hero-about .container {
        position: relative;
        z-index: 1;
    }

    .aoc-page-hero-about h1,
    .aoc-page-hero-about p,
    .aoc-page-hero-about .aoc-eyebrow {
        color: #fff;
    }

/* ── Order Process Lite page ──────────────────────────────── */
.aoc-page-hero-opl {
    background: var(--aoc-blue-dark);
}

.aoc-opl-hero-inner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/opl-hero.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-color: #0f1e50;
}

.aoc-opl-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(15, 30, 80, 0.72);
    z-index: 0;
}

.aoc-opl-steps {
    border-radius: 12px;
    overflow: hidden;
}

.aoc-opl-step {
    background: #fff;
    transition: background .2s;
}

    .aoc-opl-step:hover {
        background: var(--aoc-blue-light);
    }

.aoc-opl-step-num {
    display: inline-block;
    font-size: 2rem;
    font-weight: 800;
    color: var(--aoc-blue);
    opacity: .25;
    line-height: 1;
}

.aoc-opl-feature {
    background: #fff;
    transition: box-shadow .2s, transform .2s;
}

    .aoc-opl-feature:hover {
        box-shadow: 0 4px 16px rgba(29,78,216,.1) !important;
        transform: translateY(-2px);
    }

.aoc-opl-feature-icon {
    font-size: 1.75rem;
    flex-shrink: 0;
    margin-top: .125rem;
}

.aoc-page-hero-opl .aoc-eyebrow {
    color: rgba(255,255,255,.75);
}

.aoc-opl-hero-inner .btn-outline-light {
    border-color: #fff;
    color: #fff;
}

    .aoc-opl-hero-inner .btn-outline-light:hover {
        background: #fff;
        color: var(--aoc-blue);
    }

@media (max-width: 767px) {
    .aoc-opl-hero-inner {
        min-height: 320px;
    }
}

/* ── Inventory Barcode Solution page ──────────────────────── */
.aoc-page-hero-barcode {
    background: #0a1628;
}

.aoc-barcode-hero-inner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/barcode-hero.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.aoc-barcode-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 22, 40, 0.70);
    z-index: 0;
}

.aoc-barcode-hero-inner .btn-outline-light {
    border-color: #fff;
    color: #fff;
}

    .aoc-barcode-hero-inner .btn-outline-light:hover {
        background: #fff;
        color: var(--aoc-blue);
    }

@media (max-width: 767px) {
    .aoc-barcode-hero-inner {
        min-height: 320px;
    }
}

/* ── Custom Software Development page ────────────────────── */
.aoc-page-hero-custom {
    background: #0a1628;
}

.aoc-custom-hero-inner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/custom-software-hero.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.aoc-custom-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 22, 40, 0.68);
    z-index: 0;
}

.aoc-custom-hero-inner .btn-outline-light {
    border-color: #fff;
    color: #fff;
}

    .aoc-custom-hero-inner .btn-outline-light:hover {
        background: #fff;
        color: var(--aoc-blue);
    }

.aoc-tech-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    display: inline-block;
}

@media (max-width: 767px) {
    .aoc-custom-hero-inner {
        min-height: 320px;
    }
}

/* ── Managed IT Services page ─────────────────────────────── */
.aoc-page-hero-mit {
    background: #0a1628;
}

.aoc-mit-hero-inner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/managed-it-hero.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

.aoc-mit-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 22, 40, 0.68);
    z-index: 0;
}

.aoc-mit-hero-inner .btn-outline-light {
    border-color: #fff;
    color: #fff;
}

    .aoc-mit-hero-inner .btn-outline-light:hover {
        background: #fff;
        color: var(--aoc-blue);
    }

@media (max-width: 767px) {
    .aoc-mit-hero-inner {
        min-height: 320px;
    }
}

/* ── Amazon Web Services page ─────────────────────────────── */
.aoc-page-hero-aws {
    background: #0a1628;
}

.aoc-aws-hero-inner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/aws-hero.jpg');
    background-size: cover;
    background-position: center 60%;
    background-repeat: no-repeat;
}

.aoc-aws-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 22, 40, 0.68);
    z-index: 0;
}

.aoc-aws-hero-inner .btn-outline-light {
    border-color: #fff;
    color: #fff;
}

    .aoc-aws-hero-inner .btn-outline-light:hover {
        background: #fff;
        color: var(--aoc-blue);
    }

@media (max-width: 767px) {
    .aoc-aws-hero-inner {
        min-height: 320px;
    }
}

/* ── QuickBooks Services page ─────────────────────────────── */
.aoc-page-hero-qb {
    background: #1a3a1a;
}

.aoc-qb-hero-inner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/quickbooks-hero.jpg');
    background-size: cover;
    background-position: center 25%;
    background-repeat: no-repeat;
}

.aoc-qb-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 40, 10, 0.70);
    z-index: 0;
}

.aoc-qb-hero-inner .btn-outline-light {
    border-color: #fff;
    color: #fff;
}

    .aoc-qb-hero-inner .btn-outline-light:hover {
        background: #fff;
        color: #1a3a1a;
    }

@media (max-width: 767px) {
    .aoc-qb-hero-inner {
        min-height: 320px;
    }
}

/* ── Services TabStrip card size normalization ────────────── */
/* ── Services TabStrip card normalization ─────────────────── */
.k-tabstrip-content .card,
.k-tabstrip .card {
    font-size: 1rem;
}

.k-tabstrip-content .card-title,
.k-tabstrip .card-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: #fff;
}

.k-tabstrip-content .card-text,
.k-tabstrip .card-text {
    color: #fff;
    font-weight: 500;
    text-shadow: 0 1px 3px rgba(0,0,0,0.6);
}

.k-tabstrip-content .card-body,
.k-tabstrip .card-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
}

.k-tabstrip-content .card-footer,
.k-tabstrip .card-footer {
    padding: 0 1.5rem 1.5rem;
    background: transparent;
    border: none;
}

/* Services page card height normalization */
.k-tabstrip-content .card {
    min-height: 280px;
}

.aoc-page-hero-qb {
    background: #1a3a1a;
}

.aoc-services-hero-inner {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    background-image: url('/images/licensed/services-hero.jpg');
    background-size: cover;
    background-position: center 60%;
    background-repeat: no-repeat;
}

.aoc-services-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 22, 40, 0.68);
    z-index: 0;
}

.aoc-services-hero-overlay .btn-outline-light {
    border-color: #fff;
    color: #fff;
}

    .aoc-services-hero-overlay .btn-outline-light:hover {
        background: #fff;
        color: #1a3a1a;
    }

@media (max-width: 767px) {
    .aoc-services-hero-overlay {
        min-height: 320px;
    }
}

/* ── Contact page hero ────────────────────────────────────── */
.aoc-page-hero-contact {
    background: #0a1628;
}

    .aoc-page-hero-contact .container {
        position: relative;
        z-index: 1;
        padding-top: 3rem;
        padding-bottom: 3rem;
    }

.aoc-page-hero-contact {
    background-image: url('/images/licensed/contact-hero.jpg');
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
}

    .aoc-page-hero-contact::before {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(10, 22, 40, 0.68);
        z-index: 0;
    }

    .aoc-page-hero-contact h1,
    .aoc-page-hero-contact p,
    .aoc-page-hero-contact .aoc-eyebrow {
        color: #fff;
    }

/* ── Responsive tweaks ────────────────────────────────────── */
/* Touch targets: make buttons minimum 44px tall on mobile */
@media (max-width: 767px) {
    .btn { min-height: 44px; display: inline-flex; align-items: center; justify-content: center; }
  .btn-sm { min-height: 36px; }
}

/* Admin: collapse sidebar on mobile */
@media (max-width: 900px) {
  .aoc-admin-sidebar  { display: none; }
  .aoc-admin-stats    { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 575px) {
  .aoc-admin-stats    { grid-template-columns: 1fr; }
  .aoc-admin-content  { padding: 1rem; }
}

/* Contact page: stack on mobile */
@media (max-width: 767px) {
  .aoc-hero .lead { font-size: 1rem; }
}
