/**
 * -----------------------------------------------------------------
 * DEFINICIÓN DE FUENTES
 * -----------------------------------------------------------------
 */
@font-face {
  font-family: 'Inter';
  src: url('../fonts/Inter.woff2') format('woff2');
  font-display: swap;
}

@font-face {
  font-family: 'Lora';
  src: url('../fonts/Lora.woff2') format('woff2');
  font-display: swap;
}

@font-face {
  font-family: 'Rubik';
  src: url('../fonts/Rubik.woff2') format('woff2');
  font-display: swap;
}

/* * {border: 1px solid blue} */
/**
 * -----------------------------------------------------------------
 * VARIABLES GLOBALES (CUSTOM PROPERTIES)
 * -----------------------------------------------------------------
 * Centraliza los valores de diseño para fácil mantenimiento.
 */
/*
:root {
    /* Paleta base (modo clásico) */
/* --color-principal: #a54603;
    --color-principal-hover: #d57003;
    --color-enfasis: #990000; */

/* Tipografías */
/* --fuente-inter: 'Inter', sans-serif;
    --fuente-lora: 'Lora', serif;
    --fuente-rubik: 'Rubik', sans-serif; */

/* Transiciones */
/* --transicion-rapida: all 0.3s ease;
    --transicion-suave: all 0.4s ease;
    --transicion-modal: opacity 0.5s ease, visibility 0.5s ease; */

/* Colores globales (respaldo para temas) */
/* --bg: #ffffff;
    --text-color: #333;
    --color-principal: var(--color-principal);
    --header-bg: rgba(255,255,255,0.95);
    --sidebar-bg: rgba(255,255,255,0.95);
    --shadow-soft: 0 2px 12px rgba(0,0,0,0.05);
    --glow-subtle: 0 0 20px rgba(0,0,0,0.1);
} */

/* -----------------------------------------------------------------
   SISTEMA DE TEMAS VISUALES: DHARMA MODERNO & ZEN MINIMALISTA
   ----------------------------------------------------------------- */



:root {
  /* Tipografías */
  --fuente-inter: 'Inter', sans-serif;
  --fuente-lora: 'Lora', serif;
  --fuente-rubik: 'Rubik', sans-serif;
}

/* === Paletas Budistas Expandidas === */

/* Dharma Moderno (original + expandido) */
:root[data-theme="dharma"] {
  /* Variables originales (mantener intactas) */
  --bg: radial-gradient(circle at 50% 20%, #ffffff 0%, #f8f3ff 100%);
  --text-color: #2d2c2b;
  --color-principal: #7b4c94;
  --text-color-rgb: rgb(45, 44, 43, 0.55);
  --color-principal-hover: #9465b5;
  --header-bg: rgba(255, 255, 255, 0.9);
  --sidebar-bg: rgba(255, 255, 255, 0.85);
  --shadow-soft: 0 4px 20px rgba(123, 76, 148, 0.15);
  --glow-subtle: 0 0 25px rgba(123, 76, 148, 0.25);

  /* Variables nuevas adicionales */
  --bg-secondary: #faf7fc;
  --text-secondary: #5a5856;
  --text-muted: rgba(45, 44, 43, 0.55);
  --accent-light: #c4a7d9;
  --accent-dark: #5a3570;
  --surface-card: rgba(255, 255, 255, 0.95);
  --surface-overlay: rgba(123, 76, 148, 0.05);
  --shadow-medium: 0 8px 30px rgba(123, 76, 148, 0.2);
  --shadow-strong: 0 12px 40px rgba(123, 76, 148, 0.25);
  --glow-medium: 0 0 35px rgba(123, 76, 148, 0.35);
  --border-light: rgba(123, 76, 148, 0.1);
  --border-medium: rgba(123, 76, 148, 0.2);
  --border-accent: rgba(123, 76, 148, 0.4);
  --success: #4a9d5f;
  --warning: #d4a347;
  --error: #c94d4d;
  --info: #5b8fb9;
}

/* Zen Minimalista (original + expandido) */
:root[data-theme="zen"] {
  /* Variables originales (mantener intactas) */
  --bg: linear-gradient(to bottom, #ffffff, #f8f8f4);
  --text-color: #333;
  --color-principal: #b88b57;
  --color-principal-hover: #c79c68;
  --header-bg: rgba(255, 255, 255, 0.95);
  --sidebar-bg: rgba(255, 255, 255, 0.85);
  --shadow-soft: 0 2px 12px rgba(0, 0, 0, 0.05);
  --glow-subtle: 0 0 20px rgba(184, 139, 87, 0.15);

  /* Variables nuevas adicionales */
  --bg-secondary: #f5f5f0;
  --text-secondary: #666666;
  --text-color-rgb: rgba(51, 51, 51, 0.5);
  --text-muted: rgba(51, 51, 51, 0.5);
  --accent-light: #ddb890;
  --accent-dark: #9a7045;
  --surface-card: rgba(255, 255, 255, 0.9);
  --surface-overlay: rgba(184, 139, 87, 0.03);
  --shadow-medium: 0 4px 20px rgba(0, 0, 0, 0.08);
  --shadow-strong: 0 8px 30px rgba(0, 0, 0, 0.12);
  --glow-medium: 0 0 30px rgba(184, 139, 87, 0.25);
  --border-light: rgba(184, 139, 87, 0.1);
  --border-medium: rgba(184, 139, 87, 0.15);
  --border-accent: rgba(184, 139, 87, 0.3);
  --success: #5fa662;
  --warning: #d9a84e;
  --error: #c75555;
  --info: #6b99be;
}

/* Sangha Granate - usando #800000 */
:root[data-theme="sangha"] {
  /* Variables originales */
  /* --bg: radial-gradient(circle at 50% 20%, #fff8f8 50%, #ffe8e8 100%); */
  --bg: radial-gradient(circle at 50% 20%, #fffdf8 50%, #fffdf8 100%);
  --text-color: #2b1a1a;
  --color-principal: #800000;
  --text-color-rgb: rgba(43, 26, 26, 0.55);
  --color-principal-hover: #a61f1f;
  --header-bg: rgba(255, 255, 255, 0.92);
  --sidebar-bg: rgba(255, 248, 248, 0.88);
  --shadow-soft: 0 4px 20px rgba(128, 0, 0, 0.12);
  --glow-subtle: 0 0 25px rgba(128, 0, 0, 0.2);

  /* Variables nuevas adicionales */
  --bg-secondary: #fff0f0;
  --text-secondary: #5c3838;
  --text-muted: rgba(43, 26, 26, 0.55);
  --accent-light: #c85050;
  --accent-dark: #5c0000;
  --surface-card: #e8e3e377;
  --surface-overlay: rgba(128, 0, 0, 0.04);
  --shadow-medium: 0 8px 30px rgba(128, 0, 0, 0.18);
  --shadow-strong: 0 12px 40px rgba(128, 0, 0, 0.24);
  --glow-medium: 0 0 35px rgba(128, 0, 0, 0.3);
  --border-light: rgba(128, 0, 0, 0.12);
  --border-medium: rgba(128, 0, 0, 0.2);
  --border-accent: rgba(128, 0, 0, 0.35);
  --success: #4a8f5a;
  --warning: #c79547;
  --error: #d44545;
  --info: #5c7fa8;
}

/* Amanecer Dorado - usando #bc6100 */
:root[data-theme="amanecer"] {
  /* Variables originales */
  --bg: radial-gradient(circle at 50% 20%, #fffaf5 0%, #fff0e0 100%);
  --text-color: #2d2416;
  --color-principal: #bc6100;
  --text-color-rgb: rgba(45, 36, 22, 0.55);
  --color-principal-hover: #d97a1f;
  --header-bg: rgba(255, 255, 255, 0.92);
  --sidebar-bg: rgba(255, 250, 245, 0.88);
  --shadow-soft: 0 4px 20px rgba(188, 97, 0, 0.12);
  --glow-subtle: 0 0 25px rgba(188, 97, 0, 0.22);

  /* Variables nuevas adicionales */
  --bg-secondary: #fff5ea;
  --text-secondary: #5a4830;
  --text-muted: rgba(45, 36, 22, 0.55);
  --accent-light: #e69a4d;
  --accent-dark: #8a4800;
  --surface-card: rgba(255, 255, 255, 0.95);
  --surface-overlay: rgba(188, 97, 0, 0.04);
  --shadow-medium: 0 8px 30px rgba(188, 97, 0, 0.18);
  --shadow-strong: 0 12px 40px rgba(188, 97, 0, 0.24);
  --glow-medium: 0 0 35px rgba(188, 97, 0, 0.32);
  --border-light: rgba(188, 97, 0, 0.12);
  --border-medium: rgba(188, 97, 0, 0.2);
  --border-accent: rgba(188, 97, 0, 0.35);
  --success: #5a9e5a;
  --warning: #d4a347;
  --error: #c95555;
  --info: #608fb8;
}

/* Loto Azul */
:root[data-theme="loto"] {
  /* Variables originales */
  --bg: radial-gradient(circle at 50% 20%, #f8fcff 0%, #e8f4ff 100%);
  --text-color: #1a2a3a;
  --color-principal: #2563a8;
  --text-color-rgb: rgba(26, 42, 58, 0.55);
  --color-principal-hover: #3b7bc9;
  --header-bg: rgba(255, 255, 255, 0.92);
  --sidebar-bg: rgba(248, 252, 255, 0.88);
  --shadow-soft: 0 4px 20px rgba(37, 99, 168, 0.12);
  --glow-subtle: 0 0 25px rgba(37, 99, 168, 0.22);

  /* Variables nuevas adicionales */
  --bg-secondary: #f0f8ff;
  --text-secondary: #3a4a5a;
  --text-muted: rgba(26, 42, 58, 0.55);
  --accent-light: #5a96db;
  --accent-dark: #1a4a7e;
  --surface-card: rgba(255, 255, 255, 0.95);
  --surface-overlay: rgba(37, 99, 168, 0.04);
  --shadow-medium: 0 8px 30px rgba(37, 99, 168, 0.18);
  --shadow-strong: 0 12px 40px rgba(37, 99, 168, 0.24);
  --glow-medium: 0 0 35px rgba(37, 99, 168, 0.32);
  --border-light: rgba(37, 99, 168, 0.12);
  --border-medium: rgba(37, 99, 168, 0.2);
  --border-accent: rgba(37, 99, 168, 0.35);
  --success: #4a9d65;
  --warning: #d4a847;
  --error: #c94d5d;
  --info: #3b7bc9;
}

/* Bosque Sereno */
:root[data-theme="bosque"] {
  /* Variables originales */
  --bg: radial-gradient(circle at 50% 20%, #f8faf8 0%, #e8f2e8 100%);
  --text-color: #1f2e1f;
  --color-principal: #3d7547;
  --text-color-rgb: rgba(31, 46, 31, 0.55);
  --color-principal-hover: #4f9060;
  --header-bg: rgba(255, 255, 255, 0.92);
  --sidebar-bg: rgba(248, 250, 248, 0.88);
  --shadow-soft: 0 4px 20px rgba(61, 117, 71, 0.12);
  --glow-subtle: 0 0 25px rgba(61, 117, 71, 0.22);

  /* Variables nuevas adicionales */
  --bg-secondary: #f0f5f0;
  --text-secondary: #3d4f3d;
  --text-muted: rgba(31, 46, 31, 0.55);
  --accent-light: #6aa87a;
  --accent-dark: #2a5332;
  --surface-card: rgba(255, 255, 255, 0.95);
  --surface-overlay: rgba(61, 117, 71, 0.04);
  --shadow-medium: 0 8px 30px rgba(61, 117, 71, 0.18);
  --shadow-strong: 0 12px 40px rgba(61, 117, 71, 0.24);
  --glow-medium: 0 0 35px rgba(61, 117, 71, 0.32);
  --border-light: rgba(61, 117, 71, 0.12);
  --border-medium: rgba(61, 117, 71, 0.2);
  --border-accent: rgba(61, 117, 71, 0.35);
  --success: #4f9060;
  --warning: #c79d47;
  --error: #b84d4d;
  --info: #5c8fa8;
}

/* Variables de tamaño y utilidades (globales) */
:root {
  /* Iconos (originales + nuevos) */
  --icon-xs: 12px;
  --icon-sm: 16px;
  --icon-md: 24px;
  --icon-lg: 32px;
  --icon-xl: 40px;
  --icon-xxl: 48px;

  /* Espaciado */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-xxl: 48px;

  /* Bordes radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* Tipografía */
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --font-size-3xl: 1.875rem;
  --font-size-4xl: 2.25rem;

  /* Transiciones */
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
  --transition-slow: 350ms ease;
  --transicion-rapida: all 0.3s ease;
  --transicion-suave: all 0.4s ease;
  --transicion-modal: opacity 0.5s ease, visibility 0.5s ease;

  /* Z-index */
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;
}



/* -------------------------------------------
   NOTA: .section-title-wrap movido a components.css
------------------------------------------- */


.color-claro {
  color: var(--header-bg) !important
}
.fondo-claro {
  background-color: var(--header-bg) !important;
}

.sombra {
  box-shadow: #000;
}
.difuminado {
  backdrop-filter: blur(10px);
}

.sombra-texto {
  text-shadow: 2px 1px 3px var(--text-color);
}






.icon {
  fill: currentColor;
}

.icon-sm {
  width: var(--icon-sm);
  height: var(--icon-sm);
}

.icon-md {
  width: var(--icon-md);
  height: var(--icon-md);
}

.icon-lg {
  width: var(--icon-lg);
  height: var(--icon-lg);
}





body {
  background: var(--bg);
  font-family: var(--fuente-inter);
  /* 🔥 Mejora la consistencia entre fuentes */
  font-size-adjust: 0.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
 
}


/* -----------------------------------------------------------------
   UTILIDADES Y ESTADOS
   ----------------------------------------------------------------- */
.borde {
  border: 1px solid var(--color-principal);
}

.centrado {
  text-align: center;
  margin: 0 auto
}
.hidden {
  display: none !important;
}

/* ======== Estado maximizado ======== */
body.maximized {
  overflow: hidden;
}

/* El iframe ocupa toda la pantalla menos el header */
body.maximized #docFrame.full-view {
  position: fixed;
  top: calc(var(--header-height, 60px) + var(--controls-height, 45px));
  left: 0;
  width: 100%;
  height: calc(100vh - (var(--header-height, 60px) + var(--controls-height, 45px)));
  border: none;
  z-index: 50;
  background: #000;
}

/* Mantén visible el header y los controles */
body.maximized .header.compacto,
body.maximized .controls,
body.maximized #floating-controls {
  display: flex !important;
  z-index: 100;
}

.header-interno {
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 1px 12px rgba(123, 76, 148, 0.05);
  border-bottom: 1.5px solid var(--color-principal);
}

.footer-interno {
  background: rgba(255, 255, 255, 0.95);
  /* border-top: 1px solid var(--color-principal); */
  font-size: 0.99rem;
  color: #777;
}

.footer-interno a {
  color: var(--color-principal);
  text-decoration: underline;
}

.footer-interno a:hover {
  color: var(--color-principal-hover);
}


/* === Utilidades responsive === */

/* Ocultar en móvil (por debajo de 460px) */
.solo-desktop {
  display: block;
}
@media (max-width: 460px) {
  .solo-desktop {
    display: none !important;
  }
}

/* Ocultar en escritorio (a partir de 460px) */
.solo-movil {
  display: none;
}
@media (max-width: 460px) {
  .solo-movil {
    display: block !important;
  }
}
