@layer base, components, utilities;

@layer base {
  html { color-scheme: light dark; }
  body {
    background: var(--color-bg);
    color: var(--color-fg);
    font-family: var(--font-sans);
    line-height: var(--line-height);
  }
  :focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
  }
}

@layer components {
  /* Header: replace floats when supported */
  @supports (display: flex) {
    .w3ls-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      background: var(--color-dark);
    }
    .w3ls-header-left,
    .w3ls-header-right { float: none; }
    .agile-its-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: var(--size-4);
    }
    .logo,
    .agileits_search {
      float: none;
    }
    .w3ls-header-right ul {
      display: flex;
      align-items: center;
      gap: var(--size-4);
      flex-wrap: wrap;
    }
    .w3ls-header-right ul li.dropdown { display: inline-flex; padding: 0; }
    .w3ls-header-right ul li a { text-decoration: none; }
  }

  /* Directory listing/card: grid-based layout override */
  @supports (display: grid) {
    .directory-listing,
    .category-listing,
    .listing-item {
      container-type: inline-size;
      display: grid;
      grid-template-columns: minmax(120px, 1fr) 2fr;
      gap: var(--size-4);
      align-items: start;
    }
    /* Map common class names used in theme listing blocks */
    .category-img,
    .client { float: none; }
    .category-info,
    .client-info { float: none; }
    .directory-listing .category-img,
    .category-listing .category-img,
    .listing-item .category-img {
      float: none;
      width: auto;
    }
    .directory-listing .category-info,
    .category-listing .category-info,
    .listing-item .category-info {
      float: none;
      width: auto;
    }

    /* Container-size reflow when supported */
    @container (max-width: 520px) {
      .directory-listing,
      .category-listing,
      .listing-item {
        grid-template-columns: 1fr;
      }
    }
  }

  /* Forms: modern alignment */
  @supports (display: flex) {
    .signin-rit,
    .sign-up1,
    .sign-up2 {
      float: none;
    }
    .signin-rit { display: flex; justify-content: flex-end; gap: var(--size-3); }
    .sign-up1,
    .sign-up2 { display: flex; gap: var(--size-3); }
    .agileits_search form { display: flex; gap: var(--size-2); align-items: center; }
    .agileits_search input[type="text"] { flex: 1 1 auto; width: auto; }

    /* Generic float row fallback → flex row when supported */
    .float-row { display: flex; gap: var(--size-3); flex-wrap: wrap; }

    /* Additional form layouts from theme */
    .log-input-left,
    span.checkicon-box,
    span.checkbox2,
    .signin-rit p,
    .agileinfo_signin label.checkbox,
    .forgot { float: none; }
    .log-input-left { display: flex; align-items: center; gap: var(--size-3); flex-wrap: wrap; }
    .signin-rit { display: flex; align-items: center; justify-content: space-between; gap: var(--size-3); }
  }
}

@layer utilities {
  /* Logical spacing for common blocks */
  .section { padding-block: var(--size-7); }
  .container-gap { gap: var(--size-4); }
  .text-accent { color: var(--color-accent); }
  .bg-dark { background: var(--color-dark); color: var(--color-accent-contrast); }
}

/* Motion reduction globally respected via tokens.css */
@media (prefers-reduced-motion: reduce) {
  /* Sliders */
  .flexslider,
  .flexslider * { transition: none !important; animation: none !important; }
  /* Side menu */
  .menu-wrap,
  .icon-list a { transition: none !important; }
}

/* Ad slots: CLS-safe dimensions for responsive banner */
.textCenter.ad-banner { min-height: clamp(90px, 20vw, 280px); }
.textCenter.ad-banner .adsbygoogle { display: block; width: 100%; min-height: inherit; }

/* Consent banner */
.consent-banner { position: fixed; inset-block-end: 0; inset-inline: 0; z-index: var(--z-overlay); background: rgba(0,0,0,0.6); }
.consent-banner .consent-content { max-width: 960px; margin: var(--size-4) auto; background: var(--color-bg); color: var(--color-fg); box-shadow: var(--shadow-2); border-radius: var(--radius-2); padding: var(--size-4); display: flex; align-items: center; justify-content: space-between; gap: var(--size-4); }
.consent-banner .consent-actions { display: flex; gap: var(--size-4); }
.consent-banner button { padding: 0.5rem 0.875rem; border-radius: var(--radius-1); border: 1px solid var(--color-border); background: var(--color-light); cursor: pointer; }
.consent-banner .consent-accept { background: var(--color-accent); color: var(--color-accent-contrast); border-color: var(--color-accent); }

/* Typography defaults (consistent across site) */
html { font-size: 100%; }
body { font-family: var(--font-sans); line-height: var(--line-height); color: var(--color-fg); background: var(--color-bg); }
h1, h2, h3, h4 { font-family: var(--font-condensed); letter-spacing: 0.2px; }
h1 { font-size: var(--font-size-4); }
h2 { font-size: var(--font-size-3); }
h3 { font-size: var(--font-size-2); }
h4 { font-size: var(--font-size-1); }
a { color: var(--color-accent); }
button, input, select, textarea { font-family: inherit; font-size: inherit; line-height: inherit; }

/* Typography refinements */
h1, h2, h3, h4 { font-weight: 600; line-height: 1.25; margin-block: var(--size-4) var(--size-3); }
body { font-weight: 400; }

/* Accessible focus styles (subtle) */
a:focus-visible, button:focus-visible, [role="button"]:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}


