/* ================================================================
  DiseñaThor - Estilos de términos y condiciones
  Archivo: assets/css/pages/terminos.css
  Uso: página pública /terminos
================================================================ */

/* ── VARIABLES ── */
:root {
  --color-cyan:       #00FFFF;
  --color-turquesa:   #40E0D0;
  --color-morado:     #8000FF;
  --color-fucsia:     #FF00FF;
  --color-negro:      #000000;
  --gradient-primary:   linear-gradient(135deg, var(--color-cyan), var(--color-fucsia));
  --gradient-electric:  linear-gradient(90deg, var(--color-cyan), var(--color-morado), var(--color-fucsia), var(--color-cyan));
  --bg-dark:          #050510;
  --bg-card:          #0d0d2b;
  --bg-surface:       rgba(255,255,255,0.04);
  --border-color:     rgba(0, 255, 255, 0.15);
  --border-hover:     rgba(0, 255, 255, 0.4);
  --text-primary:     #FFFFFF;
  --text-secondary:   rgba(255, 255, 255, 0.7);
  --text-muted:       rgba(255, 255, 255, 0.45);
  --accent-cyan:      #00FFFF;
  --accent-purple:    #8000FF;
  --font-heading: 'Montserrat', sans-serif;
  --font-body:    'Open Sans', sans-serif;
  --fs-xs:   0.75rem;
  --fs-sm:   0.875rem;
  --fs-base: 1rem;
  --fs-md:   1.125rem;
  --fs-lg:   1.25rem;
  --fs-xl:   1.5rem;
  --space-xs:  0.5rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2rem;
  --space-xl:  3rem;
  --space-2xl: 5rem;
  --radius-sm:  6px;
  --radius-md:  12px;
  --radius-lg:  20px;
  --radius-full: 9999px;
  --transition-fast: 0.15s ease;
  --transition-base: 0.3s ease;
  --navbar-height: 72px;
  --container-max: 1280px;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font-body); background-color:var(--bg-dark); color:var(--text-primary); line-height:1.6; overflow-x:hidden; cursor:none; }
input, textarea, select, button, a, details, summary { cursor:none; }
img, svg { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
ul, ol { list-style:none; }

/* ── CURSOR ── */
.cursor-dot { width:8px; height:8px; background:var(--color-cyan); border-radius:50%; position:fixed; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:background var(--transition-fast), transform var(--transition-fast); box-shadow:0 0 10px var(--color-cyan); }
.cursor-ring { width:36px; height:36px; border:2px solid rgba(0,255,255,0.5); border-radius:50%; position:fixed; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:transform 0.12s ease, width var(--transition-base), height var(--transition-base); }
body.cursor-hover .cursor-dot { transform:translate(-50%,-50%) scale(0.5); background:var(--color-fucsia); }
body.cursor-hover .cursor-ring { width:56px; height:56px; border-color:rgba(255,0,255,0.6); }

/* ── CANVAS ── */
.particle-canvas { position:fixed; top:0; left:0; width:100%; height:100%; pointer-events:none; z-index:0; opacity:0.4; }

/* ── CONTAINER ── */
.container { max-width:var(--container-max); margin:0 auto; padding:0 var(--space-lg); position:relative; z-index:1; }

/* ── TIPOGRAFÍA ── */
h1,h2,h3,h4,h5,h6 { font-family:var(--font-heading); font-weight:700; line-height:1.2; color:var(--text-primary); }
.text-gradient { background:var(--gradient-electric); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; background-size:300% auto; animation:gradientShift 6s linear infinite; }
@keyframes gradientShift { 0%{background-position:0% center;} 100%{background-position:-300% center;} }

/* ── BOTONES ── */
.btn { display:inline-flex; align-items:center; gap:var(--space-xs); padding:0.75rem 1.75rem; border-radius:var(--radius-full); font-family:var(--font-heading); font-weight:600; font-size:var(--fs-sm); border:none; cursor:pointer; transition:all var(--transition-base); position:relative; overflow:hidden; text-decoration:none; }
.btn::before { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent); transition:left 0.5s ease; }
.btn:hover::before { left:100%; }
.btn-primary { background:var(--gradient-primary); color:var(--color-negro); font-weight:700; box-shadow:0 4px 20px rgba(0,255,255,0.25); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(0,255,255,0.4); }

/* ── SECTION TAG ── */
.section-tag { display:inline-block; font-family:var(--font-heading); font-size:var(--fs-xs); font-weight:600; letter-spacing:0.15em; text-transform:uppercase; color:var(--color-cyan); background:rgba(0,255,255,0.08); border:1px solid rgba(0,255,255,0.25); padding:0.3rem 1rem; border-radius:var(--radius-full); margin-bottom:var(--space-sm); }

/* ── NAVBAR ── */
.navbar { position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--navbar-height); display:flex; align-items:center; transition:background var(--transition-base), box-shadow var(--transition-base); }
.navbar .container { display:flex; align-items:center; justify-content:space-between; gap:var(--space-lg); width:100%; }
.navbar.scrolled { background:rgba(5,5,16,0.85); -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px); box-shadow:0 1px 0 var(--border-color); }
.logo { display:flex; align-items:center; gap:0.6rem; text-decoration:none; }
.logo-svg { width:28px; height:42px; flex-shrink:0; }
.logo-text { font-family:var(--font-heading); font-weight:900; font-size:var(--fs-xl); color:var(--text-primary); line-height:1; }
.logo-accent { background:var(--gradient-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.nav-list { display:flex; align-items:center; gap:var(--space-xs); }
.nav-link { font-family:var(--font-heading); font-weight:600; font-size:var(--fs-sm); color:var(--text-secondary); padding:0.5rem 0.75rem; border-radius:var(--radius-sm); transition:color var(--transition-fast); position:relative; }
.nav-link::after { content:''; position:absolute; bottom:-2px; left:50%; transform:translateX(-50%); width:0; height:2px; background:var(--gradient-primary); border-radius:var(--radius-full); transition:width var(--transition-base); }
.nav-link:hover { color:var(--text-primary); }
.nav-link:hover::after { width:60%; }
.nav-cta { margin-left:var(--space-xs); }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:0.5rem; }
.hamburger span { display:block; width:24px; height:2px; background:var(--text-primary); border-radius:var(--radius-full); transition:all var(--transition-base); }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── LANGUAGE SWITCH ── */
.lang-switch {
  position: relative;
}

.lang-switch-btn {
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.8rem;
  color: var(--text-primary);
  padding: 0.45rem 0.65rem;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.05);
  cursor: pointer;
}

.lang-switch-btn::-webkit-details-marker {
  display: none;
}

.lang-switch[open] .lang-switch-btn {
  border-color: rgba(255, 255, 255, 0.35);
}

.lang-switch-menu {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  min-width: 150px;
  display: grid;
  gap: 0.25rem;
  padding: 0.35rem;
  border-radius: 12px;
  border: 1px solid var(--border-color);
  background: rgba(8, 8, 22, 0.95);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.35);
  z-index: 20;
}

.lang-switch:not([open]) .lang-switch-menu {
  display: none;
}

.lang-switch-menu a {
  display: block;
  padding: 0.5rem 0.65rem;
  border-radius: 8px;
  font-size: 0.86rem;
  color: var(--text-secondary);
}

.lang-switch-menu a:hover,
.lang-switch-menu a[aria-current="page"] {
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.08);
}

/* ── FOOTER ── */
.footer { background:#020209; border-top:1px solid var(--border-color); padding:var(--space-2xl) 0 var(--space-lg); position:relative; z-index:1; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:var(--space-xs); }
.footer-bottom p { font-size:var(--fs-xs); color:var(--text-muted); }

/* ── SCROLL TOP ── */
.scroll-top { position:fixed; bottom:var(--space-lg); right:var(--space-lg); z-index:500; width:48px; height:48px; border-radius:50%; background:var(--gradient-primary); border:none; color:var(--color-negro); display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; transform:translateY(20px); transition:opacity var(--transition-base), transform var(--transition-base); box-shadow:0 4px 20px rgba(0,255,255,0.3); }
.scroll-top.visible { opacity:1; transform:translateY(0); }
.scroll-top:hover { transform:translateY(-4px); }

/* ── AOS ── */
[data-aos] { opacity:0; transition:opacity 0.7s ease, transform 0.7s ease; }
[data-aos="fade-up"]    { transform:translateY(40px); }
[data-aos="fade-down"]  { transform:translateY(-40px); }
[data-aos="fade-right"] { transform:translateX(-60px); }
[data-aos].aos-animate  { opacity:1; transform:translate(0,0) scale(1); }

/* ══════════════════════════════════════════════════════════
   ESTILOS PROPIOS DE TÉRMINOS Y CONDICIONES
══════════════════════════════════════════════════════════ */
.terms-hero { padding:10rem 0 4rem; text-align:center; }
.terms-hero h1 { font-size:clamp(2rem,5vw,3.5rem); font-weight:900; margin-bottom:1rem; }
.terms-hero p { color:var(--text-secondary); max-width:600px; margin:0 auto; font-size:var(--fs-md); line-height:1.7; }
.terms-main { max-width:900px; padding-bottom:5rem; }

.terms-toc { background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); padding:2rem; margin-bottom:3rem; }
.terms-toc h3 { font-size:0.7rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--text-muted); margin-bottom:1rem; }
.terms-toc ol { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:0.4rem; }
.terms-toc ol li a { color:var(--text-secondary); text-decoration:none; font-size:0.82rem; display:flex; align-items:center; gap:0.5rem; padding:0.3rem 0; transition:color 0.2s; line-height:1.4; }
.terms-toc ol li a:hover { color:var(--accent-cyan); }
.terms-toc ol li a .toc-icon { color:var(--accent-cyan); font-size:0.65rem; flex-shrink:0; opacity:0.6; }

/* Compatibilidad con estructura actual de terminos.html */
.terms-index .index-title { font-size:0.7rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--text-muted); margin-bottom:1rem; }
.terms-index ul { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:0.4rem; }
.terms-index ul li a { color:var(--text-secondary); text-decoration:none; font-size:0.82rem; display:flex; align-items:center; gap:0.5rem; padding:0.3rem 0; transition:color 0.2s; line-height:1.4; }
.terms-index ul li a:hover { color:var(--accent-cyan); }

.terms-article { background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius-lg); padding:2.5rem; margin-bottom:1.5rem; transition:border-color 0.3s; scroll-margin-top:100px; }
.terms-article:hover { border-color:var(--accent-purple); }

.terms-article > h2 { font-size:clamp(1.05rem,2.5vw,1.35rem); font-weight:700; margin:0 0 1rem; line-height:1.3; }
.terms-article > p { color:var(--text-secondary); line-height:1.8; margin-bottom:1rem; font-size:0.9rem; }
.terms-article > p:last-child { margin-bottom:0; }
.terms-article > ul { list-style:none; padding:0; margin:1rem 0 0.5rem; display:flex; flex-direction:column; gap:0.7rem; }
.terms-article > ul li { color:var(--text-secondary); font-size:0.9rem; line-height:1.75; }

.art-label { display:inline-block; background:rgba(105,18,208,0.25); border:1px solid var(--accent-purple); color:var(--accent-purple); font-size:0.62rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; padding:0.3rem 0.7rem; border-radius:6px; white-space:nowrap; margin-bottom:0.8rem; }

.article-header { display:flex; align-items:center; gap:1rem; margin-bottom:1.5rem; padding-bottom:1.5rem; border-bottom:1px solid var(--border-color); }
.article-badge { background:rgba(105,18,208,0.25); border:1px solid var(--accent-purple); color:var(--accent-purple); font-size:0.62rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; padding:0.3rem 0.7rem; border-radius:6px; white-space:nowrap; flex-shrink:0; }
.article-header h2 { font-size:clamp(1.05rem,2.5vw,1.35rem); font-weight:700; margin:0; line-height:1.3; }

.article-body > p { color:var(--text-secondary); line-height:1.8; margin-bottom:1rem; font-size:0.9rem; }
.article-body > p:last-child { margin-bottom:0; }

.terms-list { list-style:none; padding:0; margin:1rem 0 0.5rem; display:flex; flex-direction:column; gap:1rem; }
.terms-list li { display:flex; align-items:flex-start; gap:0.8rem; }
.terms-list li .li-icon { color:var(--accent-cyan); font-size:0.72rem; flex-shrink:0; line-height:1; margin-top:0.38em; }
.terms-list li .li-text { flex:1 1 0%; color:var(--text-secondary); font-size:0.9rem; line-height:1.75; }
.terms-list li .li-text strong { color:var(--text-primary); font-weight:600; }

.terms-table-wrap { overflow-x:auto; margin:1.25rem 0; border-radius:var(--radius-md); border:1px solid var(--border-color); }
.terms-table { width:100%; border-collapse:collapse; font-size:0.87rem; }
.terms-table thead { background:rgba(0,255,255,0.07); }
.terms-table thead th { padding:0.9rem 1.2rem; text-align:left; font-weight:700; font-size:0.67rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--accent-cyan); border-bottom:1px solid var(--border-color); }
.terms-table tbody td { padding:0.85rem 1.2rem; color:var(--text-secondary); border-bottom:1px solid rgba(255,255,255,0.04); vertical-align:middle; }
.terms-table tbody tr:last-child td { border-bottom:none; }
.terms-table .pct { color:var(--accent-cyan); font-weight:700; }

.terms-note { display:flex; gap:1rem; align-items:flex-start; background:rgba(255,165,0,0.07); border:1px solid rgba(255,165,0,0.3); border-radius:var(--radius-md); padding:1.2rem 1.4rem; margin-top:1.25rem; }
.terms-note--cyan   { background:rgba(0,255,255,0.06);    border-color:rgba(0,255,255,0.25); }
.terms-note--purple { background:rgba(105,18,208,0.08);   border-color:rgba(105,18,208,0.35); }
.terms-note .note-icon { font-size:1.15rem; flex-shrink:0; margin-top:0.05rem; }
.terms-note p { color:var(--text-secondary); line-height:1.75; font-size:0.87rem; margin:0 !important; }
.terms-note p strong { color:var(--text-primary); }

.payment-channels { display:grid; grid-template-columns:repeat(auto-fill,minmax(165px,1fr)); gap:0.85rem; margin:1.25rem 0; }
.payment-channel { background:rgba(255,255,255,0.03); border:1px solid var(--border-color); border-radius:var(--radius-md); padding:0.9rem 1.1rem; display:flex; align-items:center; gap:0.7rem; transition:border-color 0.2s; }
.payment-channel:hover { border-color:var(--accent-cyan); }
.payment-channel .pc-icon { font-size:1.3rem; flex-shrink:0; }
.payment-channel .pc-name { font-weight:600; color:var(--text-primary); font-size:0.85rem; line-height:1.3; }

.back-link { display:inline-flex; align-items:center; gap:0.5rem; color:var(--text-muted); text-decoration:none; font-size:0.85rem; margin-bottom:2rem; transition:color 0.2s; }
.back-link:hover { color:var(--accent-cyan); }

.terms-meta { text-align:center; color:var(--text-muted); font-size:0.8rem; margin-top:3rem; padding-top:2rem; border-top:1px solid var(--border-color); line-height:1.8; }
.terms-meta a { color:var(--accent-cyan); }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  :root { --navbar-height:64px; }
  .nav-menu { position:fixed; top:var(--navbar-height); left:0; right:0; background:rgba(5,5,16,0.97); -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px); border-bottom:1px solid var(--border-color); padding:var(--space-md); transform:translateY(-100%); opacity:0; pointer-events:none; transition:transform var(--transition-base), opacity var(--transition-base); z-index:999; }
  .nav-menu.open { transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav-list { flex-direction:column; gap:var(--space-xs); }
  .nav-link { display:block; padding:var(--space-sm) var(--space-md); font-size:var(--fs-base); }
  .hamburger { display:flex; }
  .nav-cta { display:none; }
  .lang-switch { margin-left: auto; }
  .lang-switch-menu { right: 0; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .cursor-dot, .cursor-ring { display:none; }
  body { cursor:auto; }
  a, button { cursor:pointer; }
  .terms-article { padding:1.5rem; }
  .article-header { flex-wrap:wrap; gap:0.6rem; }
  .payment-channels { grid-template-columns:1fr 1fr; }
}
@media (max-width:480px) {
  .container { padding:0 var(--space-sm); }
}
