/* ============================================
   MDE — El Mundo de Ester XX
   Dark Premium Theme with Silhouette
   ============================================ */
:root {
    --bg-primary: #050508;
    --bg-secondary: #0c0c14;
    --bg-card: #111119;
    --bg-input: #16161f;
    --border: #1f1f30;
    --border-hover: #2e2e4a;
    --text-primary: #eaeaf2;
    --text-secondary: #8888a0;
    --text-muted: #555568;
    --accent: #d4a847;
    --accent-hover: #e6be5a;
    --accent-dim: #8a7030;
    --accent-glow: rgba(212,168,71,0.12);
    --success: #4ade80;
    --error: #f87171;
    --warning: #fbbf24;
    --radius: 14px;
    --radius-sm: 8px;
    --transition: 0.25s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:'Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--accent);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--accent-hover)}
img{max-width:100%;height:auto;display:block}
.container{width:100%;max-width:1100px;margin:0 auto;padding:0 1.25rem;position:relative;z-index:1}

/* Silhouette backgrounds */
body.page-landing::before,body.page-login::before,body.page-register::before,body.page-age-gate::before{content:'';position:fixed;top:0;right:0;bottom:0;width:50%;background:url('/assets/img/silueta.png') no-repeat center center;background-size:contain;opacity:0.06;pointer-events:none;z-index:0}
body.page-app::before{content:'';position:fixed;bottom:-10%;right:-5%;width:40%;height:80%;background:url('/assets/img/silueta.png') no-repeat bottom right;background-size:contain;opacity:0.03;pointer-events:none;z-index:0}

/* Header */
.site-header{background:rgba(12,12,20,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0.85rem 0;position:sticky;top:0;z-index:100}
.header-flex{display:flex;align-items:center;justify-content:space-between}
.logo img{height:32px}
.main-nav{display:flex;gap:1.25rem;align-items:center}
.main-nav a{color:var(--text-secondary);font-size:0.88rem;font-weight:500;padding:0.4rem 0;position:relative;transition:color var(--transition)}
.main-nav a:hover,.main-nav a.active{color:var(--accent)}
.nav-toggle{display:none;background:none;border:1px solid var(--border);color:var(--text-primary);font-size:1.3rem;padding:0.3rem 0.6rem;border-radius:var(--radius-sm);cursor:pointer}
@media(max-width:768px){.nav-toggle{display:block}.main-nav{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(12,12,20,0.97);border-bottom:1px solid var(--border);padding:1rem 1.25rem;gap:0.6rem}.main-nav.open{display:flex}}

/* Main & Footer */
.site-main{flex:1;padding:2rem 0;position:relative;z-index:1}
.site-footer{background:var(--bg-secondary);border-top:1px solid var(--border);padding:1.25rem 0;text-align:center;position:relative;z-index:1}
.footer-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:0.5rem}
.footer-links a{color:var(--text-muted);font-size:0.8rem}
.footer-copy{color:var(--text-muted);font-size:0.75rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:0.7rem 1.6rem;font-size:0.92rem;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:all var(--transition);text-decoration:none;gap:0.5rem}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dim));color:#050508;box-shadow:0 4px 20px rgba(212,168,71,0.2)}
.btn-primary:hover{background:linear-gradient(135deg,var(--accent-hover),var(--accent));color:#050508;box-shadow:0 6px 30px rgba(212,168,71,0.35);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--accent);border:1px solid var(--accent-dim)}
.btn-secondary:hover{background:var(--accent-glow);border-color:var(--accent)}
.btn-danger{background:var(--error);color:#fff}
.btn-sm{padding:0.45rem 0.9rem;font-size:0.82rem}
.btn-block{width:100%}
.btn:disabled{opacity:0.4;cursor:not-allowed}

/* Forms */
.form-group{margin-bottom:1.15rem}
.form-group label{display:block;font-size:0.82rem;font-weight:500;color:var(--text-secondary);margin-bottom:0.35rem}
.form-control{width:100%;padding:0.7rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:0.92rem;transition:border-color var(--transition),box-shadow var(--transition)}
.form-control:focus{outline:none;border-color:var(--accent-dim);box-shadow:0 0 0 3px var(--accent-glow)}
textarea.form-control{resize:vertical;min-height:100px}
.form-check{display:flex;align-items:center;gap:0.5rem}
.form-check input[type="checkbox"]{accent-color:var(--accent);width:16px;height:16px}

/* Alerts */
.alert{padding:0.75rem 1.1rem;border-radius:var(--radius-sm);margin-bottom:1.1rem;font-size:0.88rem;border:1px solid}
.alert-error{background:rgba(248,113,113,0.08);color:var(--error);border-color:rgba(248,113,113,0.2)}
.alert-success{background:rgba(74,222,128,0.08);color:var(--success);border-color:rgba(74,222,128,0.2)}

/* Cards */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;transition:border-color var(--transition)}
.card:hover{border-color:var(--border-hover)}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.1rem}

.content-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all var(--transition)}
.content-card:hover{border-color:var(--accent-dim);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,0.4),0 0 20px var(--accent-glow)}
.content-card .card-thumb{position:relative;aspect-ratio:16/9;background:var(--bg-secondary);overflow:hidden}
.content-card .card-thumb img{width:100%;height:100%;object-fit:cover}
.content-card .card-thumb .badge{position:absolute;top:0.5rem;right:0.5rem;padding:0.2rem 0.55rem;border-radius:6px;font-size:0.72rem;font-weight:600}
.badge-included{background:var(--accent);color:#050508}
.badge-purchased{background:var(--success);color:#050508}
.badge-price{background:rgba(0,0,0,0.75);color:var(--text-primary);backdrop-filter:blur(4px)}
.badge-type{background:rgba(0,0,0,0.65);color:var(--text-secondary);position:absolute;top:0.5rem;left:0.5rem}
.card-thumb .lock-overlay{position:absolute;inset:0;background:rgba(5,5,8,0.6);display:flex;align-items:center;justify-content:center;font-size:2rem;backdrop-filter:blur(6px)}
.content-card .card-body{padding:0.85rem}
.content-card .card-title{font-size:0.95rem;font-weight:600;margin-bottom:0.2rem}
.content-card .card-desc{font-size:0.8rem;color:var(--text-secondary);margin-bottom:0.6rem}

/* Hero */
.hero{text-align:center;padding:5rem 0 3.5rem}
.hero h1{font-size:clamp(2.2rem,5.5vw,3.5rem);font-weight:800;letter-spacing:0.04em;margin-bottom:0.5rem;background:linear-gradient(135deg,#fff,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero .subtitle{font-size:1.05rem;color:var(--text-secondary);margin-bottom:2.5rem;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.7}
.hero .subtitle strong{color:var(--accent)}

.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin:3rem 0}
.feature-card{text-align:center;padding:1.75rem 1rem;background:rgba(17,17,25,0.6);border:1px solid var(--border);backdrop-filter:blur(8px)}
.feature-card .icon{font-size:1.8rem;margin-bottom:0.6rem}
.feature-card h3{font-size:0.95rem;margin-bottom:0.35rem}
.feature-card p{font-size:0.82rem;color:var(--text-secondary)}

/* Age gate */
.age-gate{display:flex;align-items:center;justify-content:center;min-height:75vh;text-align:center}
.age-gate-box{max-width:400px;width:100%}
.age-gate-box h1{font-size:3rem;margin-bottom:0.5rem;color:var(--accent)}
.age-gate-box p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:0.95rem}
.age-gate-btns{display:flex;gap:0.85rem;justify-content:center}

/* Auth pages */
.auth-page{display:flex;align-items:center;justify-content:center;min-height:70vh}
.auth-box{width:100%;max-width:400px}
.auth-box h1{font-size:1.6rem;margin-bottom:0.3rem}
.auth-box .auth-subtitle{color:var(--text-secondary);margin-bottom:1.3rem;font-size:0.92rem}
.auth-box .price-tag{display:inline-block;background:var(--accent-glow);border:1px solid var(--accent-dim);color:var(--accent);padding:0.5rem 1rem;border-radius:var(--radius-sm);font-size:1.1rem;font-weight:700;margin-bottom:1.5rem}

/* Dashboard */
.dashboard-header{margin-bottom:1.75rem}
.dashboard-header h1{font-size:1.6rem;margin-bottom:0.3rem}
.status-card{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.status-badge{display:inline-flex;align-items:center;gap:0.4rem;padding:0.4rem 0.9rem;border-radius:50px;font-weight:600;font-size:0.85rem}
.status-active{background:rgba(74,222,128,0.12);color:var(--success)}
.status-inactive{background:rgba(248,113,113,0.12);color:var(--error)}

/* Section header */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;flex-wrap:wrap;gap:0.75rem}
.section-header h1{font-size:1.6rem;display:flex;align-items:center;gap:0.5rem}

/* Content viewer */
.content-viewer{max-width:900px;margin:0 auto}
.content-viewer h1{font-size:1.4rem;margin-bottom:0.3rem}
.content-viewer .meta{color:var(--text-secondary);font-size:0.85rem;margin-bottom:1.25rem}
.video-wrapper{position:relative;background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:1.25rem}
.video-wrapper video{width:100%;display:block}
.photo-viewer{border-radius:var(--radius);overflow:hidden;margin-bottom:1.25rem;text-align:center;background:var(--bg-secondary)}
.photo-viewer img{max-height:80vh;margin:0 auto}

/* Admin */
.admin-layout{display:grid;grid-template-columns:200px 1fr;gap:1.75rem;min-height:70vh}
@media(max-width:768px){.admin-layout{grid-template-columns:1fr}}
.admin-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;height:fit-content;position:sticky;top:5rem}
.admin-sidebar h3{font-size:0.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.85rem}
.admin-sidebar a{display:block;padding:0.45rem 0.65rem;color:var(--text-secondary);border-radius:var(--radius-sm);margin-bottom:0.2rem;font-size:0.85rem}
.admin-sidebar a:hover,.admin-sidebar a.active{background:var(--accent-glow);color:var(--accent)}
.admin-content h1{font-size:1.4rem;margin-bottom:1.25rem}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
table th,table td{padding:0.65rem 0.85rem;text-align:left;border-bottom:1px solid var(--border);font-size:0.85rem}
table th{color:var(--text-muted);font-weight:600;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.05em}

/* Cookie banner */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);padding:0.85rem;z-index:200}
.cookie-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:0.75rem;flex-wrap:wrap}
.cookie-inner p{font-size:0.8rem;color:var(--text-secondary)}

/* Legal */
.legal-content{max-width:700px}
.legal-content h1{font-size:1.5rem;margin-bottom:1.3rem}
.legal-content h2{font-size:1.1rem;margin:1.3rem 0 0.6rem;color:var(--accent)}
.legal-content p{margin-bottom:0.85rem;color:var(--text-secondary);font-size:0.9rem}
.legal-content ul{margin:0.5rem 0 0.85rem 1.5rem;color:var(--text-secondary);font-size:0.9rem}

/* Utils */
.text-center{text-align:center}.text-muted{color:var(--text-secondary)}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}
.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
.flex-between{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}
.empty-state .icon{font-size:3rem;margin-bottom:0.75rem;opacity:0.5}
