 /** * FixFiks - Main Stylesheet * Global styles,CSS variables,and base styles */ /* =================================== CSS VARIABLES (Design Tokens) =================================== */ :root{--color-blue-dark:#1e3a8a;--color-blue-light:#2563eb;--color-yellow:#fbbf24;--color-green:#10b981;--color-gray-bg:#f3f4f6;--color-white:#ffffff;--color-black:#000000;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,0.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.1);--shadow-xl:0 20px 25px -5px rgba(0,0,0,0.1);--transition-fast:0.15s ease;--transition-base:0.3s ease;--transition-slow:0.5s ease;--z-base:1;--z-header:100;--z-overlay:200;--z-menu:300;} /* =================================== CSS RESET & BASE STYLES =================================== */ *,*::before,*::after{box-sizing:border-box;margin:0;padding:0;} html{font-size:16px;-webkit-text-size-adjust:100%;overflow:hidden;height:100%;} html,body{overscroll-behavior:none;} body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-800);background-color:var(--color-white);height:100%;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;} body.menu-open{overflow:hidden;} /* =================================== TYPOGRAPHY =================================== */ h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-gray-900);} h1{font-size:var(--font-size-3xl);} h2{font-size:var(--font-size-2xl);} h3{font-size:var(--font-size-xl);} h4{font-size:var(--font-size-lg);} p{margin-bottom:var(--spacing-md);} a{color:var(--color-blue-light);text-decoration:none;transition:color var(--transition-fast);} a:hover{color:var(--color-blue-dark);} /* =================================== LISTS =================================== */ ul,ol{padding-left:var(--spacing-lg);margin-bottom:var(--spacing-md);} li{margin-bottom:var(--spacing-xs);} .service-list,.checkmark-list{list-style:none;padding-left:0;} .service-list li,.checkmark-list li{position:relative;padding-left:var(--spacing-lg);margin-bottom:var(--spacing-sm);} .service-list li::before,.checkmark-list li::before{content:"\2713";position:absolute;left:0;color:var(--color-green);font-weight:bold;} /* =================================== BUTTONS =================================== */ button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;} button:focus-visible,a:focus-visible{outline:2px solid var(--color-blue-light);outline-offset:2px;} /* =================================== UTILITY CLASSES =================================== */ .visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;} .desktop-only{display:none;} .mobile-only{display:block;} /* =================================== APP CONTAINER =================================== */ .app-container{display:flex;flex-direction:column;min-height:100vh;width:100%;} /* =================================== BLUE HEADER/SIDEBAR =================================== */ .blue-header{background:linear-gradient(135deg,var(--color-blue-dark) 0%,var(--color-blue-light) 100%);color:var(--color-white);position:fixed;top:0;left:0;width:100%;height:40vh;min-height:320px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md);z-index:var(--z-header);overflow:hidden;isolation:isolate;contain:layout style paint;will-change:transform;transform:translateZ(0);} .blue-header::before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,0.1) 0%,transparent 60%);pointer-events:none;} .blue-header::after{content:"";position:absolute;bottom:-30%;left:-30%;width:80%;height:80%;background:radial-gradient(circle,rgba(255,255,255,0.05) 0%,transparent 50%);pointer-events:none;} /* =================================== LOGO =================================== */ .logo{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);} .logo-icon{font-size:var(--font-size-2xl);} .logo-text{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-white);} .logo-highlight{color:var(--color-yellow);} /* =================================== MAIN HEADING =================================== */ .main-heading{font-size:var(--font-size-xl);font-weight:500;color:var(--color-white);margin-bottom:var(--spacing-md);text-align:center;} /* =================================== BURGER MENU BUTTON =================================== */ .burger-menu{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:40px;height:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:rgba(255,255,255,0.1);border-radius:var(--radius-md);transition:background var(--transition-fast);z-index:calc(var(--z-header) + 1);} .burger-menu:hover{background:rgba(255,255,255,0.2);} .burger-line{display:block;width:22px;height:2px;background-color:var(--color-white);border-radius:var(--radius-full);transition:transform var(--transition-base),opacity var(--transition-base);} .burger-menu.active .burger-line:nth-child(1){transform:translateY(7px) rotate(45deg);} .burger-menu.active .burger-line:nth-child(2){opacity:0;} .burger-menu.active .burger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg);} /* =================================== CATEGORY BUTTONS =================================== */ .categories{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);width:100%;max-width:320px;margin-bottom:var(--spacing-md);} .category-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-xs);background:rgba(255,255,255,0.15);border-radius:var(--radius-md);color:var(--color-white);min-height:70px;transition:all var(--transition-fast);position:relative;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,0.1);} .category-btn:hover:not(:disabled){background:rgba(255,255,255,0.25);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.15);border-color:rgba(255,255,255,0.2);} .category-btn:active:not(:disabled){transform:translateY(0) scale(0.98);} .category-btn.active{background:var(--color-white);color:var(--color-blue-dark);box-shadow:0 4px 16px rgba(0,0,0,0.2);border-color:transparent;} .category-btn.active .category-icon{transform:scale(1.1);} .category-btn:disabled{opacity:0.6;cursor:not-allowed;background:rgba(255,255,255,0.08);} .category-icon{font-size:var(--font-size-xl);margin-bottom:var(--spacing-xs);} .category-name{font-size:var(--font-size-sm);font-weight:500;} .coming-soon-badge{position:absolute;top:-4px;right:-4px;background:var(--color-yellow);color:var(--color-gray-900);font-size:9px;font-weight:700;padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;} /* =================================== CONTACT BUTTONS =================================== */ .contact-buttons{display:flex;gap:var(--spacing-sm);width:100%;max-width:320px;} .contact-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-sm);border-radius:var(--radius-md);color:var(--color-white);text-decoration:none;min-height:50px;transition:all var(--transition-fast);position:relative;overflow:hidden;} .contact-btn::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s ease;} .contact-btn:hover::before{left:100%;} .contact-call{background:linear-gradient(135deg,#3b82f6 0%,var(--color-blue-light) 100%);} .contact-whatsapp{background:linear-gradient(135deg,#22c55e 0%,var(--color-green) 100%);} .contact-email{background:linear-gradient(135deg,#6b7280 0%,var(--color-gray-600) 100%);} .contact-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,0.25);color:var(--color-white);} .contact-btn:active{transform:translateY(-1px);} .contact-icon{font-size:var(--font-size-lg);} .contact-text{font-size:var(--font-size-xs);font-weight:500;margin-top:2px;} /* =================================== INSTAGRAM LINK =================================== */ .instagram-link{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-white);text-decoration:none;font-size:var(--font-size-sm);opacity:0.8;transition:opacity var(--transition-fast);padding:var(--spacing-sm);} .instagram-link:hover{opacity:1;color:var(--color-white);} .instagram-icon{font-size:var(--font-size-lg);} /* =================================== WHITE CONTENT AREA =================================== */ .white-content{margin-top:40vh;min-height:60vh;padding:var(--spacing-lg);background:var(--color-white);overflow-y:auto;scroll-behavior:auto;isolation:isolate;contain:layout style paint;position:relative;z-index:1;} .content-container{max-width:800px;margin:0 auto;} /* =================================== PAGE SECTIONS =================================== */ .page-section{} .section-title{color:var(--color-blue-dark);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-gray-200);} .section-intro{font-size:var(--font-size-lg);color:var(--color-gray-600);margin-bottom:var(--spacing-lg);} /* =================================== SERVICE OVERVIEW (Home Page) =================================== */ .service-overview{background:var(--color-gray-100);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);} /* =================================== TRUST BADGES =================================== */ .trust-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:var(--spacing-lg);} .badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-gray-100);border-radius:var(--radius-md);} .badge-icon{font-size:var(--font-size-lg);} .badge-text{font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-700);} /* =================================== MENU OVERLAY =================================== */ .menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base);z-index:var(--z-overlay);} .menu-overlay.active{opacity:1;visibility:visible;} /* =================================== MENU SIDEBAR =================================== */ .menu-sidebar{position:fixed;top:0;right:0;width:80%;max-width:300px;height:100vh;height:100dvh;background:var(--color-gray-100);transform:translateX(100%);transition:transform var(--transition-base) cubic-bezier(0.4,0,0.2,1);z-index:var(--z-menu);padding:var(--spacing-xl) var(--spacing-lg);overflow-y:auto;box-shadow:-10px 0 30px rgba(0,0,0,0.1);} .menu-sidebar.active{transform:translateX(0);} .menu-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-green);color:var(--color-white);border-radius:var(--radius-md);font-size:var(--font-size-2xl);font-weight:300;transition:all var(--transition-fast);} .menu-close:hover{background:#0d9668;transform:rotate(90deg);} .menu-items{list-style:none;padding:0;margin-top:var(--spacing-2xl);} .menu-items li{margin-bottom:var(--spacing-xs);opacity:0;transform:translateX(20px);transition:opacity 0.3s ease,transform 0.3s ease;} .menu-sidebar.active .menu-items li{opacity:1;transform:translateX(0);} .menu-sidebar.active .menu-items li:nth-child(1){transition-delay:0.05s;} .menu-sidebar.active .menu-items li:nth-child(2){transition-delay:0.1s;} .menu-sidebar.active .menu-items li:nth-child(3){transition-delay:0.15s;} .menu-sidebar.active .menu-items li:nth-child(4){transition-delay:0.2s;} .menu-sidebar.active .menu-items li:nth-child(5){transition-delay:0.25s;} .menu-sidebar.active .menu-items li:nth-child(6){transition-delay:0.3s;} .menu-sidebar.active .menu-items li:nth-child(7){transition-delay:0.35s;} .menu-sidebar.active .menu-items li:nth-child(8){transition-delay:0.4s;} .menu-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);color:var(--color-gray-800);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);font-weight:500;border:1px solid transparent;} .menu-item:hover{background:var(--color-gray-200);color:var(--color-gray-800);transform:translateX(4px);border-color:var(--color-gray-300);} .menu-item.active{background:var(--color-blue-dark);color:var(--color-white);box-shadow:0 2px 8px rgba(30,58,138,0.3);} .menu-item.active:hover{transform:translateX(0);} .menu-icon{font-size:var(--font-size-xl);transition:transform var(--transition-fast);} .menu-item:hover .menu-icon{transform:scale(1.1);} /* =================================== CERTIFICATE CARDS =================================== */ .cert-card{background:var(--color-gray-100);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);border-left:4px solid var(--color-green);} .cert-card h4{margin-bottom:var(--spacing-sm);color:var(--color-blue-dark);} .cert-card.coming-soon{border-left-color:var(--color-yellow);opacity:0.8;} /* =================================== PRICE TABLE =================================== */ .price-table{width:100%;border-collapse:collapse;margin:var(--spacing-lg) 0;} .price-table th,.price-table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-gray-200);} .price-table th{background:var(--color-blue-dark);color:var(--color-white);} .price-table tr:hover{background:var(--color-gray-100);} /* =================================== SERVICE GROUPS (Content Area) =================================== */ .service-group{background:var(--color-gray-100);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);} .service-group h3{color:var(--color-blue-dark);margin-bottom:var(--spacing-md);display:flex;justify-content:space-between;align-items:center;} .service-price{font-size:var(--font-size-sm);color:var(--color-green);font-weight:600;} /* =================================== RESPONSIVE IMAGES =================================== */ img{max-width:100%;height:auto;display:block;} .gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin:var(--spacing-lg) 0;} .gallery-item{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;} .gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base);} .gallery-item:hover img{transform:scale(1.05);} /* =================================== LOADING STATE =================================== */ .loading{display:flex;align-items:center;justify-content:center;min-height:200px;} .loading::after{content:"";width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-blue-light);border-radius:50%;animation:spin 1s linear infinite;} @keyframes spin{to{transform:rotate(360deg);}} /* =================================== PAGE TRANSITIONS (disabled for instant content swap) =================================== */ .content-container{} .page-section{} /* Unused keyframes - commented out @keyframes pageEnter{from{opacity:0;} to{opacity:1;}} */ /* =================================== 404 PAGE =================================== */ .page-404{text-align:center;padding:var(--spacing-2xl) var(--spacing-md);} .page-404 .error-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:bounce 2s ease-in-out infinite;} @keyframes bounce{0%,100%{transform:translateY(0);} 50%{transform:translateY(-10px);}} .page-404 .section-title{color:var(--color-gray-700);margin-bottom:var(--spacing-md);} .page-404 .section-intro{color:var(--color-gray-500);margin-bottom:var(--spacing-xl);} .page-404 .error-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap;} /* =================================== BUTTONS =================================== */ .btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base);font-weight:600;text-decoration:none;border-radius:var(--radius-lg);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);min-height:48px;} .btn-primary{background:var(--color-blue-dark);color:var(--color-white);border-color:var(--color-blue-dark);} .btn-primary:hover{background:var(--color-blue-light);border-color:var(--color-blue-light);transform:translateY(-2px);box-shadow:var(--shadow-md);} .btn-secondary{background:var(--color-white);color:var(--color-blue-dark);border-color:var(--color-blue-dark);} .btn-secondary:hover{background:var(--color-blue-dark);color:var(--color-white);transform:translateY(-2px);box-shadow:var(--shadow-md);} /* =================================== LOADING OVERLAY =================================== */ .loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,0.9);display:flex;align-items:center;justify-content:center;z-index:var(--z-overlay);opacity:0;visibility:hidden;transition:opacity var(--transition-fast),visibility var(--transition-fast);} .loading-overlay.active{opacity:1;visibility:visible;} .loading-overlay .spinner{width:50px;height:50px;border:4px solid var(--color-gray-200);border-top-color:var(--color-blue-dark);border-radius:50%;animation:spin 0.8s linear infinite;} /* =================================== SKIP LINK (Accessibility) =================================== */ .skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--color-blue-dark);color:var(--color-white);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);z-index:1000;transition:top var(--transition-fast);} .skip-link:focus{top:var(--spacing-md);} /* =================================== PRINT STYLES =================================== */ @media print{.blue-header,.burger-menu,.menu-sidebar,.menu-overlay,.contact-buttons{display:none !important;} .white-content{margin-top:0;padding:0;} body{color:#000;background:#fff;}} .lang-switcher{display:flex;gap:4px;position:fixed;top:12px;left:12px;z-index:9999;} @media (min-width:768px){.lang-switcher{top:16px;left:16px;}} .lang-btn{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.3);color:rgba(255,255,255,0.7);border-radius:4px;padding:3px 8px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s;} .lang-btn:hover{background:rgba(255,255,255,0.25);color:#fff;} .lang-btn--active{background:rgba(255,255,255,0.3);border-color:rgba(255,255,255,0.6);color:#fff;} .about-photo{margin-bottom:24px;text-align:center;} .about-photo img{width:160px;height:160px;border-radius:50%;object-fit:cover;border:4px solid var(--color-blue-light,#2563eb);box-shadow:0 4px 16px rgba(0,0,0,0.12);} .service-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-top:24px;} .service-photo img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:8px;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s;} .service-photo img:hover{transform:scale(1.03);box-shadow:0 4px 16px rgba(0,0,0,0.15);} /** * FixFiks - Component Styles * Enhanced styles for UI components */ /* =================================== CERTIFICATE CARDS =================================== */ .cert-card{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast);} .cert-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);} .cert-card--coming-soon{background:linear-gradient(135deg,#fefce8 0%,#fef9c3 100%);border-color:var(--color-yellow);} .cert-card__icon{font-size:2.5rem;flex-shrink:0;} .cert-card__content{flex:1;} .cert-card__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-800);margin:0 0 var(--spacing-xs) 0;} .cert-card__value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-blue-dark);margin:0 0 var(--spacing-xs) 0;} .cert-card__description{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0;} .cert-card__badge{display:inline-block;background:var(--color-yellow);color:var(--color-gray-800);font-size:var(--font-size-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-top:var(--spacing-xs);} /* =================================== SERVICE GROUPS (Enhanced) =================================== */ .service-group{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);transition:box-shadow var(--transition-fast);} .service-group:hover{box-shadow:var(--shadow-md);} .service-group__header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap;} .service-group__icon{font-size:var(--font-size-xl);} .service-group__name{flex:1;font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-800);} .service-price{background:var(--color-blue-dark);color:var(--color-white);font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);white-space:nowrap;} /* =================================== GALLERY =================================== */ .gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md);margin:var(--spacing-lg) 0;} .gallery-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;background:var(--color-gray-100);aspect-ratio:4/3;} .gallery-item__image{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base);} .gallery-item:hover .gallery-item__image{transform:scale(1.05);} .gallery-item__caption{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(transparent,rgba(0,0,0,0.7));color:var(--color-white);font-size:var(--font-size-sm);margin:0;} .gallery-empty{text-align:center;padding:var(--spacing-2xl);background:var(--color-gray-100);border-radius:var(--radius-lg);color:var(--color-gray-500);} .gallery-empty__icon{display:block;font-size:3rem;margin-bottom:var(--spacing-md);opacity:0.5;} .gallery-note{text-align:center;color:var(--color-gray-500);font-size:var(--font-size-sm);margin-top:var(--spacing-md);font-style:italic;} .gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(transparent,rgba(0,0,0,0.7));color:var(--color-white);font-size:var(--font-size-sm);margin:0;} /* =================================== LIGHTBOX =================================== */ .lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.95);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base);} .lightbox.active{opacity:1;visibility:visible;} .lightbox__content{max-width:90vw;max-height:85vh;display:flex;flex-direction:column;align-items:center;} .lightbox__image{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-md);} .lightbox__caption{color:var(--color-white);text-align:center;padding:var(--spacing-md);font-size:var(--font-size-sm);max-width:600px;} .lightbox__close,.lightbox__prev,.lightbox__next{position:absolute;background:rgba(255,255,255,0.1);border:none;color:var(--color-white);font-size:2rem;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);} .lightbox__close:hover,.lightbox__prev:hover,.lightbox__next:hover{background:rgba(255,255,255,0.2);} .lightbox__close{top:var(--spacing-md);right:var(--spacing-md);font-size:2.5rem;} .lightbox__prev{left:var(--spacing-md);top:50%;transform:translateY(-50%);} .lightbox__next{right:var(--spacing-md);top:50%;transform:translateY(-50%);} .lightbox__counter{position:absolute;bottom:var(--spacing-md);left:50%;transform:translateX(-50%);color:var(--color-white);font-size:var(--font-size-sm);background:rgba(0,0,0,0.5);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);} body.lightbox-open{overflow:hidden;} /* =================================== PRICE TABLE (Enhanced) =================================== */ .price-table-wrapper{overflow-x:auto;margin:var(--spacing-lg) 0;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);} .price-table{width:100%;border-collapse:collapse;font-size:var(--font-size-base);} .price-table th,.price-table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-gray-200);} .price-table th{background:var(--color-blue-dark);color:var(--color-white);font-weight:600;} .price-table th:first-child{border-top-left-radius:var(--radius-lg);} .price-table th:last-child{border-top-right-radius:var(--radius-lg);} .price-table tbody tr:hover{background:var(--color-gray-50);} .price-table tbody tr:last-child td{border-bottom:none;} .price-table__service{font-weight:500;} .price-table__rate{white-space:nowrap;color:var(--color-blue-dark);} .price-table__note{color:var(--color-gray-500);font-size:var(--font-size-sm);} /* =================================== BUSINESS HOURS (Enhanced) =================================== */ .business-hours{background:var(--color-gray-100);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-top:var(--spacing-lg);} .business-hours h3{margin:0 0 var(--spacing-md) 0;color:var(--color-blue-dark);font-size:var(--font-size-lg);} .business-hours__list{display:flex;flex-direction:column;gap:var(--spacing-sm);} .business-hours__row{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px dashed var(--color-gray-300);} .business-hours__row:last-child{border-bottom:none;} .business-hours__days{font-weight:500;color:var(--color-gray-700);} .business-hours__time{color:var(--color-gray-600);} .business-hours__row--closed .business-hours__time{color:var(--color-gray-400);} .business-hours__response,.response-time{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-gray-300);color:var(--color-green);font-weight:500;font-size:var(--font-size-sm);} /* =================================== CTA SECTION =================================== */ .cta-section{text-align:center;padding:var(--spacing-xl);background:linear-gradient(135deg,var(--color-blue-dark) 0%,var(--color-blue-light) 100%);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0;} .cta-section__title{color:var(--color-white);font-size:var(--font-size-xl);margin:0 0 var(--spacing-sm) 0;} .cta-section__subtitle{color:rgba(255,255,255,0.9);margin:0 0 var(--spacing-lg) 0;} .cta-section__buttons{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap;} .cta-section .btn-primary{background:var(--color-white);color:var(--color-blue-dark);border-color:var(--color-white);} .cta-section .btn-primary:hover{background:var(--color-yellow);border-color:var(--color-yellow);} .cta-section .btn-secondary{background:transparent;color:var(--color-white);border-color:var(--color-white);} .cta-section .btn-secondary:hover{background:var(--color-white);color:var(--color-blue-dark);} /* =================================== FEATURE LIST =================================== */ .feature-list{margin:var(--spacing-lg) 0;} .feature-list__title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--color-gray-800);} /* =================================== PAGE HEADER =================================== */ .page-header{margin-bottom:var(--spacing-xl);} .page-header .section-title{margin-bottom:var(--spacing-sm);} .page-header .section-intro{color:var(--color-gray-600);font-size:var(--font-size-lg);} /* =================================== RESPONSIVE ADJUSTMENTS =================================== */ @media (max-width:767px){.cert-card{flex-direction:column;text-align:center;} .cert-card__icon{margin-bottom:var(--spacing-sm);} .gallery-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);} .lightbox__prev,.lightbox__next{width:40px;height:40px;font-size:1.5rem;} .lightbox__close{width:40px;height:40px;font-size:2rem;} .price-table th,.price-table td{padding:var(--spacing-sm);font-size:var(--font-size-sm);} .business-hours__row{flex-direction:column;gap:var(--spacing-xs);}} @media (min-width:768px){.gallery-grid{grid-template-columns:repeat(3,1fr);}} @media (min-width:1024px){.gallery-grid{grid-template-columns:repeat(4,1fr);}} /* =================================== CONTACT METHODS (Contact Page) =================================== */ .contact-methods{display:flex;flex-direction:column;gap:var(--spacing-md);margin:var(--spacing-lg) 0;} .contact-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);text-decoration:none;color:var(--color-gray-800);transition:all var(--transition-fast);} .contact-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-blue-light);color:var(--color-gray-800);} @media (min-width:768px){.contact-methods{flex-direction:row;flex-wrap:wrap;} .contact-card{flex:1;min-width:200px;flex-direction:column;text-align:center;}} /* =================================== COMING SOON NOTICE =================================== */ .coming-soon-notice{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(135deg,#fefce8 0%,#fef9c3 100%);border:1px solid var(--color-yellow);border-radius:var(--radius-lg);margin:var(--spacing-lg) 0;} .coming-soon-notice__icon,.notice-icon{font-size:2rem;flex-shrink:0;} .coming-soon-notice__content,.notice-content{flex:1;} .coming-soon-notice__content h4,.notice-content h4{color:var(--color-gray-800);margin:0 0 var(--spacing-xs) 0;} .coming-soon-notice__content p,.notice-content p{color:var(--color-gray-600);margin:0;font-size:var(--font-size-sm);} .coming-soon-notice__date{color:var(--color-gray-500);font-style:italic;margin-top:var(--spacing-sm) !important;} /* =================================== CONTACT INFO EXTRA =================================== */ .contact-info-extra{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-gray-200);} .contact-info-extra h3{font-size:var(--font-size-base);color:var(--color-gray-700);margin:var(--spacing-lg) 0 var(--spacing-sm) 0;} .contact-info-extra h3:first-child{margin-top:0;} .contact-info-extra p{color:var(--color-gray-600);margin:0;} /* =================================== CONTACT CARD ENHANCED =================================== */ .contact-card__icon{font-size:2rem;} .contact-card__label{font-weight:600;font-size:var(--font-size-lg);} .contact-card__value{color:var(--color-gray-500);font-size:var(--font-size-sm);margin-left:auto;} .contact-card--whatsapp{background:linear-gradient(135deg,#dcfce7 0%,#bbf7d0 100%);} @media (min-width:768px){.contact-card__value{margin-left:0;}} /* =================================== INTERACTIVE ENHANCEMENTS =================================== */ @media (hover:none) and (pointer:coarse){.category-btn:active,.contact-btn:active,.menu-item:active,.btn:active{transform:scale(0.97);opacity:0.9;}} .category-btn:focus-visible,.contact-btn:focus-visible,.menu-item:focus-visible,.contact-card:focus-visible{outline:3px solid var(--color-yellow);outline-offset:2px;} .skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;} @keyframes skeleton-loading{0%{background-position:200% 0;} 100%{background-position:-200% 0;}} .page-section{animation:pageSlideIn 0.4s ease-out;} @keyframes pageSlideIn{from{opacity:0;transform:translateY(30px);} to{opacity:1;transform:translateY(0);}} .gallery-item__image,.gallery-item img{opacity:0;transition:opacity 0.3s ease;} .gallery-item__image.loaded,.gallery-item img.loaded{opacity:1;} @keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(37,99,235,0.4);} 50%{box-shadow:0 0 0 10px rgba(37,99,235,0);}} .contact-btn.contact-whatsapp{animation:pulse 2s infinite;} .contact-btn.contact-whatsapp:hover,.contact-btn.contact-whatsapp:focus{animation:none;} @media (prefers-reduced-motion:reduce){.page-section,.skeleton,.contact-btn.contact-whatsapp{animation:none;} .gallery-item__image,.gallery-item img{opacity:1;transition:none;}} /** * FixFiks - Mobile Styles * Mobile-first base styles (0 - 767px) * Vertical layout:40vh header top,60vh content bottom */ /* =================================== MOBILE LAYOUT (Default/Base) =================================== */ .app-container{flex-direction:column;min-height:100vh;min-height:100dvh;} .blue-header{width:100%;height:40vh;min-height:300px;max-height:420px;position:fixed;top:0;left:0;padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-sm);transform:translateZ(0);} .white-content{margin-top:40vh;height:60vh;height:60dvh;min-height:60vh;padding:var(--spacing-md);padding-bottom:calc(var(--spacing-xl) + 20px);overflow-y:auto;transform:translateZ(0);} /* =================================== MOBILE LOGO =================================== */ .logo{margin-bottom:var(--spacing-sm);} .logo-icon{font-size:var(--font-size-xl);} .logo-text{font-size:var(--font-size-xl);} /* =================================== MOBILE TYPOGRAPHY =================================== */ .main-heading{font-size:var(--font-size-base);margin-bottom:var(--spacing-sm);} .section-title{font-size:var(--font-size-xl);} .section-intro{font-size:var(--font-size-base);} /* =================================== MOBILE CATEGORIES (2x2 Grid) =================================== */ .categories{grid-template-columns:repeat(2,1fr);gap:8px;max-width:280px;margin-bottom:var(--spacing-sm);} .category-btn{min-height:58px;padding:var(--spacing-xs) var(--spacing-xs);} .category-icon{font-size:var(--font-size-lg);margin-bottom:2px;} .category-name{font-size:11px;} .coming-soon-badge{font-size:8px;padding:1px 4px;top:-2px;right:-2px;} /* =================================== MOBILE CONTACT BUTTONS =================================== */ .contact-buttons{max-width:280px;flex-direction:row;gap:8px;} .contact-btn{min-height:44px;padding:var(--spacing-xs) var(--spacing-xs);} .contact-icon{font-size:var(--font-size-base);} .contact-text{font-size:10px;margin-top:1px;} /* =================================== MOBILE BURGER MENU =================================== */ .burger-menu{width:36px;height:36px;top:var(--spacing-sm);right:var(--spacing-sm);} .burger-line{width:18px;} .menu-sidebar{width:85%;max-width:300px;} /* =================================== MOBILE INSTAGRAM LINK =================================== */ .instagram-link.desktop-only{display:none !important;} .instagram-link.mobile-only{display:flex;justify-content:center;margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-gray-100);border-radius:var(--radius-md);color:var(--color-gray-600);} .instagram-link.mobile-only:hover{background:var(--color-gray-200);color:var(--color-gray-800);} /* =================================== MOBILE CONTENT SECTIONS =================================== */ .content-container{padding:0;} .service-overview{padding:var(--spacing-md);} .service-group{padding:var(--spacing-md);} .service-group h3{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);} .service-price{font-size:var(--font-size-xs);} /* =================================== MOBILE GALLERY =================================== */ .gallery-grid{grid-template-columns:1fr;gap:var(--spacing-sm);} /* =================================== MOBILE TRUST BADGES =================================== */ .trust-badges{flex-direction:column;gap:var(--spacing-sm);} .badge{width:100%;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);} /* =================================== MOBILE PRICE TABLE =================================== */ .price-table{font-size:var(--font-size-sm);display:block;overflow-x:auto;} .price-table th,.price-table td{padding:var(--spacing-sm);white-space:nowrap;} @media (max-width:400px){.price-table th:last-child,.price-table td:last-child{display:none;}} /* =================================== MOBILE CERTIFICATE CARDS =================================== */ .cert-card{padding:var(--spacing-md);} /* =================================== VERY SMALL SCREENS (320px - 359px) =================================== */ @media (max-width:359px){.blue-header{padding:var(--spacing-xs) var(--spacing-sm);min-height:280px;} .logo-text{font-size:var(--font-size-lg);} .main-heading{font-size:var(--font-size-sm);} .categories{max-width:240px;gap:6px;} .category-btn{min-height:52px;} .category-icon{font-size:var(--font-size-base);} .category-name{font-size:10px;} .contact-buttons{max-width:240px;gap:6px;} .contact-btn{min-height:40px;} .white-content{padding:var(--spacing-sm);} .section-title{font-size:var(--font-size-lg);}} /* =================================== SMALL MOBILE (360px - 413px) iPhone SE,small Android =================================== */ @media (min-width:360px) and (max-width:413px){.categories{max-width:260px;} .contact-buttons{max-width:260px;}} /* =================================== STANDARD MOBILE (414px - 479px) iPhone Plus,standard Android =================================== */ @media (min-width:414px) and (max-width:479px){.blue-header{padding:var(--spacing-sm) var(--spacing-md);} .categories{max-width:300px;gap:10px;} .category-btn{min-height:62px;} .contact-buttons{max-width:300px;gap:10px;}} /* =================================== LARGE MOBILE (480px - 639px) Phablets,small tablets in portrait =================================== */ @media (min-width:480px) and (max-width:639px){.blue-header{min-height:320px;max-height:380px;padding:var(--spacing-md);} .logo-text{font-size:var(--font-size-2xl);} .main-heading{font-size:var(--font-size-lg);} .categories{max-width:340px;gap:var(--spacing-sm);} .category-btn{min-height:68px;} .category-icon{font-size:var(--font-size-xl);} .category-name{font-size:var(--font-size-sm);} .contact-buttons{max-width:340px;} .contact-btn{min-height:48px;} .white-content{padding:var(--spacing-md) var(--spacing-lg);} .gallery-grid{grid-template-columns:repeat(2,1fr);}} /* =================================== SMALL TABLET (640px - 767px) Transition zone before tablet layout =================================== */ @media (min-width:640px) and (max-width:767px){.blue-header{height:38vh;min-height:300px;max-height:360px;padding:var(--spacing-md) var(--spacing-lg);} .white-content{margin-top:38vh;min-height:62vh;padding:var(--spacing-lg) var(--spacing-xl);} .logo-text{font-size:var(--font-size-2xl);} .main-heading{font-size:var(--font-size-xl);} .categories{max-width:380px;gap:var(--spacing-sm);} .category-btn{min-height:72px;padding:var(--spacing-sm);} .category-icon{font-size:var(--font-size-xl);} .category-name{font-size:var(--font-size-sm);} .contact-buttons{max-width:380px;gap:var(--spacing-sm);} .contact-btn{min-height:52px;} .content-container{max-width:600px;} .trust-badges{flex-direction:row;flex-wrap:wrap;justify-content:center;} .badge{width:auto;}} /* =================================== LANDSCAPE MOBILE ORIENTATION =================================== */ @media (max-width:767px) and (orientation:landscape) and (max-height:500px){.blue-header{height:auto;min-height:auto;max-height:none;position:relative;padding:var(--spacing-sm) var(--spacing-md);} .white-content{margin-top:0;min-height:auto;} .logo{margin-bottom:var(--spacing-xs);} .main-heading{margin-bottom:var(--spacing-xs);} .categories{margin-bottom:var(--spacing-xs);} .category-btn{min-height:48px;} .contact-buttons{margin-bottom:0;} .burger-menu{top:var(--spacing-xs);right:var(--spacing-sm);}} /* =================================== TOUCH DEVICE OPTIMIZATIONS Ensure 44x44px minimum touch targets =================================== */ @media (pointer:coarse){.burger-menu,.menu-close,.category-btn,.contact-btn,.menu-item{min-height:44px;min-width:44px;} .category-btn:hover:not(:disabled){transform:none;box-shadow:none;} .category-btn:active:not(:disabled){transform:scale(0.97);background:rgba(255,255,255,0.25);} .contact-btn:hover{transform:none;} .contact-btn:active{transform:scale(0.97);}} /* =================================== SAFE AREA INSETS (Notched Devices) =================================== */ @supports (padding-top:env(safe-area-inset-top)){.blue-header{padding-top:max(var(--spacing-sm),env(safe-area-inset-top));padding-left:max(var(--spacing-md),env(safe-area-inset-left));padding-right:max(var(--spacing-md),env(safe-area-inset-right));} .burger-menu{top:max(var(--spacing-sm),env(safe-area-inset-top));right:max(var(--spacing-sm),env(safe-area-inset-right));} .white-content{padding-left:max(var(--spacing-md),env(safe-area-inset-left));padding-right:max(var(--spacing-md),env(safe-area-inset-right));padding-bottom:max(var(--spacing-xl),calc(env(safe-area-inset-bottom) + var(--spacing-md)));} .menu-sidebar{padding-top:max(var(--spacing-xl),calc(env(safe-area-inset-top) + var(--spacing-md)));padding-bottom:max(var(--spacing-lg),env(safe-area-inset-bottom));}} /* =================================== HIGH DPI / RETINA DISPLAYS =================================== */ @media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.burger-line{height:2.5px;}} /* =================================== REDUCED MOTION =================================== */ @media (prefers-reduced-motion:reduce){.category-btn,.contact-btn,.menu-sidebar,.menu-item,.page-section{transition:none;} .menu-sidebar.active .menu-items li{transition:none;transition-delay:0s;}} /** * FixFiks - Desktop & Tablet Styles * Responsive breakpoints for tablet (768px+) and desktop (1024px+) * Horizontal layout:sidebar left,content right */ /* =================================== TABLET LAYOUT (768px - 1023px) 40% sidebar / 60% content =================================== */ @media (min-width:768px){.app-container{flex-direction:row;min-height:100vh;} .blue-header{width:40%;height:100vh;min-height:auto;max-height:none;position:fixed;top:0;left:0;padding:var(--spacing-lg);justify-content:center;gap:var(--spacing-md);transform:translateZ(0);} .white-content{margin-top:0;margin-left:40%;width:60%;height:100vh;min-height:100vh;padding:var(--spacing-xl);overflow-y:auto;transform:translateZ(0);} .logo{margin-bottom:var(--spacing-md);} .logo-icon{font-size:var(--font-size-2xl);} .logo-text{font-size:var(--font-size-2xl);} .main-heading{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);} .categories{grid-template-columns:1fr;max-width:220px;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);} .category-btn{flex-direction:row;justify-content:flex-start;gap:var(--spacing-sm);min-height:48px;padding:var(--spacing-sm) var(--spacing-md);} .category-icon{margin-bottom:0;font-size:var(--font-size-lg);} .category-name{font-size:var(--font-size-sm);} .coming-soon-badge{top:auto;right:var(--spacing-sm);font-size:9px;} .contact-buttons{flex-direction:column;max-width:220px;gap:var(--spacing-sm);margin-bottom:60px;} .contact-btn{flex-direction:row;justify-content:center;gap:var(--spacing-sm);min-height:44px;padding:var(--spacing-sm) var(--spacing-md);} .contact-icon{font-size:var(--font-size-lg);} .contact-text{font-size:var(--font-size-sm);margin-top:0;} .instagram-link.desktop-only{display:flex !important;position:absolute;bottom:var(--spacing-md);left:50%;transform:translateX(-50%);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm);white-space:nowrap;} .instagram-link.mobile-only{display:none !important;} .burger-menu{width:40px;height:40px;top:var(--spacing-md);right:var(--spacing-md);} .burger-line{width:20px;} .menu-sidebar{width:320px;max-width:320px;padding:var(--spacing-xl) var(--spacing-lg);} .section-title{font-size:var(--font-size-2xl);} .section-intro{font-size:var(--font-size-lg);} .content-container{max-width:600px;} .gallery-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);} .trust-badges{flex-direction:row;flex-wrap:wrap;} .badge{width:auto;} .service-group h3{flex-direction:row;align-items:center;} .price-table{display:table;font-size:var(--font-size-base);} .desktop-only{display:flex !important;} .mobile-only{display:none !important;}} /* =================================== WIDE TABLET (900px - 1023px) Transition between tablet and desktop =================================== */ @media (min-width:900px) and (max-width:1023px){.blue-header{padding:var(--spacing-lg) var(--spacing-xl);} .categories{grid-template-columns:repeat(2,1fr);max-width:280px;} .category-btn{flex-direction:column;justify-content:center;min-height:65px;padding:var(--spacing-sm);} .category-icon{margin-bottom:var(--spacing-xs);} .coming-soon-badge{top:-2px;right:-2px;} .contact-buttons{max-width:280px;margin-bottom:55px;} .white-content{padding:var(--spacing-xl) var(--spacing-2xl);}} /* =================================== DESKTOP LAYOUT (1024px - 1279px) 35% sidebar / 65% content =================================== */ @media (min-width:1024px){.blue-header{width:35%;padding:var(--spacing-xl);gap:var(--spacing-lg);} .white-content{margin-left:35%;width:65%;height:100vh;padding:var(--spacing-2xl);} .logo-icon{font-size:var(--font-size-3xl);} .logo-text{font-size:var(--font-size-3xl);} .main-heading{font-size:var(--font-size-xl);margin-bottom:var(--spacing-lg);} .categories{grid-template-columns:repeat(2,1fr);max-width:320px;gap:var(--spacing-md);} .category-btn{flex-direction:column;justify-content:center;min-height:80px;padding:var(--spacing-md);} .category-icon{font-size:var(--font-size-xl);margin-bottom:var(--spacing-xs);} .category-name{font-size:var(--font-size-base);} .coming-soon-badge{font-size:10px;padding:2px 6px;} .contact-buttons{flex-direction:column;max-width:320px;gap:var(--spacing-sm);margin-bottom:50px;} .contact-btn{min-height:50px;padding:var(--spacing-md);} .contact-icon{font-size:var(--font-size-xl);} .contact-text{font-size:var(--font-size-base);} .menu-sidebar{width:380px;max-width:380px;padding:var(--spacing-2xl);} .menu-item{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg);} .menu-icon{font-size:var(--font-size-2xl);} .category-btn:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,0.2);} .contact-btn:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.25);} .menu-item:hover{transform:translateX(8px);} .content-container{max-width:700px;} .gallery-grid{grid-template-columns:repeat(3,1fr);} .section-title{font-size:1.75rem;} .service-group{padding:var(--spacing-xl);} .price-table th,.price-table td{padding:var(--spacing-md) var(--spacing-lg);}} /* =================================== LARGE DESKTOP (1280px - 1439px) =================================== */ @media (min-width:1280px){.blue-header{padding:var(--spacing-xl) var(--spacing-2xl);} .white-content{padding:var(--spacing-2xl) 4rem;} .logo-text{font-size:2rem;} .main-heading{font-size:var(--font-size-2xl);} .categories{max-width:360px;} .category-btn{min-height:90px;} .contact-buttons{max-width:360px;} .content-container{max-width:800px;}} /* =================================== EXTRA LARGE DESKTOP (1440px - 1919px) =================================== */ @media (min-width:1440px){.blue-header{padding:var(--spacing-2xl) 3rem;} .white-content{padding:3rem 5rem;} .logo-text{font-size:2.25rem;} .categories{max-width:400px;gap:var(--spacing-md);} .category-btn{min-height:100px;} .category-icon{font-size:var(--font-size-2xl);} .contact-buttons{max-width:400px;} .contact-btn{min-height:56px;} .menu-sidebar{width:420px;max-width:420px;} .content-container{max-width:850px;} .section-title{font-size:2rem;} .section-intro{font-size:var(--font-size-xl);}} /* =================================== ULTRA WIDE DESKTOP (1920px+) =================================== */ @media (min-width:1920px){.blue-header{width:30%;padding:3rem 4rem;} .white-content{margin-left:30%;width:70%;height:100vh;padding:4rem 6rem;} .logo-text{font-size:2.5rem;} .main-heading{font-size:1.75rem;} .categories{max-width:440px;} .category-btn{min-height:110px;} .contact-buttons{max-width:440px;} .content-container{max-width:1000px;} .gallery-grid{grid-template-columns:repeat(4,1fr);}} /* =================================== ULTRA ULTRA WIDE (2560px+) 4K monitors =================================== */ @media (min-width:2560px){.blue-header{width:25%;} .white-content{margin-left:25%;width:75%;height:100vh;padding:5rem 8rem;} .content-container{max-width:1200px;}} /* =================================== HIGH RESOLUTION SCREENS =================================== */ @media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.category-btn,.contact-btn,.badge,.cert-card,.service-group,.menu-sidebar{box-shadow:0 1px 3px rgba(0,0,0,0.08);} body{-webkit-font-smoothing:subpixel-antialiased;}} /* =================================== DESKTOP HOVER STATES Only apply on devices with fine pointer (mouse) =================================== */ @media (hover:hover) and (pointer:fine){.category-btn{cursor:pointer;} .category-btn:hover:not(:disabled) .category-icon{transform:scale(1.15);} .contact-btn::before{content:"";} .menu-item{cursor:pointer;} .gallery-item:hover img{transform:scale(1.08);} .price-table tbody tr{cursor:default;transition:background var(--transition-fast);} .price-table tbody tr:hover{background:var(--color-gray-100);} .badge{transition:transform var(--transition-fast),box-shadow var(--transition-fast);} .badge:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}} /* =================================== REDUCED MOTION PREFERENCE =================================== */ @media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;} .page-section{animation:none;} .menu-sidebar.active .menu-items li{opacity:1;transform:none;transition:none;} .contact-btn::before{display:none;}} /* =================================== PRINT STYLES OVERRIDE =================================== */ @media print{.app-container{flex-direction:column;} .blue-header{width:100%;height:auto;position:relative;background:none !important;color:#000;padding:1rem;print-color-adjust:exact;-webkit-print-color-adjust:exact;} .white-content{margin-left:0;width:100%;padding:1rem;} .burger-menu,.menu-sidebar,.menu-overlay,.contact-buttons,.instagram-link{display:none !important;} .categories{display:none;} .content-container{max-width:100%;} a{color:#000;text-decoration:underline;} .service-group,.cert-card,.badge{break-inside:avoid;page-break-inside:avoid;}} /* =================================== LANDSCAPE TABLET ORIENTATION =================================== */ @media (min-width:768px) and (max-width:1023px) and (orientation:landscape){.blue-header{width:35%;} .white-content{margin-left:35%;width:65%;height:100vh;} .categories{grid-template-columns:repeat(2,1fr);max-width:260px;} .category-btn{flex-direction:column;min-height:60px;}} 