feat: agregar selector de tema oscuro/claro
Toggle sol/luna en el navbar que permite cambiar entre tema oscuro (por defecto) y tema claro. Preferencia guardada en localStorage. Incluye overrides de CSS para todos los componentes con colores hardcodeados, inversión de logo, y transición suave entre temas. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -90,6 +90,288 @@
|
||||
--container-narrow: 800px;
|
||||
}
|
||||
|
||||
/* ----- Light Theme Overrides ----- */
|
||||
[data-theme="light"] {
|
||||
--color-primary: #f5f5f5;
|
||||
--color-primary-dark: #e8e8e8;
|
||||
--color-primary-light: #ffffff;
|
||||
--color-accent: #333333;
|
||||
--color-accent-dark: #555555;
|
||||
--color-accent-light: #222222;
|
||||
|
||||
--gradient-silver: linear-gradient(135deg, #222 0%, #333 25%, #2a2a2a 50%, #444 75%, #222 100%);
|
||||
--gradient-dark: linear-gradient(135deg, #f5f5f5 0%, #ffffff 50%, #fafafa 100%);
|
||||
--gradient-hero: linear-gradient(135deg, #e8e8e8 0%, #f5f5f5 40%, #efefef 100%);
|
||||
|
||||
--color-white: #111111;
|
||||
--color-off-white: #eaeaea;
|
||||
--color-gray-100: #e8e8e8;
|
||||
--color-gray-200: #d4d4d4;
|
||||
--color-gray-300: #bbbbbb;
|
||||
--color-gray-400: #999999;
|
||||
--color-gray-500: #777777;
|
||||
--color-gray-600: #555555;
|
||||
--color-gray-700: #3a3a3a;
|
||||
--color-gray-800: #2a2a2a;
|
||||
--color-gray-900: #1a1a1a;
|
||||
|
||||
--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
|
||||
--shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
|
||||
--shadow-lg: 0 8px 30px rgba(0, 0, 0, 0.12);
|
||||
--shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.15);
|
||||
--shadow-silver: 0 0 20px rgba(0, 0, 0, 0.05);
|
||||
}
|
||||
|
||||
/* Light-theme element overrides (hardcoded colors) */
|
||||
[data-theme="light"] .navbar {
|
||||
background-color: rgba(255, 255, 255, 0.95);
|
||||
border-bottom-color: rgba(0, 0, 0, 0.08);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar--scrolled {
|
||||
background-color: rgba(255, 255, 255, 0.98);
|
||||
box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1);
|
||||
border-bottom-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar__dropdown {
|
||||
background-color: #ffffff;
|
||||
border-color: rgba(0, 0, 0, 0.1);
|
||||
box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar__link:hover {
|
||||
background-color: rgba(0, 0, 0, 0.05);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar__dropdown-link:hover {
|
||||
background-color: rgba(0, 0, 0, 0.05);
|
||||
}
|
||||
|
||||
[data-theme="light"] .card--service,
|
||||
[data-theme="light"] .value-card,
|
||||
[data-theme="light"] .testimonial-card,
|
||||
[data-theme="light"] .contact__info-card,
|
||||
[data-theme="light"] .confirmation-card {
|
||||
background-color: #ffffff;
|
||||
border-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .card--service:hover {
|
||||
box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1), 0 0 20px rgba(0, 0, 0, 0.03);
|
||||
border-color: rgba(0, 0, 0, 0.18);
|
||||
}
|
||||
|
||||
[data-theme="light"] .testimonial-card:hover {
|
||||
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
|
||||
border-color: rgba(0, 0, 0, 0.15);
|
||||
}
|
||||
|
||||
[data-theme="light"] .contact__info-card:hover {
|
||||
background-color: #f8f8f8;
|
||||
border-color: rgba(0, 0, 0, 0.15);
|
||||
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
|
||||
}
|
||||
|
||||
[data-theme="light"] .service-detail__form {
|
||||
background-color: #ffffff;
|
||||
border-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .form-control {
|
||||
background-color: #ffffff;
|
||||
border-color: rgba(0, 0, 0, 0.2);
|
||||
color: #1a1a1a;
|
||||
}
|
||||
|
||||
[data-theme="light"] .form-control:focus {
|
||||
border-color: #333333;
|
||||
box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.08);
|
||||
}
|
||||
|
||||
[data-theme="light"] .form-control::placeholder {
|
||||
color: #999999;
|
||||
}
|
||||
|
||||
[data-theme="light"] select.form-control {
|
||||
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23333333' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
|
||||
}
|
||||
|
||||
[data-theme="light"] .footer {
|
||||
background-color: #e0e0e0;
|
||||
color: rgba(30, 30, 30, 0.7);
|
||||
border-top-color: rgba(0, 0, 0, 0.08);
|
||||
}
|
||||
|
||||
[data-theme="light"] .footer__text {
|
||||
color: rgba(30, 30, 30, 0.6);
|
||||
}
|
||||
|
||||
[data-theme="light"] .footer__contact-list a {
|
||||
color: rgba(30, 30, 30, 0.7);
|
||||
}
|
||||
|
||||
[data-theme="light"] .footer__bottom {
|
||||
color: rgba(30, 30, 30, 0.4);
|
||||
}
|
||||
|
||||
[data-theme="light"] .footer__grid {
|
||||
border-bottom-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .footer__social-link {
|
||||
background-color: rgba(0, 0, 0, 0.06);
|
||||
border-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .footer__social-link:hover {
|
||||
box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar__logo,
|
||||
[data-theme="light"] .footer__logo {
|
||||
filter: invert(1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .btn--primary {
|
||||
background: var(--gradient-silver);
|
||||
color: #ffffff;
|
||||
border-color: rgba(0, 0, 0, 0.2);
|
||||
}
|
||||
|
||||
[data-theme="light"] .btn--primary:hover {
|
||||
background: linear-gradient(135deg, #111 0%, #2a2a2a 25%, #1a1a1a 50%, #333 75%, #111 100%);
|
||||
border-color: rgba(0, 0, 0, 0.3);
|
||||
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
|
||||
}
|
||||
|
||||
[data-theme="light"] .btn--secondary {
|
||||
background-color: #e8e8e8;
|
||||
border-color: #555555;
|
||||
}
|
||||
|
||||
[data-theme="light"] .btn--secondary:hover {
|
||||
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .card__icon,
|
||||
[data-theme="light"] .value-card__icon {
|
||||
background: rgba(0, 0, 0, 0.05);
|
||||
border-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .card--service:hover .card__icon {
|
||||
background: rgba(0, 0, 0, 0.08);
|
||||
border-color: rgba(0, 0, 0, 0.15);
|
||||
}
|
||||
|
||||
[data-theme="light"] .contact__info-icon {
|
||||
background: rgba(0, 0, 0, 0.05);
|
||||
border-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .section__badge {
|
||||
background-color: rgba(0, 0, 0, 0.05);
|
||||
border-color: rgba(0, 0, 0, 0.12);
|
||||
}
|
||||
|
||||
[data-theme="light"] .hero__overlay {
|
||||
background-image:
|
||||
radial-gradient(ellipse at 20% 80%, rgba(0, 0, 0, 0.03) 0%, transparent 50%),
|
||||
radial-gradient(ellipse at 80% 20%, rgba(0, 0, 0, 0.02) 0%, transparent 50%);
|
||||
}
|
||||
|
||||
[data-theme="light"] .hero__subtitle {
|
||||
color: rgba(80, 80, 80, 0.85);
|
||||
}
|
||||
|
||||
[data-theme="light"] .hero__stats {
|
||||
border-top-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .hero__stat-label {
|
||||
color: rgba(80, 80, 80, 0.6);
|
||||
}
|
||||
|
||||
[data-theme="light"] .service-hero {
|
||||
border-bottom-color: rgba(0, 0, 0, 0.06);
|
||||
}
|
||||
|
||||
[data-theme="light"] .service-hero__price {
|
||||
color: rgba(80, 80, 80, 0.75);
|
||||
}
|
||||
|
||||
[data-theme="light"] .service-hero__icon {
|
||||
background: rgba(0, 0, 0, 0.04);
|
||||
border-color: rgba(0, 0, 0, 0.12);
|
||||
}
|
||||
|
||||
[data-theme="light"] .contact__map {
|
||||
border-color: rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar__overlay {
|
||||
background-color: rgba(0, 0, 0, 0.3);
|
||||
}
|
||||
|
||||
[data-theme="light"] .form-heading {
|
||||
border-bottom-color: rgba(0, 0, 0, 0.15);
|
||||
}
|
||||
|
||||
/* Mobile menu light override */
|
||||
@media (max-width: 768px) {
|
||||
[data-theme="light"] .navbar__menu {
|
||||
background-color: #ffffff;
|
||||
border-left-color: rgba(0, 0, 0, 0.08);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar__link {
|
||||
border-bottom-color: rgba(0, 0, 0, 0.06);
|
||||
}
|
||||
|
||||
[data-theme="light"] .navbar__dropdown-link {
|
||||
border-bottom-color: rgba(0, 0, 0, 0.06);
|
||||
}
|
||||
}
|
||||
|
||||
/* Theme toggle button */
|
||||
.theme-toggle {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
border-radius: 50%;
|
||||
background: transparent;
|
||||
border: 1.5px solid rgba(192, 192, 192, 0.2);
|
||||
color: var(--color-accent);
|
||||
font-size: 1.1rem;
|
||||
cursor: pointer;
|
||||
transition: all var(--transition-base);
|
||||
flex-shrink: 0;
|
||||
margin-right: var(--space-sm);
|
||||
}
|
||||
|
||||
.theme-toggle:hover {
|
||||
background-color: rgba(192, 192, 192, 0.1);
|
||||
border-color: rgba(192, 192, 192, 0.35);
|
||||
transform: scale(1.05);
|
||||
}
|
||||
|
||||
[data-theme="light"] .theme-toggle {
|
||||
border-color: rgba(0, 0, 0, 0.15);
|
||||
}
|
||||
|
||||
[data-theme="light"] .theme-toggle:hover {
|
||||
background-color: rgba(0, 0, 0, 0.05);
|
||||
border-color: rgba(0, 0, 0, 0.25);
|
||||
}
|
||||
|
||||
/* Smooth theme transition */
|
||||
html {
|
||||
transition: background-color 0.3s ease, color 0.3s ease;
|
||||
}
|
||||
|
||||
/* ============================================================
|
||||
CSS Reset (Modern)
|
||||
============================================================ */
|
||||
|
||||
Reference in New Issue
Block a user