/* =====================================================
   THEMES KING — Identidad "Sala del Trono"
   Display: Cinzel · Cuerpo: Manrope · Acento: oro heráldico
   ===================================================== */
:root{
  --ink:#121014;          /* fondo carbón cálido */
  --panel:#1B1820;        /* paneles */
  --panel-2:#221E29;      /* paneles elevados */
  --line:#332D3C;         /* bordes */
  --gold:#D9A441;
  --gold-2:#F0C75E;
  --gold-grad:linear-gradient(135deg,#F0C75E 0%,#D9A441 45%,#A87B22 100%);
  --parchment:#EDE6D8;    /* texto principal */
  --muted:#9B948A;        /* texto secundario */
  --crimson:#8E2C3A;      /* velvet real, usar con moderación */
  --ok:#3F9D6B; --warn:#C98A2D; --err:#C04545;
  --radius:14px;
  --shadow:0 14px 40px rgba(0,0,0,.45);
  --font-display:'Cinzel',serif;
  --font-body:'Manrope',system-ui,sans-serif;
  --font-mono:ui-monospace,'JetBrains Mono',Menlo,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
body{
  background:var(--ink);color:var(--parchment);
  font-family:var(--font-body);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
/* textura sutil de damasco con gradientes radiales */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(700px 360px at 85% -5%, rgba(217,164,65,.07), transparent 60%),
    radial-gradient(560px 320px at 0% 100%, rgba(142,44,58,.06), transparent 60%);
}
main,header.site,footer.site{position:relative;z-index:1}
a{color:var(--gold-text);text-decoration:none}
a:hover{color:var(--link-hover)}
img{max-width:100%;display:block}
:focus-visible{outline:2px solid var(--gold-2);outline-offset:3px;border-radius:4px}

.container{max-width:1200px;margin:0 auto;padding:0 22px}
.container.nav{max-width:1280px}

/* ---------- Tipografía real ---------- */
h1,h2,h3,.display{font-family:var(--font-display);font-weight:700;letter-spacing:.04em;color:var(--heading)}
h1{font-size:clamp(2rem,4.6vw,3.4rem);line-height:1.12}
h2{font-size:clamp(1.4rem,2.6vw,2rem)}
.eyebrow{
  font-family:var(--font-body);font-size:.74rem;font-weight:700;
  letter-spacing:.32em;text-transform:uppercase;color:var(--gold-text);
}

/* Regla real: línea con diamante (elemento firma) */
.royal-rule{display:flex;align-items:center;gap:14px;margin:14px 0 26px}
.royal-rule::before,.royal-rule::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--line))}
.royal-rule::after{background:linear-gradient(90deg,var(--line),transparent)}
.royal-rule i{
  width:9px;height:9px;background:var(--gold-grad);
  transform:rotate(45deg);flex:none;box-shadow:0 0 12px rgba(217,164,65,.5);
}

/* ---------- Header ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(18,16,20,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:28px;height:74px}
.brand{display:flex;align-items:center;gap:12px;color:var(--brand1);white-space:nowrap;flex-shrink:0}
.brand img{width:46px;height:46px}
.brand b{font-family:var(--font-display);font-size:1.22rem;letter-spacing:.08em}
.brand b span{color:var(--gold-text)}
.nav-links{display:flex;gap:12px;margin-left:auto;align-items:center;flex:1;min-width:0}
/* Reparto del header: el primer item y el selector de idioma absorben el espacio
   sobrante a partes iguales -> logo | menus centrados | controles a la derecha */
.nav-links > :first-child{margin-left:auto}
header.site .nav-links .lang-dd{margin-left:auto}
.nav-links a{color:var(--header-text);font-weight:600;font-size:.94rem}
/* Los enlaces de menú (texto) conservan su separación amplia vía padding;
   los controles (selector, tema, botones) quedan a 12px entre sí */
.nav-links > a:not(.btn),.nav-dd-toggle{padding:6px 7px}
.nav-links a:hover,.nav-links a.active{color:var(--gold-text)}
.nav-burger{display:none;margin-left:auto;background:none;border:1px solid var(--line);
  color:var(--gold-2);border-radius:8px;padding:8px 12px;font-size:1.1rem;cursor:pointer}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 26px;border-radius:10px;border:1px solid transparent;
  font-family:var(--font-body);font-weight:700;font-size:.95rem;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold-grad);color:var(--btn-gold-text);box-shadow:0 2px 8px rgba(217,164,65,.14)}
.btn-gold:hover{box-shadow:0 3px 12px rgba(217,164,65,.20);color:var(--btn-gold-text)}
.btn-ghost{border-color:var(--line);color:var(--parchment);background:transparent}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-text)}
.btn-sm{padding:9px 16px;font-size:.85rem;border-radius:8px}
.btn-danger{background:var(--crimson);color:#fff}

/* ---------- Hero ---------- */
.hero{padding:96px 0 64px;text-align:center;position:relative;overflow:hidden}
.hero .crest{width:118px;height:118px;margin:0 auto 22px;filter:drop-shadow(0 10px 30px rgba(217,164,65,.35));
  animation:crest-in .9s cubic-bezier(.2,.8,.2,1) both}
@keyframes crest-in{from{opacity:0;transform:translateY(-18px) scale(.92)}to{opacity:1;transform:none}}
.hero h1 span{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{max-width:620px;margin:18px auto 30px;color:var(--muted);font-size:1.08rem}
.hero .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Secciones ---------- */
section.block{padding:56px 0}
.section-head{text-align:center;max-width:560px;margin:0 auto 36px}

/* ---------- Grid de categorías ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:18px}
.cat-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;text-align:center;transition:.2s;color:var(--parchment);
  display:flex;flex-direction:column;
}
.cat-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--shadow)}
/* Arte flotante: PNG transparente directo sobre la tarjeta, con halo dorado sutil */
.cat-art{
  display:flex;align-items:center;justify-content:center;height:150px;
  padding:18px 16px 6px;position:relative;
  background:radial-gradient(ellipse 70% 60% at 50% 55%,
    color-mix(in srgb, var(--gold) 9%, transparent), transparent 75%);
}
.cat-art img{
  max-width:80%;max-height:100%;object-fit:contain;transition:transform .3s ease;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.35));
}
.cat-card:hover .cat-art img{transform:scale(1.06) translateY(-2px)}
.cat-art-emoji{font-size:2.6rem}
.cat-body{display:block;padding:6px 14px 20px}
.cat-card b{font-family:var(--font-display);letter-spacing:.05em;display:block;color:var(--heading)}


/* ---------- Tarjetas de producto ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:22px}
.prod-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:.2s;position:relative;
}
.prod-card::before{ /* filo de pan de oro al hover */
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gold-grad);opacity:0;transition:.25s;z-index:2;
}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#4A4154}
.prod-card:hover::before{opacity:1}
.prod-thumb{aspect-ratio:16/10;background:var(--panel-2);overflow:hidden}
.prod-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.prod-card:hover .prod-thumb img{transform:scale(1.05)}
.prod-thumb .ph{display:flex;align-items:center;justify-content:center;height:100%;opacity:.35}
.prod-thumb .ph img{width:64px;height:64px;object-fit:contain}
.prod-body{padding:18px 18px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.prod-body .cat{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-text)}
.prod-body h3{font-size:1.04rem;letter-spacing:.02em}
.prod-body h3 a{color:var(--heading)}
.prod-body h3 a:hover{color:var(--gold-text)}
.prod-body p{color:var(--muted);font-size:.88rem;flex:1}
.prod-foot{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.price{font-family:var(--font-display);font-weight:700;color:var(--gold-text);font-size:1.06rem}
.price small{color:var(--muted);font-family:var(--font-body);font-weight:500}
.badge{display:inline-block;padding:3px 10px;border-radius:99px;font-size:.7rem;font-weight:700;letter-spacing:.06em}
.badge-gold{background:rgba(217,164,65,.14);color:var(--gold-2);border:1px solid rgba(217,164,65,.4)}
.badge-warn{background:rgba(201,138,45,.15);color:#F0CF94;border:1px solid rgba(201,138,45,.4)}
.badge-muted{background:rgba(140,140,140,.12);color:var(--muted);border:1px solid var(--line)}
.badge-ok{background:rgba(63,157,107,.15);color:#7ED6A8;border:1px solid rgba(63,157,107,.4)}
.badge-err{background:rgba(192,69,69,.14);color:#E89090;border:1px solid rgba(192,69,69,.4)}

/* ---------- Ficha de producto ---------- */
.product-layout{display:grid;grid-template-columns:1.6fr 1fr;gap:34px;align-items:start;padding:46px 0}
.gallery .main{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--panel-2)}
.gallery .main img{width:100%;aspect-ratio:16/10;object-fit:cover}
.gallery .thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.gallery .thumbs img{width:88px;height:60px;object-fit:cover;border-radius:8px;border:2px solid var(--line);cursor:pointer;opacity:.65;transition:.15s}
.gallery .thumbs img:hover,.gallery .thumbs img.on{opacity:1;border-color:var(--gold)}
.buy-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}

.buy-box h1{font-size:1.3rem;margin-bottom:5px}
.lic-option{
  display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:10px;
  padding:10px 14px;margin:8px 0;cursor:pointer;transition:.15s;background:var(--panel-2);
}
.lic-option:hover{border-color:var(--gold)}
.lic-option input{accent-color:var(--gold)}
.lic-option.sel{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset}
.lic-option .nm{font-weight:700;color:var(--heading)}
.lic-option small{color:var(--muted);display:block}
.lic-option .pr{margin-left:auto;font-family:var(--font-display);color:var(--gold-text);font-weight:700}
.meta-list{list-style:none;margin-top:14px;border-top:1px solid var(--line);padding-top:10px;font-size:.88rem}
.meta-list li{display:flex;justify-content:space-between;padding:4px 0;color:var(--muted)}
.meta-list li b{color:var(--parchment);font-weight:600}
.prose{max-width:860px;color:#CFC8BC}
.prose h2,.prose h3{margin:26px 0 10px}
.prose p{margin:12px 0}
.prose ul{margin:12px 0 12px 22px}

/* ---------- Formularios ---------- */
.form-card{max-width:430px;margin:60px auto;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.form-card .crest{width:64px;margin:0 auto 14px;display:block}
.form-card h1{font-size:1.4rem;text-align:center;margin-bottom:22px}
label{display:block;font-weight:600;font-size:.88rem;margin:14px 0 6px;color:var(--parchment)}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=url],
select,textarea{
  width:100%;background:var(--ink);border:1px solid var(--line);border-radius:9px;
  color:var(--parchment);padding:12px 14px;font:inherit;font-size:.95rem;transition:border .15s;
}
input:focus,select:focus,textarea:focus{border-color:var(--gold);outline:none}
textarea{min-height:130px;resize:vertical}
.form-foot{margin-top:22px;text-align:center;color:var(--muted);font-size:.9rem}

/* ---------- Flash ---------- */
.flash{max-width:1200px;margin:16px auto 0;padding:0 22px}
.flash div{padding:13px 18px;border-radius:10px;margin-bottom:10px;font-weight:600;border:1px solid;text-align:center}
.flash .ok{background:rgba(63,157,107,.12);border-color:rgba(63,157,107,.5);color:#9FE2C0}
.flash .error{background:rgba(192,69,69,.12);border-color:rgba(192,69,69,.5);color:#F0A8A8}
.flash .warn{background:rgba(201,138,45,.12);border-color:rgba(201,138,45,.5);color:#F0CF94}

/* ---------- Tablas (cuenta / admin) ---------- */
.table-wrap{overflow-x:auto;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-text);text-align:left}
th,td{padding:13px 16px;border-bottom:1px solid var(--line)}
tr:last-child td{border-bottom:0}
tbody tr:hover{background:rgba(217,164,65,.04)}
.kbd{font-family:var(--font-mono);background:var(--ink);border:1px solid var(--line);
  border-radius:6px;padding:3px 8px;font-size:.82rem;color:var(--gold-2)}

/* ---------- Footer ---------- */
footer.site{border-top:1px solid var(--line);margin-top:70px;padding:44px 0 30px;background:var(--footer-bg)}
.foot-grid{display:flex;gap:40px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start}
.foot-grid .col small{color:var(--muted);display:block;max-width:300px;margin-top:8px}
.foot-grid b{font-family:var(--font-display);letter-spacing:.06em;color:var(--footer-heading);display:block;margin-bottom:10px}
.foot-grid a{display:block;color:var(--footer-text);padding:3px 0;font-size:.92rem}
.foot-grid a:hover{color:var(--gold-text)}
.copy{text-align:center;color:var(--footer-text);font-size:.82rem;margin-top:34px;letter-spacing:.04em}

/* ---------- Empty state ---------- */
.empty{text-align:center;padding:70px 20px;color:var(--muted)}
.empty img{width:80px;margin:0 auto 16px;opacity:.4}

/* ---------- Admin layout ---------- */
.admin-wrap{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{background:var(--panel);border-right:1px solid var(--line);padding:22px 16px;position:sticky;top:0;height:100vh}
.admin-side .brand{margin-bottom:26px;padding:0 8px}
.admin-side a.item{display:flex;gap:10px;align-items:center;color:var(--muted);font-weight:600;
  padding:11px 12px;border-radius:9px;margin-bottom:4px;font-size:.93rem}
.admin-side a.item:hover{background:var(--panel-2);color:var(--parchment)}
.admin-side a.item.on{background:rgba(217,164,65,.12);color:var(--gold-text)}
.admin-main{padding:30px 34px;min-width:0}
.admin-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;gap:16px;flex-wrap:wrap}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:30px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.stat b{font-family:var(--font-display);font-size:1.7rem;color:var(--gold-text);display:block}
.stat small{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:.7rem}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .product-layout{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .admin-wrap{grid-template-columns:1fr}
  .admin-side{position:static;height:auto;display:flex;gap:6px;overflow-x:auto;align-items:center}
  .admin-side .brand{margin:0 14px 0 0}
  .grid-2{grid-template-columns:1fr}
}
@media(max-width:1180px){
  .nav-links{gap:9px}
  .nav-links > a:not(.btn),.nav-dd-toggle{padding:6px 4px}
}
@media(max-width:980px){
  /* Panel del menú móvil: anclado al header sticky, alto de viewport con scroll propio.
     OJO: no usar position:fixed aquí — el backdrop-filter del header lo convierte en
     containing block y colapsa el panel. */
  .nav-links{
    display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;
    height:calc(100vh - 74px);height:calc(100dvh - 74px);
    background:var(--panel);padding:6px 22px 40px;gap:0;align-items:stretch;
    overflow-y:auto;-webkit-overflow-scrolling:touch;z-index:49;
  }
  .nav-links.open{display:flex}
  body.nav-open{overflow:hidden}
  .nav-burger{display:block}
  .nav-links > :first-child,header.site .nav-links .lang-dd{margin-left:0}
  /* Filas del menú */
  .nav-links > a:not(.btn),.nav-links .nav-dd{border-bottom:1px solid var(--line)}
  .nav-links > a:not(.btn){padding:15px 2px;font-size:1rem}
  .nav-links .nav-dd{display:block}
  .nav-links .nav-dd-toggle{display:flex;justify-content:space-between;align-items:center;padding:15px 2px;font-size:1rem;width:100%}
  .nav-links .nav-dd:hover .caret{transform:none}
  .nav-links .nav-dd.open > .nav-dd-toggle .caret{transform:rotate(180deg)}
  /* Submenús: acordeón (cerrados por defecto, se abren al tocar el padre) */
  .nav-links .nav-dd-menu{
    display:none;position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;
    min-width:0;background:transparent;margin:0 0 14px;padding:0 0 0 14px;
    border:0;border-left:2px solid var(--line);border-radius:0;
  }
  .nav-links .nav-dd.open > .nav-dd-menu{display:block}
  .nav-links .nav-dd-menu a{font-size:.95rem;padding:11px 12px}
  .nav-links .dd-parent-link{display:block;color:var(--gold-text);font-weight:700}
  /* Controles al final del panel */
  .nav-links .theme-toggle{align-self:flex-start;margin-top:16px}
  .nav-links .btn{width:100%;margin-top:12px}
}
@media(max-width:720px){
  .cat-grid{grid-template-columns:1fr}
  /* Móvil: subir el bloque del hero (mismos tamaños, solo menos espacio arriba)
     para que ambos botones se vean a primera vista */
  .hero{padding:14px 0 46px}
}

/* ---------- Selector de idioma ---------- */
.lang-sel{
  background:var(--panel-2);border:1px solid var(--line);color:var(--gold-2);
  border-radius:8px;padding:8px 10px;font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;
}
.lang-sel:focus{border-color:var(--gold);outline:none}

/* ---------- Botón de cambio de tema ---------- */
.theme-toggle{
  background:var(--panel-2);border:1px solid var(--line);
  border-radius:8px;padding:7px 11px;font-size:1rem;line-height:1;cursor:pointer;
  text-decoration:none;transition:.15s;
}
.theme-toggle:hover{border-color:var(--gold)}


/* ---------- Modo claro: ajustes que dependen de variables ---------- */
[data-theme="light"] body::before{
  background:
    radial-gradient(700px 360px at 85% -5%, rgba(217,164,65,.10), transparent 60%),
    radial-gradient(560px 320px at 0% 100%, rgba(142,44,58,.05), transparent 60%);
}
[data-theme="light"] header.site{background:color-mix(in srgb, var(--header-bg) 88%, transparent)}
[data-theme="light"] .form-card,
[data-theme="light"] .prod-card:hover{box-shadow:0 14px 40px rgba(120,100,60,.14)}
/* El header oscuro translúcido también se adapta */
header.site{background:color-mix(in srgb, var(--header-bg) 88%, transparent)}

/* ---------- Submenús desplegables del nav ---------- */
.nav-dd{position:relative;display:inline-block}
.nav-dd-toggle{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.nav-dd .caret{font-size:.7rem;transition:transform .2s}
.nav-dd:hover .caret{transform:rotate(180deg)}
.nav-dd-menu{
  position:absolute;top:100%;left:0;min-width:200px;background:var(--panel);
  border:1px solid var(--line);border-radius:10px;padding:8px;margin-top:8px;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:60;
  box-shadow:0 14px 40px rgba(0,0,0,.35);
}
.nav-dd:hover .nav-dd-menu,.nav-dd:focus-within .nav-dd-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dd-menu a{display:block;padding:9px 12px;border-radius:7px;color:var(--muted);font-size:.9rem}
.nav-dd-menu a:hover{background:var(--panel-2);color:var(--gold-text)}
/* Enlace al padre dentro del submenú: solo existe visualmente en móvil */
.dd-parent-link{display:none}

/* ---------- Iconos imagen de categoría en portada ---------- */
.cat-card .ico img{margin:0 auto}

/* ---------- Redes sociales en footer ---------- */
.foot-social{display:flex;gap:12px;margin-top:14px}
.foot-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;
  border:1px solid var(--line);border-radius:9px;color:var(--muted);font-size:1.1rem;transition:.15s}
.foot-social a:hover{border-color:var(--gold);color:var(--gold-text)}

/* ---------- Páginas estáticas ---------- */
.page-content{max-width:820px;margin:0 auto;color:var(--parchment)}
.page-content h2{margin:28px 0 12px}
.page-content h3{margin:22px 0 10px}
.page-content p{margin:12px 0;line-height:1.75}
.page-content ul,.page-content ol{margin:12px 0 12px 24px}
.page-content a{color:var(--gold-text)}

/* ============ PANEL ADMIN PREMIUM: pestañas ============ */
.tk-tabs{display:flex;gap:2px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:thin;border-bottom:1px solid var(--line);margin-bottom:24px;position:sticky;top:0;background:var(--ink);z-index:20;padding-top:4px}
.tk-tab{padding:11px 13px;border:0;background:none;color:var(--muted);font:inherit;font-weight:600;font-size:.86rem;cursor:pointer;border-bottom:2px solid transparent;border-radius:8px 8px 0 0;transition:.15s;display:flex;align-items:center;gap:6px;white-space:nowrap;flex:0 0 auto;text-decoration:none}
.tk-tab:hover{color:var(--parchment);background:var(--panel)}
.tk-tab.on{color:var(--gold-text);border-bottom-color:var(--gold)}
.tk-panel{display:none;animation:tkfade .25s ease}
.tk-panel.on{display:block}
@keyframes tkfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.tk-save-bar{position:sticky;bottom:0;background:linear-gradient(180deg,transparent,var(--ink) 30%);padding:18px 0 6px;margin-top:10px;display:flex;gap:12px;flex-wrap:wrap;z-index:15}
/* Cuadrícula de colores más compacta y elegante */
.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.color-grid .cf{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:12px}
.color-grid .cf label{margin:0 0 8px;font-size:.82rem}
.tk-help{background:var(--panel-2);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:8px;padding:12px 14px;font-size:.86rem;color:var(--muted);margin-bottom:18px}
.tk-section-title{font-family:var(--font-display);font-size:1.15rem;color:var(--heading);margin-bottom:4px;letter-spacing:.03em}

/* Botones del nav en una sola linea */
.nav-links .btn{white-space:nowrap}
.nav-links a{white-space:nowrap}

/* ============ Editor visual TK ============ */
.tk-ed{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:6px 0 10px;background:var(--ink)}
.tk-ed-bar{display:flex;flex-wrap:wrap;gap:3px;padding:8px;background:var(--panel-2);border-bottom:1px solid var(--line)}
.tk-ed-btn{background:var(--panel);border:1px solid var(--line);color:var(--parchment);border-radius:6px;
  padding:6px 10px;font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:.12s}
.tk-ed-btn:hover{border-color:var(--gold);color:var(--gold-text)}
.tk-ed-sep{width:1px;background:var(--line);margin:2px 4px;align-self:stretch}
.tk-ed-imgbar{display:flex;gap:6px;align-items:center;padding:8px;background:var(--panel-2);border-bottom:1px solid var(--line);font-size:.82rem;flex-wrap:wrap}
.tk-ed-danger{border-color:var(--crimson);color:#ff9b9b}
.tk-ed-area{min-height:260px;max-height:560px;overflow-y:auto;padding:16px 18px;outline:none;line-height:1.7}
.tk-ed-area h2,.tk-ed-area h3{margin:16px 0 8px}
.tk-ed-area p{margin:8px 0}
.tk-ed-area ul,.tk-ed-area ol{margin:8px 0 8px 22px}
.tk-ed-area img{max-width:100%;border-radius:8px}
.tk-ed-area img.tk-ed-imgsel{outline:2px solid var(--gold);outline-offset:2px}
.tk-ed-area a{color:var(--gold-text);text-decoration:underline}
.tk-ed + textarea, .tk-ed textarea{min-height:260px;font-family:var(--font-mono,monospace);font-size:.85rem}

/* ===== Controles del header: a juego con el header SIEMPRE (identicos en ambos modos) ===== */
header.site .nav-links .btn-ghost{
  background:color-mix(in srgb, var(--header-text) 12%, transparent);
  border:1px solid color-mix(in srgb, var(--header-text) 30%, transparent);
}
/* Botón de tema: sin fondo ni borde (limpio sobre el header) */
header.site .theme-toggle{background:transparent;border:1px solid transparent}
/* Selector de idioma: mismo dropdown que los menús (texto y flecha a 5px, sin quirks de <select>) */
header.site .lang-dd .lang-toggle{color:var(--gold-2);font-size:.94rem;font-weight:600;padding:6px 7px}
header.site .theme-toggle{color:var(--header-text)}
header.site .nav-links .btn-ghost{color:color-mix(in srgb, var(--header-text) 45%, #FFFFFF)}
header.site .theme-toggle:hover,
header.site .nav-links .btn-ghost:hover{border-color:var(--gold)}
header.site .nav-links .btn-ghost:hover{color:var(--gold-2)}
/* Botón dorado dentro del header (Create account): mismos colores pero sin glow,
   texto NEGRO fijo que no cambia al hover */
header.site .nav-links .btn-gold{box-shadow:none;color:#000}
header.site .nav-links .btn-gold:hover{box-shadow:none;color:#000;filter:brightness(1.05)}

/* ===== Fondo del hero: presencia de Sala del Trono (ambos modos) ===== */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 1300px 560px at 50% 6%, color-mix(in srgb, var(--gold) 13%, transparent), transparent 68%),
    radial-gradient(ellipse 760px 320px at 50% 102%, color-mix(in srgb, var(--gold) 8%, transparent), transparent 72%);
  -webkit-mask-image:linear-gradient(to bottom, #000 70%, transparent 100%);
          mask-image:linear-gradient(to bottom, #000 70%, transparent 100%);
}
/* Celosía heráldica tenue (rombos dorados) que se desvanece hacia los bordes */
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.45;
  background:
    repeating-linear-gradient(45deg,  color-mix(in srgb, var(--gold) 9%, transparent) 0 1px, transparent 1px 17px),
    repeating-linear-gradient(-45deg, color-mix(in srgb, var(--gold) 9%, transparent) 0 1px, transparent 1px 17px);
  -webkit-mask-image:radial-gradient(ellipse 96% 68% at 50% 26%, #000 30%, transparent 86%);
          mask-image:radial-gradient(ellipse 96% 68% at 50% 26%, #000 30%, transparent 86%);
}
/* Modo claro: oro puro no contrasta sobre crema (luminancia similar) — se usa bronce
   derivado de --gold para que la celosía y el halo sí se lean. El modo oscuro no se toca. */
[data-theme="light"] .hero::after{
  opacity:.7;
  background:
    repeating-linear-gradient(45deg,  color-mix(in srgb, color-mix(in srgb, var(--gold) 68%, #3A2A08) 14%, transparent) 0 1px, transparent 1px 17px),
    repeating-linear-gradient(-45deg, color-mix(in srgb, color-mix(in srgb, var(--gold) 68%, #3A2A08) 14%, transparent) 0 1px, transparent 1px 17px);
}
[data-theme="light"] .hero::before{
  background:
    radial-gradient(ellipse 1300px 560px at 50% 6%, color-mix(in srgb, color-mix(in srgb, var(--gold) 75%, #7A5514) 22%, transparent), transparent 68%),
    radial-gradient(ellipse 760px 320px at 50% 102%, color-mix(in srgb, color-mix(in srgb, var(--gold) 75%, #7A5514) 12%, transparent), transparent 72%),
    radial-gradient(ellipse 130% 115% at 50% 32%, transparent 58%, color-mix(in srgb, color-mix(in srgb, var(--gold) 45%, #2A1E06) 7%, transparent) 100%);
}
[data-theme="light"] .hero::before{
  -webkit-mask-image:linear-gradient(to bottom, #000 70%, transparent 100%);
          mask-image:linear-gradient(to bottom, #000 70%, transparent 100%);
}
.hero > *{position:relative;z-index:1}

/* Ornamento separador: hilo dorado con rombo central */
.hero-sep{position:relative;margin:72px auto 0;max-width:540px;height:1px;
  background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--gold) 60%, transparent), transparent)}
.hero-sep i{position:absolute;left:50%;top:50%;width:9px;height:9px;
  transform:translate(-50%,-50%) rotate(45deg);
  background:linear-gradient(135deg, var(--gold-2), var(--gold));
  box-shadow:0 0 0 6px var(--ink), 0 0 14px color-mix(in srgb, var(--gold) 55%, transparent)}

/* Escritorio: subir el bloque del hero (mismos tamaños, solo menos margen superior) */
@media(min-width:961px){
  .hero{padding-top:40px}
}

/* Chips de subcategorías en la página de una categoría madre */
.cat-chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:26px 0 34px}
.cat-chip{display:inline-flex;align-items:center;gap:9px;padding:9px 16px;border-radius:999px;
  background:var(--panel);border:1px solid var(--line);color:var(--parchment);font-weight:600;font-size:.92rem}
.cat-chip:hover{border-color:var(--gold);color:var(--gold-text)}
.cat-chip-ico{display:inline-flex;font-size:1.05rem;line-height:1}
.cat-chip-ico img{width:20px!important;height:20px!important}
.cat-chip b{font-weight:700;color:var(--gold-text);background:var(--panel-2);
  border-radius:999px;padding:2px 9px;font-size:.78rem}

/* Mi cuenta: todo centrado */
.account-center{text-align:center}
.account-center th,.account-center td{text-align:center}
.account-center .table-wrap{margin-left:auto;margin-right:auto}

/* Icono de idioma (imagen) */
.lang-ico{width:17px;height:17px;object-fit:contain;vertical-align:-3px;margin-right:2px}
