/* Colores y diseño */
body { margin:0; font-family:Arial,Helvetica,sans-serif; background:#f0f0f5; color:#222; }
:root { --primario:#8b2fc9; --secundario:#ffb347; --oscuro:#222; --claro:#fff; }

/* Header y menú */
header { background:var(--primario); color:white; padding:20px; text-align:center; font-size:1.6rem; position:sticky; top:0; z-index:1000; }
.menu-btn { position:absolute; left:18px; top:16px; width:30px; cursor:pointer; }
.menu-btn div { height:4px; background:white; margin:5px 0; transition:0.3s; }

#menu { position:fixed; top:0; left:-260px; width:260px; height:100vh; background:var(--oscuro); color:white; padding:18px; transition:0.28s; box-shadow:2px 0 8px rgba(0,0,0,0.2); }
#menu.visible { left:0; }
#menu ul { list-style:none; padding:0; margin:0; }
#menu li { margin:12px 0; }
#menu a { color:white; text-decoration:none; }
.contact-btn { width:100%; padding:12px; background:var(--secundario); border:none; border-radius:8px; cursor:pointer; font-weight:bold; }

/* Secciones y animación scroll */
.section { opacity:0; transform:translateY(40px); transition:all .7s ease-out; padding:50px 20px; max-width:980px; margin:24px auto; text-align:center; }
.section.visible { opacity:1; transform:translateY(0); }

/* Productos */
.productos { display:grid; gap:20px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); margin-top:18px; }
.producto { background:var(--claro); padding:20px; border-radius:10px; border-left:6px solid var(--secundario); box-shadow:0 6px 18px rgba(0,0,0,0.06); }

/* Calendario */
#calendar-wrap { max-width:720px; margin:0 auto 18px; }
#calendar-controls { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
#calendar-controls button { padding:6px 10px; border-radius:6px; border:1px solid #ddd; background:white; cursor:pointer; }
#calendar { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.day { padding:10px; background:white; border-radius:8px; min-height:60px; display:flex; align-items:flex-start; justify-content:flex-start; flex-direction:column; box-shadow:0 4px 12px rgba(0,0,0,0.03); transition:transform .15s; }
.day:hover { transform:translateY(-4px); }
.day .num { font-weight:600; margin-bottom:6px; }
.day.free { border-left:4px solid #2ecc71; }
.day.booked { border-left:4px solid #e74c3c; opacity:0.95; background:linear-gradient(180deg,#fff,#fff6f6); }
.dot { display:inline-block; width:12px; height:12px; border-radius:50%; margin-right:6px; vertical-align:middle; }
.dot.free { background:#2ecc71; }
.dot.booked { background:#e74c3c; }
#legend { text-align:center; color:#555; margin-top:8px; }

/* Formulario */
form { background:var(--claro); padding:18px; border-radius:10px; box-shadow:0 6px 18px rgba(0,0,0,0.06); }
input, textarea, button { width:100%; padding:12px; margin:8px 0; border-radius:8px; border:1px solid #ccc; font-size:1rem; box-sizing:border-box; }
button { background:var(--primario); color:white; border:none; cursor:pointer; }

/* Responsive */
@media (max-width:700px){ .day { min-height:72px; } }
