/* public_html/assets/css/app.css */
:root{--azul:#1F5370;--bg:#F3F5F8;--card:#FFFFFF;--muted:#6B7280;--line:#E5E7EB;--dourado:#BC963F}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:#111827}
a{text-decoration:none;color:inherit}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;border-radius:10px;font-weight:900;font-size:12px;border:0;cursor:pointer;background:var(--azul);color:#fff}
.btn.secondary{background:#fff;color:var(--azul);border:1px solid rgba(31,83,112,.35)}
.btn.w100{width:100%}
.link{color:var(--azul);font-weight:900}
.link.danger{color:#b91c1c}
.tag{display:inline-flex;padding:4px 8px;border-radius:999px;border:1px solid rgba(31,83,112,.25);font-size:12px;font-weight:900;color:var(--azul);background:#fff}
.muted{color:var(--muted)}
.empty{padding:12px;border:1px dashed var(--line);border-radius:12px;color:var(--muted);background:#fff}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px}
.table th{font-weight:900;color:#0f172a;background:#f8fafc}
.box{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;margin:14px 0}
.box-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.box-head h3{margin:0;font-size:14px}
.box-actions{display:flex;gap:10px;flex-wrap:wrap}
.form-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:12px}
.form-grid .full{grid-column:1/-1}
label{display:block;font-size:12px;font-weight:900;color:#0f172a;margin-bottom:6px}
input,select,textarea{width:100%;padding:10px;border-radius:10px;border:1px solid var(--line);outline:none;background:#fff}
textarea{resize:vertical}
.kpis{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:12px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.kpi-n{font-size:22px;font-weight:900;color:var(--azul)}
.kpi-l{font-size:12px;color:var(--muted);font-weight:900}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width: 980px){.two-col{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}}
.site-top{background:var(--azul);color:#fff}
.site-top-inner{max-width:1120px;margin:0 auto;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:center;gap:10px;font-weight:900}
.brand-mark{width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.15);display:grid;place-items:center}
.site-nav{display:flex;gap:14px;font-size:13px;font-weight:900;opacity:.95}
.site-main{max-width:1120px;margin:0 auto;padding:18px}
.site-foot{border-top:1px solid var(--line);background:#fff}
.site-foot-inner{max-width:1120px;margin:0 auto;padding:14px 18px;color:var(--muted);font-size:12px;font-weight:900}
.hero{background:#fff;border:1px solid var(--line);border-radius:16px}
.hero-inner{padding:18px}
.hero h1{margin:0 0 6px 0;font-size:22px;color:var(--azul)}
.hero p{margin:0;color:var(--muted);font-weight:600}
.hero-actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.section{margin-top:14px}
.section-head h1,.section-head h2{margin:0;color:#0f172a}
.section-head p{margin:6px 0 0;color:var(--muted);font-weight:600}
.grid{margin-top:12px;display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:12px}
@media (max-width: 980px){.grid{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;display:block}
.card-title{font-weight:900;color:#0f172a}
.card-sub{margin-top:6px;color:var(--muted);font-weight:700;font-size:12px}
.card-price{margin-top:10px;font-weight:900;color:var(--azul)}
.price-big{margin-top:10px;font-size:20px;font-weight:900;color:var(--azul)}
.cover{margin-top:12px;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#fff}
.cover img{width:100%;height:auto;display:block}
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.gallery img{width:100%;height:180px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.gallery figcaption{margin-top:6px;color:var(--muted);font-size:12px;font-weight:700}
.admin-shell{display:flex;min-height:100vh}
.admin-side{width:280px;background:var(--azul);color:#fff;padding:16px;position:fixed;top:0;bottom:0;left:0;overflow:auto}
.admin-main{margin-left:280px;width:calc(100% - 280px);padding:16px}
.admin-brand{display:flex;gap:10px;align-items:center;padding:10px 10px 14px;border-bottom:1px solid rgba(255,255,255,.15)}
.admin-mark{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.15);display:grid;place-items:center;font-weight:900}
.admin-name{font-weight:900}
.admin-sub{font-size:12px;opacity:.85;margin-top:2px}
.admin-nav{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.admin-nav a{padding:10px;border-radius:10px;font-weight:900;font-size:13px}
.admin-nav a:hover{background:rgba(255,255,255,.10)}
.admin-nav a.active{background:rgba(255,255,255,.18)}
.admin-top{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.admin-top-title{font-weight:900;color:var(--azul)}
.admin-top-meta{font-size:12px;color:var(--muted);font-weight:800}
.admin-content{padding-top:14px}
@media (max-width: 980px){.admin-side{position:static;width:100%}.admin-main{margin-left:0;width:100%}}
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:18px}
.login-card{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px}
.login-title{font-weight:900;color:var(--azul);font-size:18px}
.login-sub{color:var(--muted);font-weight:800;font-size:12px;margin-top:4px}
.alert{margin:10px 0;padding:10px;border-radius:12px;border:1px solid rgba(185,28,28,.35);background:rgba(185,28,28,.08);color:#7f1d1d;font-weight:900;font-size:12px}
.media-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.media-item{display:flex;gap:10px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px;background:#fff}
.media-item img{width:86px;height:62px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}
.media-meta{flex:1}
.media-cap{font-weight:800;font-size:12px;color:#0f172a}
.media-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

