/* ==========================================================
   GA AUDITOR — CORE UI SYSTEM
========================================================== */


/* ==========================================================
   DESIGN TOKENS
========================================================== */

:root{

  /* Brand */
  --gaa-primary:#215C98;
  --gaa-primary-dark:#184C84;
  --gaa-primary-light:#3A73AF;

  /* Text */
  --gaa-text:#111827;
  --gaa-text-2:#374151;
  --gaa-text-light:#6b7280;

  /* Backgrounds */
  --gaa-bg:#f5f7fb;
  --gaa-card:#ffffff;
  --gaa-subtle:#f9fafb;

  /* Borders */
  --gaa-border:#e5e7eb;

  /* Status */
  --gaa-success:#16a34a;
  --gaa-success-bg:#dcfce7;

  --gaa-warn:#d97706;
  --gaa-warn-bg:#fef3c7;

  --gaa-danger:#dc2626;
  --gaa-danger-bg:#fee2e2;

  --gaa-info:#2563eb;
  --gaa-info-bg:#dbeafe;

  /* Radius */
  --gaa-r-sm:8px;
  --gaa-r-md:12px;
  --gaa-r-lg:16px;

  /* Shadows */
  --gaa-shadow-sm:0 2px 8px rgba(0,0,0,.05);
  --gaa-shadow-md:0 10px 24px rgba(0,0,0,.08);

  /* Layout */
  --gaa-content-width:1100px;

}


/* ==========================================================
   BASE
========================================================== */

.gaa-container{
  width:100%;
  max-width:var(--gaa-content-width);
}

.gaa-section{
  margin-bottom:20px;
}


/* ==========================================================
   BUTTONS
========================================================== */

.gaa-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;

  padding:10px 16px;

  border-radius:10px;
  border:1px solid var(--gaa-border);

  background:#fff;
  color:var(--gaa-text);

  font-size:14px;
  font-weight:600;
  text-decoration:none;

  cursor:pointer;

  transition:
    background .15s ease,
    border-color .15s ease,
    transform .15s ease,
    box-shadow .15s ease;
}

.gaa-btn:hover{
  background:#f3f4f6;
  transform:translateY(-1px);
}

.gaa-btn-primary{
  background:var(--gaa-primary);
  border-color:var(--gaa-primary);
  color:#fff;
}

.gaa-btn-primary:hover{
  background:var(--gaa-primary-dark);
  color:#fff;
}


/* ==========================================================
   CARDS
========================================================== */

.gaa-card{
  background:var(--gaa-card);

  border:1px solid var(--gaa-border);
  border-radius:var(--gaa-r-lg);

  padding:20px;

  box-shadow:var(--gaa-shadow-sm);

  transition:
    transform .15s ease,
    box-shadow .15s ease,
    border-color .15s ease;
}

.gaa-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--gaa-shadow-md);
}

.gaa-card-title{
  margin:0 0 10px;

  font-size:18px;
  font-weight:700;

  color:var(--gaa-text);
}

.gaa-card-text{
  margin:0 0 16px;

  color:var(--gaa-text-2);
  line-height:1.6;
}


/* ==========================================================
   OVERVIEW CARD
========================================================== */

.gaa-overview-card{
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
  margin-bottom:18px;
}

.gaa-overview-title{
  margin:0 0 14px;

  font-size:26px;
  font-weight:700;

  color:var(--gaa-text);
}

.gaa-overview-primary{
  margin:0;

  font-size:16px;
  color:var(--gaa-text);
}

.gaa-overview-meta{
  margin:4px 0 0;

  font-size:14px;
  color:var(--gaa-text-light);
}

.gaa-overview-link{
  margin-top:8px;
}

.gaa-overview-link a{
  color:var(--gaa-primary);

  text-decoration:none;
  font-weight:600;
}

.gaa-overview-link a:hover{
  text-decoration:underline;
}

.gaa-overview-divider{
  margin:16px 0;
  border-top:1px solid var(--gaa-border);
}


/* ==========================================================
   BANNER
========================================================== */

.gaa-banner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;

  background:#f0f9ff;

  border:1px solid #bae6fd;
  border-radius:14px;

  padding:16px 18px;

  margin:0 0 20px;

  max-width:none;
}

.gaa-banner.small{
  background:#f9fafb;
  border-color:var(--gaa-border);
}

.gaa-banner-text{
  line-height:1.5;
}


/* ==========================================================
   ONBOARDING
========================================================== */

.gaa-onboarding{
  background:#fff;

  border:1px solid var(--gaa-border);
  border-radius:16px;

  padding:28px 32px;

  max-width:none;

  margin:20px 0 40px;

  box-shadow:var(--gaa-shadow-sm);
}

.gaa-onboarding h2{
  margin:0 0 14px;

  font-size:26px;
  font-weight:700;

  color:var(--gaa-text);
}

.gaa-subtext{
  color:var(--gaa-text-light);

  margin-bottom:20px;

  line-height:1.6;
}


/* ==========================================================
   CONNECTIONS
========================================================== */

.gaa-connection-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.gaa-connection-item{
  display:flex;
  justify-content:space-between;
  align-items:center;

  padding:16px 18px;

  background:#fff;

  border:1px solid var(--gaa-border);
  border-radius:14px;

  cursor:pointer;

  transition:
    border-color .15s ease,
    background .15s ease,
    transform .15s ease,
    box-shadow .15s ease;
}

.gaa-connection-item:hover{
  border-color:var(--gaa-primary);

  background:#f8fbff;

  transform:translateY(-1px);

  box-shadow:var(--gaa-shadow-sm);
}

.gaa-connection-info{
  display:flex;
  flex-direction:column;
}

.gaa-connection-title{
  font-size:15px;
  font-weight:700;
  color:var(--gaa-text);
}

.gaa-connection-sub{
  margin-top:4px;

  font-size:13px;
  color:var(--gaa-text-light);
}

.gaa-link-arrow{
  color:var(--gaa-primary);
  font-weight:700;

  transition:transform .15s ease;
}

.gaa-connection-item:hover .gaa-link-arrow{
  transform:translateX(3px);
}


/* ==========================================================
   AUDIT CARDS GRID
========================================================== */

.gaa-cards{
  display:grid;

  grid-template-columns:
    repeat(auto-fit,minmax(280px,1fr));

  gap:20px;

  margin-top:24px;
}

.gaa-card-audit{
  min-height:220px;

  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.gaa-card-audit h3{
  margin:0 0 10px;

  font-size:18px;
  font-weight:700;
}

.gaa-card-audit p{
  margin:0 0 16px;

  color:var(--gaa-text-2);
  line-height:1.6;
}

.gaa-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.gaa-card-warning{
  color:#b45309;
  font-size:14px;
}

@media (max-width:920px){

  .gaa-card-audit{
    grid-column:span 12;
  }

}


/* ==========================================================
   FEEDBACK / INFO
========================================================== */

.gaa-feedback{
  background:#eef6ff;

  border-left:4px solid var(--gaa-primary);

  border-radius:10px;

  padding:16px;

  margin-top:24px;

  line-height:1.6;
}

.gaa-feedback a{
  color:var(--gaa-primary);

  font-weight:600;
  text-decoration:none;
}

.gaa-feedback a:hover{
  text-decoration:underline;
}

.gaa-pending-banner{
  background:#fff4d6;

  border-left:5px solid #e5a700;

  border-radius:10px;

  padding:16px 18px;

  margin-bottom:20px;

  color:#5a4400;

  box-shadow:var(--gaa-shadow-sm);
}


/* ==========================================================
   TABLES
========================================================== */

.gaa-table{
  width:100%;
  border-collapse:collapse;

  margin-top:12px;
}

.gaa-table th,
.gaa-table td{
  border:1px solid var(--gaa-border);

  padding:10px 12px;

  text-align:left;
}

.gaa-table th{
  background:#f9fafb;

  font-weight:700;

  color:var(--gaa-text-2);
}


/* ==========================================================
   AUDIT RESULTS
========================================================== */

.gaa-check-card{
  border:1px solid var(--gaa-border);
  border-radius:12px;

  background:#fff;

  margin:10px 0;

  overflow:hidden;

  transition:
    box-shadow .15s ease,
    border-color .15s ease;
}

.gaa-check-card:hover{
  box-shadow:var(--gaa-shadow-sm);
}

.gaa-check-header{
  display:flex;
  align-items:center;
  justify-content:space-between;

  padding:14px 16px;

  cursor:pointer;
}

.gaa-check-header:hover{
  background:#f9fafb;
}

.gaa-check-title{
  flex:1;

  font-weight:600;

  color:var(--gaa-text);
}

.gaa-check-content{
  display:none;

  padding:16px 18px;

  border-top:1px solid var(--gaa-border);

  background:#fafafa;
}

.gaa-check-card.open .gaa-check-content{
  display:block;
}


/* ==========================================================
   STATUS BADGES
========================================================== */

.gaa-status-badge{
  display:inline-flex;
  align-items:center;

  padding:4px 10px;

  border-radius:999px;

  font-size:11px;
  font-weight:700;

  letter-spacing:.3px;

  text-transform:uppercase;
}

.gaa-status-badge.pass{
  background:var(--gaa-success-bg);
  color:#166534;
}

.gaa-status-badge.warn{
  background:var(--gaa-warn-bg);
  color:#854d0e;
}

.gaa-status-badge.fail{
  background:var(--gaa-danger-bg);
  color:#991b1b;
}


/* ==========================================================
   SPINNER
========================================================== */

.gaa-spinner{
  width:36px;
  height:36px;

  border:4px solid #e5e7eb;
  border-top-color:var(--gaa-primary);

  border-radius:50%;

  animation:gaa-spin 1s linear infinite;

  margin:20px auto;

  display:none;
}

@keyframes gaa-spin{
  to{
    transform:rotate(360deg);
  }
}

/* =========================================
   OVERVIEW STATS
========================================= */

.gaa-overview-stats{
  display:grid;

  grid-template-columns:
    repeat(auto-fit,minmax(260px,1fr));

  gap:18px;

  margin-top:28px;
}

.gaa-stat-card{
  background:#fff;

  border:1px solid var(--gaa-border);
  border-radius:14px;

  padding:22px;

  box-shadow:var(--gaa-shadow-sm);

  transition:
    transform .15s ease,
    box-shadow .15s ease,
    border-color .15s ease;
}

.gaa-stat-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--gaa-shadow-md);
}

.gaa-stat-value{
  font-size:40px;
  font-weight:800;
  line-height:1;

  color:var(--gaa-primary);

  margin-bottom:10px;
}

.gaa-stat-label{
  font-size:15px;
  font-weight:700;

  color:var(--gaa-text);

  margin-bottom:8px;
}

.gaa-stat-meta{
  font-size:14px;
  line-height:1.6;

  color:var(--gaa-text-light);

  margin-bottom:14px;
}

.gaa-stat-action a{
  color:var(--gaa-primary);

  font-size:14px;
  font-weight:600;

  text-decoration:none;
}

.gaa-stat-action a:hover{
  text-decoration:underline;
}

