/* =========================
   TRCG THEME CSS
   Author: TRCG
   Supports full theme customization via CSS variables
============================ */

/* -------------------------
   THEME VARIABLES
------------------------- */
:root {
  --trcg-primary:   #425F71;
  --trcg-secondary: #548E88;
  --trcg-success:   #819561;
  --trcg-danger:    #D68476;
  --trcg-warning:   #D1BA59;
  --trcg-info:      #464A59;
  --trcg-code:      #068AD1;

  --trcg-bg:        #afc2aa;
  --trcg-text:      #1f2933;
  --trcg-border:    #e5e7eb;
  --trcg-radius:    6px;
  --trcg-shadow:    0 4px 12px rgba(0,0,0,0.08);
  --trcg-transition: 0.25s ease;
  --trcg-header-footer-bg: #798777;
  --trcg-header-footer-text: #ffffff;
  --trcg-surface-bg: #f8ede3;
  --trcg-surface-light-bg: #FAFAFA;
}

/* -------------------------
   GLOBAL
------------------------- */
.trcg-theme {
  background-color: var(--trcg-bg);
  color: var(--trcg-text);
  font-family: 'Inter', sans-serif;
  margin: 0;
}

/* -------------------------
   HEADER & FOOTER
------------------------- */
.trcg-header,
.trcg-footer {
  background-color: var(--trcg-header-footer-bg);
  color: var(--trcg-header-footer-text);
  width: 100%;
  box-shadow: var(--trcg-shadow);
}

.trcg-header {
  position: fixed;
  top: 0;
  height: 72px;
  display: flex;
  align-items: center;
  padding: 0 24px;
  z-index: 1000;
  gap: 12px;
}

.trcg-footer {
  position: fixed;
  bottom: 0;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
}

/* -------------------------
   LOGO
------------------------- */
.trcg-logo {
  height: 36px;
  max-width: 120px;
  object-fit: contain;
}
@media (max-width: 768px) {
  .trcg-logo {
    height: 28px;
    max-width: 90px;
  }
}

/* -------------------------
   SURFACES (MODAL / CARD / FORM)
------------------------- */
.trcg-surface {
  background-color: var(--trcg-surface-bg);
  border-radius: var(--trcg-radius);
  padding: 16px;
  box-shadow: var(--trcg-shadow);
  transition: background-color var(--trcg-transition);
}

.trcg-card {
  background-color: var(--trcg-surface-light-bg); /* can be slightly off-surface if needed */
  padding: 20px;
  width: 100%;
  border-radius: var(--trcg-radius);
  box-shadow: var(--trcg-shadow);
  text-align: center;
  margin-right: 8px;
  transition: transform var(--trcg-transition), box-shadow var(--trcg-transition);
}

.trcg-card,
.trcg-card input,
.trcg-card textarea,
.trcg-card select {
  box-sizing: border-box;
}

.trcg-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.12);
}


/* -------------------------
   BUTTONS
------------------------- */
.trcg-btn {
  padding: 8px 16px;
  border: none;
  border-radius: var(--trcg-radius);
  cursor: pointer;
  font-weight: 500;
  transition: all var(--trcg-transition);
}

.trcg-btn-primary { background-color: var(--trcg-primary); color: #fff; }
.trcg-btn-secondary { background-color: var(--trcg-secondary); color: #fff; }
.trcg-btn-success { background-color: var(--trcg-success); color: #fff; }
.trcg-btn-danger { background-color: var(--trcg-danger); color: #fff; }
.trcg-btn-warning { background-color: var(--trcg-warning); color: #fff; }
.trcg-btn-info { background-color: var(--trcg-info); color: #fff; }

.trcg-btn:hover {
  filter: brightness(1.1);
}

/* -------------------------
   INPUTS & TEXTAREA
------------------------- */
.trcg-input,
.trcg-textarea {
  width: 100%;
  padding: 8px 12px;
  margin-bottom: 12px;
  border: 1px solid var(--trcg-border);
  border-radius: var(--trcg-radius);
  font-size: 14px;
  transition: border-color var(--trcg-transition), box-shadow var(--trcg-transition);
}

.trcg-input:focus,
.trcg-textarea:focus {
  outline: none;
  border-color: var(--trcg-primary);
  box-shadow: 0 0 0 2px rgba(66, 95, 113, 0.2);
}

.trcg-input-success { border-color: var(--trcg-success); }
.trcg-input-danger { border-color: var(--trcg-danger); }

/* -------------------------
   TABLE
------------------------- */
.trcg-table {
  width: 100%;
  border-collapse: collapse;
}

.trcg-table th,
.trcg-table td {
  border: 1px solid var(--trcg-border);
  padding: 8px 12px;
  text-align: left;
}

.trcg-table th {
  background-color: var(--trcg-secondary);
  color: #fff;
}

.trcg-text-success { color: var(--trcg-success); }
.trcg-text-danger { color: var(--trcg-danger); }
.trcg-text-warning { color: var(--trcg-warning); }
.trcg-text-info { color: var(--trcg-info); }

/* -------------------------
   ALERTS & BADGES
------------------------- */
.trcg-alert {
  padding: 8px 12px;
  border-radius: var(--trcg-radius);
  color: #fff;
  font-weight: 500;
}

.trcg-alert-primary { background-color: rgba(66,95,113,0.15); color: var(--trcg-primary); border: solid 2px var(--trcg-primary); }
.trcg-alert-success { background-color: rgba(129,149,97,0.15); color: var(--trcg-success); border: solid 2px var(--trcg-success);}
.trcg-alert-danger { background-color: rgba(214,132,118,0.15); color: var(--trcg-danger); border: solid 2px var(--trcg-danger); }
.trcg-alert-warning { background-color: rgba(209,186,89,0.15); color: var(--trcg-warning); border: solid 2px var(--trcg-warning); }
.trcg-alert-info { background-color: rgba(37,163,246,0.15); color: var(--trcg-info); border: solid 2px var(--trcg-info); }

/* BADGES */
.trcg-badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  border-radius: var(--trcg-radius);
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
}

/* Badge Variants */
.trcg-badge-primary   { background-color: var(--trcg-primary);   color: #fff; }
.trcg-badge-secondary { background-color: var(--trcg-secondary); color: #fff; }
.trcg-badge-success   { background-color: var(--trcg-success);   color: #fff; }
.trcg-badge-danger    { background-color: var(--trcg-danger);    color: #fff; }
.trcg-badge-warning   { background-color: var(--trcg-warning);   color: #fff; }
.trcg-badge-info      { background-color: var(--trcg-info);      color: #fff; }

/* Optional: small shadow/hover effect */
.trcg-badge:hover {
  opacity: 0.85;
  transition: opacity var(--trcg-transition);
}

/* Grid System */
.trcg-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px; /* space between columns */
}

/* Generic column */
.trcg-col {
  flex: 1; /* flexible width */
  min-width: 200px; /* ensures stacking on small screens */
}

/* Specific column widths */
.trcg-col-50  { flex: 0 0 calc(50% - 16px); }   /* 2 columns */
.trcg-col-33  { flex: 0 0 calc(33.333% - 16px); } /* 3 columns */
.trcg-col-25  { flex: 0 0 calc(25% - 16px); }    /* 4 columns */
.trcg-col-20  { flex: 0 0 calc(20% - 16px); }    /* 5 columns */
.trcg-col-16  { flex: 0 0 calc(16.666% - 16px); } /* 6 columns */

/* TOAST / NOTIFICATION */
.trcg-toast-container {
  position: fixed;
  top: 16px;
  right: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 9999;
}

.trcg-toast {
  min-width: 200px;
  padding: 12px 16px;
  border-radius: var(--trcg-radius);
  color: #fff;
  font-size: 14px;
  box-shadow: var(--trcg-shadow);
  opacity: 0;
  transform: translateX(100%);
  animation: trcg-toast-in 0.3s forwards, trcg-toast-out 0.3s forwards 3s;
}

/* Toast Variants */
.trcg-toast-success { background-color: var(--trcg-success); border: solid 2px color-mix(in srgb, black 20%, var(--trcg-success)); }
.trcg-toast-error   { background-color: var(--trcg-danger); border: solid 2px color-mix(in srgb, black 20%, var(--trcg-danger)); }
.trcg-toast-warning { background-color: var(--trcg-warning); border: solid 2px color-mix(in srgb, black 20%, var(--trcg-warning)); }
.trcg-toast-info    { background-color: var(--trcg-info); border: solid 2px color-mix(in srgb, black 20%, var(--trcg-info)); }

/* Animation */
@keyframes trcg-toast-in {
  from { opacity: 0; transform: translateX(100%); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes trcg-toast-out {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(100%); }
}

/* -------------------------
   MODAL
------------------------- */
.trcg-modal-overlay {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.45);
  z-index: 2000;
}

.trcg-modal {
  max-width: 420px;
  width: 100%;
  background-color: var(--trcg-surface-bg);
  border-radius: var(--trcg-radius);
  padding: 16px;
  box-shadow: var(--trcg-shadow);
  transition: transform var(--trcg-transition), opacity var(--trcg-transition);
}

/* -------------------------
   TRANSITIONS / ANIMATIONS
------------------------- */
.trcg-fade-in {
  opacity: 0;
  transform: translateY(-10px);
  animation: fadeIn 0.25s forwards;
}

@keyframes fadeIn {
  to { opacity: 1; transform: translateY(0); }
}
