/* ------------------------------
   Diseño general (inspirado en código original)
   ------------------------------ */
:root{
  --glass: rgba(251, 250, 250, 0.85);
  --shadow: 0 10px 30px rgba(0,0,0,0.12);
  --accent-gradient: linear-gradient(90deg,#ffee02,#eca50c,#e4d612,#ebcf16,#9b59b6);
  --primary: #1e3c72;
  --accent: #2d5291;
}

/* Reset y tipografía */
*{box-sizing:border-box;font-family:Inter, system-ui, Arial, Helvetica, sans-serif}
body{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(circle at 10% 20%, #ffffff 0%, transparent 20%),
    radial-gradient(circle at 90% 80%, #e7f5ff 0%, transparent 18%),
    linear-gradient(135deg,#ffecd2 0%,#fcb69f 25%,#c6ffdd 50%,#f3e7ff 75%);
  color:#000000;
}

/* Layout wrapper */
.page-wrap{display:flex;flex-direction:column;min-height:100vh}

/* Header */
.site-header{backdrop-filter:blur(6px);background:linear-gradient(90deg,var(--accent),#939393);padding:12px 18px;color:rgb(223, 0, 0)}
.header-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo{font-weight:800;letter-spacing:0.6px;font-size:1.1rem}
.top-nav a{color:rgba(255,255,255,0.95);text-decoration:none;margin-left:14px;padding:6px 10px;border-radius:8px;transition:0.18s}
.top-nav a:hover{background:rgba(255,255,255,0.08)}
.top-nav a.active{background:rgba(0,0,0,0.12)}

/* Footer */
.site-footer{margin-top:auto;padding:14px;text-align:center;color:#333;background:transparent}

/* Glass card */
.glass-card{
  background:var(--glass);
  padding:18px;border-radius:12px;box-shadow:var(--shadow);max-width:1100px;margin:18px auto;
}

/* Welcome card */
.welcome-card{text-align:center}
.welcome-card h1{margin:0 0 6px}
.welcome-card p{color:#333;margin-bottom:10px}
.cta-row{display:flex;justify-content:center}

/* Buttons */
.btn{
  display:inline-block;padding:10px 14px;border-radius:10px;border:none;font-weight:700;cursor:pointer;background:#ffffff;color:var(--accent);box-shadow:0 8px 18px rgba(0,0,0,0.08)
}
.btn.small{padding:8px 10px;font-size:0.9rem}
.btn.ghost{background:transparent;border:1px solid rgba(0,0,0,0.06);color:#222}
.btn.rainbow{background:var(--accent-gradient);color:white;box-shadow:0 10px 30px rgba(0,0,0,0.12)}

/* Forms and auth layout */
.auth-main{padding:18px}
.forms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;max-width:1100px;margin:12px auto}
.form-box{padding:16px;border-radius:12px;background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(255,255,255,0.9));box-shadow:var(--shadow)}
.form-box input, .form-box textarea, .form-box select{width:100%;padding:10px;border-radius:8px;border:1px solid #e6e6e6;margin:8px 0}

/* Gallery layout */
.gallery-main{max-width:none;width:100%;margin:18px auto;padding:0 18px}
.upload-panel{display:block;margin-bottom:12px}
.upload-controls input[type="file"]{padding:8px;border-radius:8px}
.upload-controls textarea{resize:vertical}

/* Filter */
.filter-panel{max-width:none;margin:0 auto;padding:0 18px}
.filter-row{display:flex;gap:12px;align-items:end;justify-content:space-between;padding:12px;border-radius:10px;background:linear-gradient(90deg,rgba(255,255,255,0.9),rgba(255,255,255,0.8));box-shadow:var(--shadow);margin-bottom:12px}
.filter-row label{display:block;font-weight:700;color:#333}

/* Grid of thumbnails */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:14px;
}
.thumb{
  background:white;border-radius:12px;padding:10px;box-shadow:0 6px 18px rgba(0,0,0,0.06);position:relative;overflow:hidden;transition:transform .22s,box-shadow .22s;
}
.thumb:hover{transform:translateY(-6px);box-shadow:0 14px 30px rgba(0,0,0,0.12)}
.thumb img{width:100%;height:160px;object-fit:cover;border-radius:8px;cursor:pointer}
.meta{padding:8px 6px}
.meta strong{display:block}
.tags{font-size:0.85rem;color:#444;margin-top:6px}
.actions{display:flex;gap:8px;margin-top:8px}
.badge{position:absolute;right:10px;top:10px;padding:6px 8px;border-radius:8px;font-weight:700;background:linear-gradient(90deg,#ffd89b,#19547b);color:#111}

/* Admin lists */
.admin-box{max-width:1100px;margin:18px auto;padding:12px;border-radius:12px}
.admin-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.admin-controls{display:flex;gap:8px;justify-content:center;margin-top:6px}
.admin-controls button{padding:8px 10px;border-radius:8px;border:none;font-weight:700;cursor:pointer}
.admin-controls .approve{background:#28a745;color:white}
.admin-controls .reject{background:#dc3545;color:white}

/* Modal */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.45);z-index:60;padding:20px}
.modal .modal-content{background:white;padding:18px;border-radius:12px;max-width:920px;width:100%;box-shadow:var(--shadow);position:relative}
.modal img{width:100%;border-radius:8px}
.modal .close{position:absolute;right:12px;top:8px;background:transparent;border:none;font-size:26px;cursor:pointer}
.modal-meta{padding-top:10px}
.muted{color:#666}
.small{font-size:0.85rem}

/* Utility: hidden */
.hidden{display:none !important}

/* Responsive */
@media(max-width:820px){
  .filter-row{flex-direction:column;align-items:stretch}
}

/* Width utility: 80% on desktop, 100% on mobile/tablet */
.wide-80{width:100%;margin-left:auto;margin-right:auto}
.glass-card.wide-80{max-width:none}
.admin-box.wide-80{max-width:none}
.filter-panel.wide-80{max-width:none}
@media(min-width:1024px){
  .wide-80{width:80%}
}
