/* ==========================================================
   AGY MODULES v1.0
   Bootstrap-Compatible Component & Utility Extensions
   Compatible with framework.css + responsive.css + style.css
   Author: Kenan Uçar | AGY Bilişim
   ========================================================== */

/* ================================
   1️⃣ Layout Enhancements
   ================================ */
.agy-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.agy-stack-horizontal {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

/* Aspect Ratio Helpers */
.agy-ratio-1x1 { aspect-ratio: 1/1; }
.agy-ratio-16x9 { aspect-ratio: 16/9; }
.agy-ratio-21x9 { aspect-ratio: 21/9; }

/* Container Size Overrides */
.agy-container-sm { max-width: 540px; margin: 0 auto; }
.agy-container-md { max-width: 720px; margin: 0 auto; }
.agy-container-lg { max-width: 960px; margin: 0 auto; }
.agy-container-xl { max-width: 1140px; margin: 0 auto; }
.agy-container-fluid { width: 100%; padding: 0 var(--space-sm); }

/* Genel grid temel ayarları */
[class^="agy-grid-"] {
  display: grid;
  gap: var(--space-md);
  width: 100%;
  margin: var(--space-md) 0;
}

/* === Grid Türleri === */
.agy-grid-2 {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.agy-grid-3 {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.agy-grid-4 {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.agy-grid-5 {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.agy-grid-equal {grid-auto-rows: 1fr; align-items: stretch; }
.agy-grid-equal-sm { grid-auto-rows: auto; align-items: start; }
.agy-grid-equal-md { grid-auto-rows: auto; align-items: start; }
.agy-grid-equal-lg { grid-auto-rows: auto; align-items: start; }
.agy-grid-equal-xl { grid-auto-rows: auto; align-items: start; }


/* === Grid Elemanları === */
.agy-grid-item {
  background: var(--bg-white);
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.agy-grid-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

/* ================================
   2️⃣ Components (Card, Badge, Media)
   ================================ */

/* --- Cards --- */
.agy-card {
  background: var(--bg-white);
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
  transition: all 0.3s ease;
  overflow: hidden;
}
.agy-card:hover { transform: translateY(-3px); box-shadow: 0 4px 16px rgba(0,0,0,0.15); }
.agy-card-body { padding: var(--space-md); }
.agy-card-title { font-weight: var(--font-weight-bold); margin-bottom: var(--space-sm); color: var(--primary); }
.agy-card-footer { border-top: 1px solid #eee; padding: var(--space-sm) var(--space-md); }

/* --- Badges --- */
.agy-badge {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: var(--font-weight-bold);
  line-height: 1;
  text-transform: uppercase;
}
.agy-badge-primary { background: var(--primary); color: var(--text-white); }
.agy-badge-success { background: var(--success); color: var(--text-white); }
.agy-badge-warning { background: var(--warning); color: var(--text-dark); }
.agy-badge-danger  { background: var(--danger); color: var(--text-white); }
.agy-badge-outline { border: 1px solid currentColor; background: transparent; }

/* --- Media Object --- */
.agy-media {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.agy-media img {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
}
.agy-media-content h4 { margin-bottom: 4px; font-size: var(--font-size-lg); }
.agy-media-content p  { font-size: var(--font-size-sm); color: var(--text-light); }

/* ================================
   3️⃣ Utility Components
   ================================ */

/* Spacing Utilities */
.m-0 { margin: 0 !important; } 
.mt-1 { margin-top: var(--space-xs) !important; }
.mt-2 { margin-top: var(--space-sm) !important; }
.mt-3 { margin-top: var(--space-md) !important; }
.mb-1 { margin-bottom: var(--space-xs) !important; }
.mb-2 { margin-bottom: var(--space-sm) !important; }
.mb-3 { margin-bottom: var(--space-md) !important; }
.p-1 { padding: var(--space-xs) !important; }
.p-2 { padding: var(--space-sm) !important; }
.p-3 { padding: var(--space-md) !important; }

/* Divider */
.agy-divider {
  width: 100%;
  border-top: 1px solid #ddd;
  margin: var(--space-md) 0;
}
.agy-divider-text {
  display: flex;
  align-items: center;
  text-align: center;
  margin: var(--space-md) 0;
}
.agy-divider-text::before,
.agy-divider-text::after {
  content: '';
  flex: 1;
  border-top: 1px solid #ddd;
}
.agy-divider-text:not(:empty)::before { margin-right: .5em; }
.agy-divider-text:not(:empty)::after { margin-left: .5em; }

/* Visibility */
.d-none { display: none !important; }
.d-flex { display: flex !important; }
.text-center { text-align: center; }
.text-right { text-align: right; }

/* Colors */
.text-primary { color: var(--primary) !important; }
.text-accent { color: var(--accent) !important; }
.text-success { color: var(--success) !important; }
.text-warning { color: var(--warning) !important; }
.text-danger  { color: var(--danger) !important; }

.bg-primary { background: var(--primary) !important; color: #fff; }
.bg-light   { background: var(--bg-light) !important; }
.bg-white   { background: var(--bg-white) !important; }
.bg-dark    { background: var(--bg-dark) !important; color: #fff; }

/* ================================
   4️⃣ Typography & Media
   ================================ */
.agy-heading { font-weight: var(--font-weight-bold-x); margin-bottom: var(--space-sm); }
.agy-subheading { font-size: var(--font-size-lg); color: var(--text-light); }
.agy-text-muted { color: var(--text-light); }
.agy-highlight { background: var(--accent); color: #fff; padding: 2px 6px; border-radius: 4px; }

.agy-frame {
  display: inline-block;
  border: 6px solid #fff;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
  border-radius: 8px;
  overflow: hidden;
}
.agy-frame img { width: 100%; height: auto; display: block; }

/* ================================
   5️⃣ Interactive Elements
   ================================ */
.agy-btn {
  display: inline-block;
  padding: 10px 20px;
  border-radius: 5px;
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  transition: all 0.3s ease;
}
.agy-btn-primary { background: var(--primary); color: #fff; }
.agy-btn-outline { border: 2px solid var(--primary); color: var(--primary); background: none; }
.agy-btn:hover { transform: translateY(-2px); opacity: 0.9; }

/* Tooltip */
.agy-tooltip {
  position: relative;
  cursor: help;
}
.agy-tooltip:hover::after {
  content: attr(data-tip);
  position: absolute;
  bottom: 125%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-dark);
  color: #fff;
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 0.75rem;
  white-space: nowrap;
  opacity: 0.9;
}

/* Accordion */
.agy-accordion { border: 1px solid #ddd; border-radius: 8px; overflow: hidden; }
.agy-accordion-item { border-bottom: 1px solid #ddd; }
.agy-accordion-header {
  padding: var(--space-sm);
  background: var(--bg-light);
  cursor: pointer;
  font-weight: var(--font-weight-bold);
}
.agy-accordion-body { display: none; padding: var(--space-sm); }
.agy-accordion-item.active .agy-accordion-body { display: block; }

/* ================================
   ✅ Responsive (Bootstrap-style)
   ================================ */
@media (min-width: 576px) { 
  .agy-media img { width: 56px; height: 56px; } 
  .agy-grid-2 { grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
  .agy-grid-3 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
  .agy-grid-equal-sm { grid-auto-rows: 1fr; align-items: stretch; }
}

@media (min-width: 768px) { 
  .agy-media img { width: 64px; height: 64px; } 
  .agy-grid-2 { grid-template-columns: repeat(2, 1fr); }
  .agy-grid-3 { grid-template-columns: repeat(3, 1fr); }
  .agy-grid-4 { grid-template-columns: repeat(3, 1fr); }
  .agy-grid-equal-md { grid-auto-rows: 1fr; align-items: stretch; }
}

@media (min-width: 992px) { 
  .agy-media img { width: 72px; height: 72px; } 
  .agy-grid-2 { grid-template-columns: repeat(2, 1fr); }
  .agy-grid-3 { grid-template-columns: repeat(3, 1fr); }
  .agy-grid-4 { grid-template-columns: repeat(4, 1fr); }
  .agy-grid-5 { grid-template-columns: repeat(5, 1fr); }
  .agy-grid-equal-lg { grid-auto-rows: 1fr; align-items: stretch; }
}

@media (min-width: 1200px) { 
  .agy-media img { width: 80px; height: 80px; } 
  [class^="agy-grid-"] { gap: var(--space-lg); }
}

@media (min-width: 1400px) {
  .agy-grid-equal-xl { grid-auto-rows: 1fr; align-items: stretch; }
}
