/* 🏰 Condado de Castilla — Estilo Medieval Moderno */

:root {
    --bg: #0d0d1a;
    --bg2: #15152a;
    --bg3: #1e1e38;
    --fg: #e8e8f0;
    --fg2: #9999bb;
    --gold: #d4a040;
    --gold2: #b8860b;
    --accent: #7c5ce0;
    --success: #4ade80;
    --danger: #f87171;
    --border: #2a2a45;
    --radius: 10px;
    --font: 'Segoe UI', system-ui, -apple-system, sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; }
body { background:var(--bg); color:var(--fg); font-family:var(--font); line-height:1.7; }

/* ── Nav ── */
.nav { display:flex; align-items:center; padding:14px 32px; background:var(--bg2); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:100; gap:24px; flex-wrap:wrap; }
.nav-brand { display:flex; align-items:center; gap:10px; }
.nav-icon { font-size:28px; }
.nav-title { font-size:20px; font-weight:700; color:var(--gold); text-decoration:none; }
.nav-links { display:flex; gap:20px; margin-left:auto; }
.nav-links a { color:var(--fg2); text-decoration:none; font-size:15px; padding:6px 0; border-bottom:2px solid transparent; transition:all .2s; }
.nav-links a:hover, .nav-links a.active { color:var(--fg); border-bottom-color:var(--gold); }
.btn-nav { background:var(--gold); color:#1a1a0a; padding:8px 20px; border-radius:var(--radius); text-decoration:none; font-weight:600; font-size:14px; transition:all .2s; }
.btn-nav:hover { background:var(--gold2); }

/* ── Hero ── */
.hero { display:flex; align-items:center; justify-content:center; padding:80px 32px; gap:60px; max-width:1200px; margin:0 auto; flex-wrap:wrap; }
.hero-content { flex:1; min-width:300px; }
.hero-badge { display:inline-block; background:var(--bg3); color:var(--gold); padding:6px 16px; border-radius:20px; font-size:14px; margin-bottom:20px; border:1px solid var(--gold2); }
.hero h1 { font-size:48px; line-height:1.15; margin-bottom:20px; }
.hero h1 span:nth-child(1) { color:var(--fg); }
.hero h1 span:nth-child(2) { color:var(--gold); }
.hero h1 span:nth-child(3) { color:var(--accent); }
.hero-subtitle { font-size:18px; color:var(--fg2); max-width:500px; margin-bottom:32px; }
.hero-subtitle strong { color:var(--fg); }
.hero-stats { display:flex; gap:32px; margin-bottom:32px; flex-wrap:wrap; }
.hero-stat { text-align:center; }
.stat-num { display:block; font-size:36px; font-weight:800; color:var(--gold); }
.stat-label { font-size:13px; color:var(--fg2); }
.hero-cta { display:flex; gap:16px; flex-wrap:wrap; }

/* ── Swarm Animation ── */
.hero-visual { width:350px; height:350px; position:relative; }
.swarm-animation { width:100%; height:100%; position:relative; }
.node { position:absolute; width:12px; height:12px; border-radius:50%; animation: orbit 4s linear infinite; }
.node.n0 { background:var(--gold); top:50%; left:50%; width:20px; height:20px; animation:none; transform:translate(-50%,-50%); box-shadow:0 0 20px var(--gold); }
.node.n1 { background:var(--accent); top:20%; left:30%; animation-delay:0s; }
.node.n2 { background:#f59e0b; top:20%; left:70%; animation-delay:-0.5s; }
.node.n3 { background:#ef4444; top:50%; left:85%; animation-delay:-1s; }
.node.n4 { background:#8b5cf6; top:80%; left:70%; animation-delay:-1.5s; }
.node.n5 { background:#06b6d4; top:80%; left:30%; animation-delay:-2s; }
.node.n6 { background:#10b981; top:50%; left:15%; animation-delay:-2.5s; }
.node.n7 { background:#f97316; top:35%; left:50%; animation-delay:-3s; }
.node.n8 { background:#ec4899; top:65%; left:50%; animation-delay:-3.5s; }
@keyframes orbit { 0%{transform:translate(0,0) scale(1)} 50%{transform:translate(10px,-10px) scale(1.5)} 100%{transform:translate(0,0) scale(1)} }
.hero-caption { text-align:center; color:var(--fg2); font-size:13px; margin-top:12px; font-style:italic; }

/* ── Sections ── */
.section { padding:64px 32px; max-width:1100px; margin:0 auto; }
.section h2 { font-size:32px; margin-bottom:12px; text-align:center; color:var(--gold); }
.section .subtitle { text-align:center; color:var(--fg2); margin-bottom:40px; font-size:16px; }

/* ── Buttons ── */
.btn-primary, .btn-secondary {
    display:inline-block; padding:12px 28px; border-radius:var(--radius); text-decoration:none;
    font-weight:600; font-size:16px; cursor:pointer; border:none; transition:all .2s;
}
.btn-primary { background:var(--gold); color:#1a1a0a; }
.btn-primary:hover { background:var(--gold2); transform:translateY(-1px); box-shadow:0 4px 16px rgba(212,160,64,0.3); }
.btn-secondary { background:var(--bg3); color:var(--fg); border:1px solid var(--border); }
.btn-secondary:hover { border-color:var(--gold); }
.btn-lg { padding:16px 36px; font-size:18px; }
.btn-sm { padding:8px 16px; font-size:14px; }
.btn-full { width:100%; text-align:center; }

/* ── How ── */
.how { background:var(--bg2); }
.how-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.how-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:32px 24px; text-align:center; transition:border-color .2s; }
.how-card:hover { border-color:var(--gold); }
.how-icon { font-size:48px; margin-bottom:16px; }
.how-card h3 { color:var(--fg); margin-bottom:8px; }
.how-card p { color:var(--fg2); font-size:14px; }

/* ── Catalog ── */
.catalog-grid, .catalog-grid-full { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:24px; }
.product-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:24px; display:flex; flex-direction:column; transition:border-color .2s; }
.product-card:hover { border-color:var(--gold); }
.product-category { font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--accent); margin-bottom:8px; font-weight:600; }
.product-card h3 { font-size:18px; margin-bottom:8px; color:var(--fg); }
.product-desc { color:var(--fg2); font-size:14px; margin-bottom:12px; flex:1; }
.product-preview { background:var(--bg3); padding:12px; border-radius:6px; font-size:13px; color:var(--fg2); font-style:italic; margin-bottom:12px; border-left:3px solid var(--gold); }
.product-tags { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.tag { background:var(--bg3); color:var(--fg2); font-size:11px; padding:3px 10px; border-radius:12px; }
.product-meta { color:var(--fg2); font-size:13px; margin-bottom:12px; }
.product-footer { display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--border); padding-top:12px; }
.product-price { font-size:24px; font-weight:700; color:var(--gold); }

/* ── Testimonials ── */
.testimonial-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:20px; }
.testimonial { background:var(--bg2); border:1px solid var(--border); border-left:4px solid var(--gold); border-radius:var(--radius); padding:24px; }
.testimonial p { color:var(--fg); font-style:italic; margin-bottom:12px; }
.testimonial-author { color:var(--gold); font-size:13px; font-weight:600; }

/* ── Trust ── */
.trust { background:var(--bg2); }
.trust-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; }
.trust-item { text-align:center; padding:20px; }
.trust-icon { font-size:32px; display:block; margin-bottom:8px; }
.trust-item strong { display:block; color:var(--fg); margin-bottom:4px; }
.trust-item p { color:var(--fg2); font-size:13px; }

/* ── Contact ── */
.contact { text-align:center; }
.contact h2 { margin-bottom:8px; }
.contact p { color:var(--fg2); margin-bottom:24px; }
.contact-form { max-width:450px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.contact-form input, .contact-form textarea {
    background:var(--bg3); border:1px solid var(--border); color:var(--fg);
    padding:12px 16px; border-radius:var(--radius); font-family:var(--font); font-size:15px;
    transition:border-color .2s;
}
.contact-form input:focus, .contact-form textarea:focus { border-color:var(--gold); outline:none; }

/* ── Product Detail ── */
.product-detail { padding:48px 32px; }
.product-hero { display:flex; gap:48px; flex-wrap:wrap; }
.product-info { flex:1; min-width:300px; }
.product-info h1 { font-size:36px; margin-bottom:16px; color:var(--fg); }
.product-desc-full { color:var(--fg2); font-size:16px; margin-bottom:24px; }
.product-highlights { display:flex; flex-wrap:wrap; gap:16px; margin-bottom:24px; }
.highlight { background:var(--bg3); padding:10px 16px; border-radius:8px; font-size:14px; }
.highlight strong { color:var(--gold); }
.product-preview-box { background:var(--bg3); padding:20px; border-radius:var(--radius); border-left:4px solid var(--gold); margin-bottom:24px; }
.product-preview-box h4 { color:var(--gold); margin-bottom:8px; }

/* ── Buy Box ── */
.product-buy-box { width:360px; min-width:300px; }
.buy-card { background:var(--bg2); border:2px solid var(--gold); border-radius:var(--radius); padding:32px; position:sticky; top:100px; }
.buy-price { display:block; font-size:42px; font-weight:800; color:var(--gold); text-align:center; }
.buy-currency { display:block; color:var(--fg2); text-align:center; margin-bottom:24px; font-size:14px; }
.buy-features { list-style:none; margin-bottom:24px; }
.buy-features li { padding:6px 0; color:var(--fg); font-size:14px; }
.buy-input { width:100%; background:var(--bg3); border:1px solid var(--border); color:var(--fg); padding:12px; border-radius:var(--radius); margin-bottom:12px; font-size:14px; }
.buy-input:focus { border-color:var(--gold); outline:none; }
.buy-secure { text-align:center; color:var(--fg2); font-size:12px; margin-top:12px; }

/* ── Thanks ── */
.thanks-page { text-align:center; padding:100px 32px; }
.thanks-page h1 { font-size:48px; color:var(--gold); margin-bottom:16px; }
.thanks-details { background:var(--bg2); max-width:500px; margin:24px auto; padding:24px; border-radius:var(--radius); color:var(--fg2); }
.thanks-session { font-size:12px; color:var(--fg2); font-family:monospace; margin-top:12px; }

/* ── Blog ── */
.blog-posts { display:flex; flex-direction:column; gap:20px; max-width:700px; margin:0 auto; }
.blog-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:24px; }
.blog-date { font-size:12px; color:var(--gold); }
.blog-card h3 { font-size:20px; margin:8px 0; }
.blog-card p { color:var(--fg2); margin-bottom:12px; }

/* ── Footer ── */
.footer { background:var(--bg2); border-top:1px solid var(--border); padding:40px 32px 20px; }
.footer-content { display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; max-width:1100px; margin:0 auto 24px; }
.footer-brand strong { color:var(--gold); }
.footer-brand p { color:var(--fg2); font-size:13px; margin-top:4px; }
.footer-links { display:flex; gap:20px; }
.footer-links a { color:var(--fg2); text-decoration:none; font-size:14px; }
.footer-links a:hover { color:var(--gold); }
.footer-bottom { text-align:center; color:var(--fg2); font-size:12px; border-top:1px solid var(--border); padding-top:16px; }

/* ── Utilities ── */
.center { text-align:center; }
.mt-3 { margin-top:24px; }

/* ═══ GAMIFICACIÓN ═══ */
.gamificacion { background:var(--bg2); }
.niveles-grid { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin:24px 0; }
.nivel-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:20px 24px; text-align:center; min-width:120px; transition:all .2s; }
.nivel-card:hover { border-color:var(--gold); transform:translateY(-2px); }
.nivel-card.highlight { border-color:var(--gold); background:linear-gradient(135deg,var(--bg3),#2a2a10); }
.nivel-icon { font-size:36px; display:block; margin-bottom:8px; }
.nivel-card strong { display:block; color:var(--fg); font-size:14px; }
.nivel-card span { color:var(--fg2); font-size:12px; }
.badges-preview { text-align:center; margin-top:32px; }
.badges-preview h3 { color:var(--gold); margin-bottom:12px; }
.badges-grid { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.badge { font-size:28px; cursor:help; transition:transform .2s; }
.badge:hover { transform:scale(1.3); }

/* Gamer progress */
.gamer-progress { background:var(--bg3); border:2px solid var(--gold); border-radius:var(--radius); padding:24px; max-width:500px; margin:24px auto; }
.gamer-progress h3 { color:var(--gold); margin-bottom:12px; text-align:center; }
.gamer-nivel { margin-bottom:16px; }
.nivel-badge { display:inline-block; background:var(--gold); color:#1a1a0a; padding:4px 14px; border-radius:20px; font-weight:700; font-size:14px; margin-bottom:8px; }
.progress-bar { height:12px; background:var(--bg); border-radius:6px; overflow:hidden; margin:8px 0; }
.progress-fill { height:100%; background:linear-gradient(90deg,var(--gold),var(--accent)); border-radius:6px; transition:width .5s; }
.progress-text { color:var(--fg2); font-size:12px; }
.gamer-badges { margin-top:12px; display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.badge-earned { background:var(--bg); border:1px solid var(--gold); padding:4px 10px; border-radius:12px; font-size:13px; color:var(--fg); }

/* Ranking */
.ranking-section { background:var(--bg); }
.ranking-table { max-width:500px; margin:0 auto; }
.rank-row { display:flex; align-items:center; gap:12px; padding:12px 16px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); margin-bottom:8px; transition:border-color .2s; }
.rank-row:hover { border-color:var(--gold); }
.rank-pos { font-weight:700; color:var(--gold); font-size:18px; min-width:30px; }
.rank-name { flex:1; color:var(--fg); }
.rank-level { font-size:12px; color:var(--fg2); background:var(--bg3); padding:2px 8px; border-radius:8px; }
.rank-cafes { color:var(--gold); font-weight:600; }
.rank-gastado { color:var(--fg2); font-size:12px; }
.precio-original { text-decoration:line-through; color:var(--fg2); font-size:14px; margin-left:6px; }

/* Hero ranking */
.hero-ranking { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:16px; margin-top:16px; }
.hero-ranking h4 { color:var(--gold); font-size:14px; margin-bottom:8px; }
.mini-rank { display:flex; align-items:center; gap:8px; padding:4px 0; font-size:13px; }

/* BANCO Dashboard */
.banco-dashboard h1 { color:var(--gold); text-align:center; }
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:16px; margin:24px 0; }
.kpi-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:24px; text-align:center; }
.kpi-value { display:block; font-size:36px; font-weight:800; color:var(--gold); }
.kpi-label { color:var(--fg2); font-size:12px; margin-top:4px; }
.table-container { overflow-x:auto; }
.data-table { width:100%; border-collapse:collapse; margin:16px 0; }
.data-table th { background:var(--bg3); color:var(--gold); padding:10px; text-align:left; font-size:13px; }
.data-table td { padding:10px; border-bottom:1px solid var(--border); font-size:14px; }
.tasa-alta { color:#4ade80; font-weight:700; }
.tasa-media { color:#f59e0b; }
.tasa-baja { color:#f87171; }
.agent-ranking-dash { display:flex; flex-direction:column; gap:10px; max-width:500px; }
.agent-rank-card { display:flex; align-items:center; gap:12px; }
.rank-bar { flex:1; height:8px; background:var(--bg3); border-radius:4px; overflow:hidden; }
.rank-fill { height:100%; background:var(--gold); border-radius:4px; transition:width .5s; }
.banco-footer { text-align:center; color:var(--fg2); font-size:11px; margin-top:32px; }
.dash-niveles { margin:16px 0; }

/* ═══ CHAT WIDGET ═══ */
.chat-widget { position:fixed; bottom:20px; right:20px; z-index:999; }
.chat-toggle { width:56px; height:56px; background:var(--gold); border:none; border-radius:50%; font-size:24px; cursor:pointer; box-shadow:0 4px 16px rgba(212,160,64,0.5); position:relative; transition:transform .2s; }
.chat-toggle:hover { transform:scale(1.1); }
.chat-badge { position:absolute; top:0; right:0; color:#f87171; font-size:14px; animation:pulse 2s infinite; }
.chat-box { position:absolute; bottom:70px; right:0; width:340px; height:450px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); display:flex; flex-direction:column; box-shadow:0 8px 32px rgba(0,0,0,0.5); }
.chat-box-header { padding:12px 16px; background:var(--bg3); border-radius:var(--radius) var(--radius) 0 0; display:flex; justify-content:space-between; align-items:center; font-weight:600; color:var(--gold); }
.chat-box-messages { flex:1; overflow-y:auto; padding:12px; display:flex; flex-direction:column; gap:8px; }
.chat-msg { padding:6px 10px; border-radius:8px; max-width:85%; font-size:13px; }
.chat-msg.agent { background:var(--bg3); border-left:3px solid var(--gold); align-self:flex-start; }
.chat-msg.user { background:var(--accent); color:white; align-self:flex-end; }
.msg-author { font-weight:700; color:var(--gold); font-size:11px; display:block; }
.msg-text { color:var(--fg); }
.chat-box-input { display:flex; padding:8px; gap:8px; border-top:1px solid var(--border); }
.chat-box-input input { flex:1; background:var(--bg3); border:1px solid var(--border); color:var(--fg); padding:8px 12px; border-radius:var(--radius); font-size:14px; }
.chat-box-input input:focus { border-color:var(--gold); outline:none; }

/* ═══ REFERIDOS ═══ */
.referidos { background:var(--bg); text-align:center; }
.referral-box { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; align-items:center; }

/* ═══ RATING ═══ */
.rating-box { margin:16px 0; text-align:center; }
.stars { display:flex; gap:4px; justify-content:center; }
.stars span { font-size:28px; cursor:pointer; color:var(--gold); transition:transform .2s; }
.stars span:hover { transform:scale(1.3); }

/* ═══ NEWSLETTER ═══ */
.newsletter-page { max-width:700px; }
.newsletter-content { display:flex; flex-direction:column; gap:20px; }
.nl-section { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:20px; }
.nl-section h3 { color:var(--gold); margin-bottom:8px; }

/* ═══ SUSCRIPCIÓN ═══ */
.suscripcion-grid { display:flex; gap:24px; justify-content:center; flex-wrap:wrap; margin:24px 0; }
.plan-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:32px 24px; width:300px; text-align:center; }
.plan-card h3 { margin-bottom:8px; }
.plan-price { font-size:36px; font-weight:800; color:var(--gold); }
.plan-price small { font-size:16px; color:var(--fg2); }
.plan-card ul { list-style:none; margin:16px 0; text-align:left; }
.plan-card li { padding:6px 0; color:var(--fg); font-size:14px; }
.highlight-plan { border:2px solid var(--gold); position:relative; }
.plan-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--gold); color:#1a1a0a; padding:4px 16px; border-radius:20px; font-size:11px; font-weight:700; }

/* ═══ SABIDURÍA ACTIONS ═══ */
.sabiduria-actions { display:flex; gap:8px; justify-content:center; margin:16px 0; flex-wrap:wrap; }

/* ═══ MARKETPLACE ═══ */
.marketplace-submit { display:flex; gap:12px; margin-bottom:24px; }
.marketplace-list { display:flex; flex-direction:column; gap:8px; }
.mp-card { display:flex; gap:16px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:16px; align-items:flex-start; }
.mp-votes { display:flex; flex-direction:column; align-items:center; min-width:40px; }
.mp-votes button { background:none; border:none; color:var(--fg2); cursor:pointer; font-size:18px; }
.mp-votes button:hover { color:var(--gold); }
.mp-votes span { font-weight:700; color:var(--gold); }
.mp-content p { color:var(--fg); margin-bottom:4px; }
.mp-meta { font-size:11px; color:var(--fg2); }

/* ═══ AUTÓMATA ═══ */
.ciclos-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:12px; margin:16px 0; }
.ciclo-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:16px; }
.ciclo-card strong { display:block; color:var(--gold); margin-bottom:4px; }
.ciclo-card span { display:block; font-size:12px; color:var(--fg2); }
.ciclo-card p { font-size:13px; color:var(--fg); margin:8px 0; }
.estado-activo { color:#4ade80!important; font-weight:600; margin-top:4px; }

@media (max-width:768px) {
    .hero h1 { font-size:32px; }
    .hero { padding:40px 20px; }
    .product-hero { flex-direction:column; }
    .product-buy-box { width:100%; }
    .nav { padding:12px 16px; }
    .nav-links { gap:12px; }
}
