/* Theme Name:Corr Brothers Theme URI:https://corrbrothers.co.uk Author:SimonTodd Digital Author URI:https://simontodd.co.uk Description:Professional WordPress theme for Corr Brothers Ltd - DVA Approved Tachograph Centre. Mobile-first, SEO optimised, accessible. Version:1.8.3 License:GNU General Public License v2 or later License URI:http://www.gnu.org/licenses/gpl-2.0.html Text Domain:corr-brothers Tags:commercial-vehicles, tachograph, business, mobile-first Corr Brothers Ltd - DVA Approved Tachograph Centre Est. 1976 | 101 Ballyards Road, Armagh, BT60 3NS === Lighthouse 100 Optimisation Notes === - All images should use WebP/AVIF via WordPress media library - Hero images must have fetchpriority="high" and explicit dimensions - Critical CSS inlined, main CSS deferred - JavaScript deferred, no forced reflows - WCAG 2.1 AA contrast ratios throughout */ /* ========================================================================== CSS Custom Properties ========================================================================== */ /* Font fallback with size-adjust to prevent CLS */ @font-face{font-family:'Plus Jakarta Sans Fallback';src:local('Arial');ascent-override:95%;descent-override:25%;line-gap-override:0%;size-adjust:104%}:root{/* Primary Red Palette - Based on Corr Brothers Logo #cd2027 */ --color-primary-50:#fef2f2;--color-primary-100:#fee2e2;--color-primary-200:#fecaca;--color-primary-300:#fca5a5;--color-primary-400:#f87171;--color-primary-500:#ef4444;--color-primary-600:#cd2027;--color-primary-700:#cd2027;--color-primary-800:#b01c22;--color-primary-900:#8b161b;--color-primary-950:#450a0a;/* Grey from logo #989898 */ --color-grey-logo:#989898;/* Neutral Palette */ --color-neutral-50:#fafafa;--color-neutral-100:#f5f5f5;--color-neutral-200:#e5e5e5;--color-neutral-300:#d4d4d4;--color-neutral-400:#a3a3a3;--color-neutral-500:#737373;--color-neutral-600:#525252;--color-neutral-700:#404040;--color-neutral-800:#262626;--color-neutral-900:#171717;--color-neutral-950:#0a0a0a;/* Semantic Colors */ --color-success:#16a34a;--color-warning:#ca8a04;--color-error:#dc2626;--color-info:#0284c7;/* Primary Theme Colors */ --color-primary:#cd2027;--color-primary-hover:#b01c22;--color-primary-light:var(--color-primary-100);--color-text:var(--color-neutral-800);--color-text-light:var(--color-neutral-600);--color-text-muted:var(--color-neutral-600);--color-bg:#ffffff;--color-bg-alt:var(--color-neutral-50);--color-bg-dark:var(--color-neutral-900);--color-border:var(--color-neutral-200);--color-border-light:var(--color-neutral-100);/* Typography - with fallback that matches Plus Jakarta Sans metrics */ --font-primary:'Plus Jakarta Sans', 'Plus Jakarta Sans Fallback', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;--font-display:'Plus Jakarta Sans', 'Plus Jakarta Sans Fallback', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;/* Font Sizes - Mobile First */ --text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;/* Font Weights */ --font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--font-extrabold:800;/* Line Heights */ --leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;/* Spacing */ --space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;/* Border Radius */ --radius-sm:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--radius-full:9999px;/* Shadows */ --shadow-sm:0 1px 2px 0 rgb(0 0 0 / 0.05);--shadow-md:0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);--shadow-lg:0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--shadow-xl:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);--shadow-2xl:0 25px 50px -12px rgb(0 0 0 / 0.25);/* Transitions */ --transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease;/* Container */ --container-max:1280px;--container-narrow:720px;--container-wide:1440px;/* Header */ --header-height:70px;--header-height-scrolled:60px;/* Brand Logo Icon SVG - The distinctive arc from the logo */ --logo-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-10 280 280 180'%3E%3Cpath fill='%23cd2027' d='M124.71,290.71c-72.35,0-131,58.65-131,131,0,67.95,51.74,123.81,117.97,130.36-57.48-10.8-100.97-61.24-100.97-121.86,0-68.48,55.52-124,124-124,14.68,0,28.76,2.57,41.83,7.25l4.63-9.98c-17.1-8.18-36.24-12.77-56.46-12.77Z'/%3E%3Cpath fill='%23989898' d='M251.28,387.85c-9.95-37.28-35.93-68.01-70.11-84.37l-4.63,9.98c34.65,12.42,62.17,39.81,74.74,74.39Z'/%3E%3Cpath fill='%23989898' d='M170.71,339.42l-57.18,93.27h0c-.16.25-.31.51-.43.78-.25.6-.39,1.26-.39,1.95,0,2.76,2.24,5,5,5,1.88,0,3.5-1.05,4.35-2.59h.02s48.63-98.41,48.63-98.41Z'/%3E%3C/svg%3E");--logo-icon-light:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-10 280 280 180'%3E%3Cpath fill='%23cd2027' opacity='0.5' d='M124.71,290.71c-72.35,0-131,58.65-131,131,0,67.95,51.74,123.81,117.97,130.36-57.48-10.8-100.97-61.24-100.97-121.86,0-68.48,55.52-124,124-124,14.68,0,28.76,2.57,41.83,7.25l4.63-9.98c-17.1-8.18-36.24-12.77-56.46-12.77Z'/%3E%3Cpath fill='%23989898' opacity='0.5' d='M251.28,387.85c-9.95-37.28-35.93-68.01-70.11-84.37l-4.63,9.98c34.65,12.42,62.17,39.81,74.74,74.39Z'/%3E%3Cpath fill='%23989898' opacity='0.5' d='M170.71,339.42l-57.18,93.27h0c-.16.25-.31.51-.43.78-.25.6-.39,1.26-.39,1.95,0,2.76,2.24,5,5,5,1.88,0,3.5-1.05,4.35-2.59h.02s48.63-98.41,48.63-98.41Z'/%3E%3C/svg%3E")}/* ========================================================================== Custom Design Elements - Corr Brothers Brand Motifs ========================================================================== */ /* Brand Arc Icon */ .brand-icon{display:inline-block;width:48px;height:48px;background-image:var(--logo-icon);background-size:contain;background-repeat:no-repeat;background-position:center}.brand-icon--sm{width:32px;height:32px}.brand-icon--lg{width:64px;height:64px}.brand-icon--xl{width:96px;height:96px}/* Section Header with Logo Icon */ .section-header--branded::before{content:'';display:block;width:48px;height:48px;margin:0 auto var(--space-4);background-image:var(--logo-icon);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:0.25}/* Accent Line - Animated gradient */ .accent-line{height:4px;background:linear-gradient(90deg, var(--color-primary) 0%, var(--color-grey-logo) 50%, var(--color-primary) 100%);background-size:200% 100%;border-radius:var(--radius-full)}.accent-line--animated{animation:accent-shimmer 3s ease infinite}@keyframes accent-shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}/* Arc Corner Decoration - simplified */ .arc-corner{position:relative}/* Decorative Divider with Logo Icon */ .divider-brand{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin:var(--space-8) 0}.divider-brand::before, .divider-brand::after{content:'';flex:1;height:1px;background:linear-gradient(90deg, transparent, var(--color-border), transparent)}.divider-brand__icon{width:40px;height:40px;background-image:var(--logo-icon);background-size:contain;background-repeat:no-repeat;opacity:0.25}/* Card with Arc Hover Effect */ .card-arc-hover{position:relative;overflow:hidden;transition:transform var(--transition-base), box-shadow var(--transition-base)}.card-arc-hover::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg, var(--color-primary), var(--color-grey-logo));transform:scaleX(0);transform-origin:left;transition:transform var(--transition-slow)}.card-arc-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-arc-hover:hover::after{transform:scaleX(1)}/* Stat Card - Clean style */ .stat-card-arc{position:relative;padding:var(--space-6);background:#fff;border-radius:var(--radius-xl);overflow:hidden}/* Badge with Brand Icon */ .badge-arc{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg, var(--color-primary-50), #fff);border:1px solid var(--color-primary-100);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-primary-700)}.badge-arc::before{content:'';width:20px;height:20px;background-image:var(--logo-icon);background-size:contain;background-repeat:no-repeat}/* Floating Animation */ @keyframes float-arc{0%, 100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(3deg)}}.arc-float{animation:float-arc 4s ease-in-out infinite}/* Feature Box with Gradient Border */ .feature-box-gradient{position:relative;padding:var(--space-6);background:#fff;border-radius:var(--radius-xl)}.feature-box-gradient::before{content:'';position:absolute;inset:0;border-radius:var(--radius-xl);padding:2px;background:linear-gradient(135deg, var(--color-primary), var(--color-grey-logo), var(--color-primary));-webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}/* Number with styled background */ .number-arc{position:relative;display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-primary);background:var(--color-primary-50);border-radius:var(--radius-full)}/* Quote with Arc Decoration */ .quote-arc{position:relative;padding-left:var(--space-6)}.quote-arc::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg, var(--color-primary), var(--color-grey-logo));border-radius:var(--radius-full)}/* Icon Circle with Arc */ .icon-arc{position:relative;display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-primary-50);border-radius:var(--radius-full);color:var(--color-primary)}.icon-arc::after{content:'';position:absolute;inset:-4px;border:2px dashed var(--color-primary-200);border-radius:var(--radius-full);animation:spin-slow 20s linear infinite}@keyframes spin-slow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}/* CTA Box - Dark with subtle accent */ .cta-arc{position:relative;padding:var(--space-8);background:linear-gradient(135deg, var(--color-neutral-900), var(--color-neutral-800));border-radius:var(--radius-2xl);overflow:hidden}.cta-arc::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg, var(--color-primary), var(--color-grey-logo), var(--color-primary))}/* Process Steps */ .process-steps{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:var(--space-6);max-width:1000px;margin:0 auto}.process-step{text-align:center;padding:var(--space-8) var(--space-6);background:#fff;border-radius:var(--radius-xl);position:relative}.process-step .number-arc{margin:0 auto var(--space-4)}.process-step__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-neutral-900);margin-bottom:var(--space-3)}.process-step__text{font-size:var(--text-sm);color:var(--color-text-light);line-height:var(--leading-relaxed);margin:0}/* Connector lines between steps (desktop) */ @media (min-width:768px){.process-steps{position:relative}.process-step:not(:last-child)::after{content:'';position:absolute;top:50%;right:-15%;width:30%;height:2px;background:linear-gradient(90deg, var(--color-primary), var(--color-grey-logo));transform:translateY(-50%);z-index:-1}}/* Stats Grid */ .stats-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:var(--space-6);max-width:900px;margin:0 auto}@media (min-width:768px){.stats-grid{grid-template-columns:repeat(4, 1fr)}}.stat-card-arc{text-align:center}.stat-card__value{font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:var(--color-primary);line-height:1;margin-bottom:var(--space-2)}.stat-card__value span{font-size:var(--text-2xl);opacity:0.7}.stat-card__label{font-size:var(--text-sm);color:var(--color-text-muted)}@media (min-width:768px){.stat-card__value{font-size:var(--text-5xl)}}/* ========================================================================== CSS Reset & Base ========================================================================== */ *, *::before, *::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + var(--space-4))}body{font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}/* Focus styles for accessibility */:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}/* Selection */::selection{background:var(--color-primary-200);color:var(--color-primary-900)}/* ========================================================================== Typography ========================================================================== */ h1, h2, h3, h4, h5, h6{font-family:var(--font-display);font-weight:var(--font-bold);line-height:var(--leading-tight);color:var(--color-neutral-900);text-wrap:balance}h1{font-size:var(--text-3xl);font-weight:var(--font-extrabold);letter-spacing:-0.02em}h2{font-size:var(--text-2xl);font-weight:var(--font-bold);letter-spacing:-0.01em}h3{font-size:var(--text-xl);font-weight:var(--font-semibold)}h4{font-size:var(--text-lg);font-weight:var(--font-semibold)}h5{font-size:var(--text-base);font-weight:var(--font-semibold)}h6{font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:0.05em}p{margin-bottom:var(--space-4);text-wrap:pretty}p:last-child{margin-bottom:0}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}strong, b{font-weight:var(--font-semibold)}small{font-size:var(--text-sm)}/* Lists */ ul, ol{margin-bottom:var(--space-4);padding-left:var(--space-6)}li{margin-bottom:var(--space-2)}/* ========================================================================== Media Elements ========================================================================== */ img, video, svg{max-width:100%;height:auto;display:block}img{font-style:italic;background-repeat:no-repeat;background-size:cover;shape-margin:0.75rem}figure{margin:var(--space-6) 0}figcaption{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2)}/* ========================================================================== Layout Components ========================================================================== */ .container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--space-4)}.container--narrow{max-width:var(--container-narrow)}.container--wide{max-width:var(--container-wide)}@media (min-width:640px){.container{padding:0 var(--space-6)}}@media (min-width:1024px){.container{padding:0 var(--space-8)}}/* Section spacing */ .section{padding:var(--space-12) 0}.section--sm{padding:var(--space-8) 0}.section--lg{padding:var(--space-16) 0}.section--alt{background-color:var(--color-bg-alt)}.section--dark{background-color:var(--color-bg-dark);color:var(--color-neutral-100)}.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4{color:#ffffff}.section--primary{background-color:var(--color-primary);color:#ffffff}.section--primary h1, .section--primary h2, .section--primary h3, .section--primary h4{color:#ffffff}@media (min-width:768px){.section{padding:var(--space-16) 0}.section--sm{padding:var(--space-12) 0}.section--lg{padding:var(--space-24) 0}}@media (min-width:1024px){h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}}/* ========================================================================== Header & Navigation ========================================================================== */ .site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#ffffff;border-bottom:1px solid var(--color-border);transition:all var(--transition-base)}.site-header.scrolled{box-shadow:var(--shadow-md)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);gap:var(--space-4)}/* Logo */ .site-logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;flex-shrink:0;padding:var(--space-2) 0}.site-logo img, .site-logo-img{height:44px;width:auto;max-width:170px;object-fit:contain;object-position:left center}@media (min-width:768px){.site-logo img, .site-logo-img{height:55px}}.site-logo-text{display:flex;flex-direction:column;line-height:var(--leading-tight)}.site-logo-name{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-neutral-900);letter-spacing:-0.01em}.site-logo-tagline{font-size:var(--text-xs);color:var(--color-primary);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:0.05em}/* Desktop Navigation */ .main-nav{display:none}.nav-menu{display:flex;align-items:center;gap:var(--space-1);list-style:none;margin:0;padding:0}.nav-menu li{margin:0;position:relative}.nav-menu a{display:block;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-neutral-700);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-menu a:hover, .nav-menu .current-menu-item > a, .nav-menu .current_page_item > a{color:var(--color-primary);background-color:var(--color-primary-50)}/* Dropdown menus */ .nav-menu .sub-menu{position:absolute;top:100%;left:0;min-width:220px;background:#ffffff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);padding:var(--space-2);opacity:0;visibility:hidden;transform:translateY(10px);transition:all var(--transition-base);z-index:100;list-style:none;margin:0}.nav-menu li:hover > .sub-menu, .nav-menu li.focus-within > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}.nav-menu .sub-menu li{margin:0}.nav-menu .sub-menu a{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);white-space:nowrap}/* Header Actions */ .header-actions{display:flex;align-items:center;gap:var(--space-3)}.header-phone{display:none;align-items:center;gap:var(--space-2);font-weight:var(--font-semibold);color:var(--color-neutral-900);text-decoration:none}.header-phone svg{color:var(--color-primary)}.header-phone:hover{color:var(--color-primary)}/* Mobile Menu Toggle */ .mobile-menu-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:none;border:none;cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.mobile-menu-toggle:hover{background-color:var(--color-neutral-100)}.mobile-menu-toggle svg{width:24px;height:24px;color:var(--color-neutral-700)}.mobile-menu-toggle .icon-close{display:none}.mobile-menu-toggle.active .icon-menu{display:none}.mobile-menu-toggle.active .icon-close{display:block}/* Mobile Navigation */ .mobile-nav{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:#ffffff;z-index:999;overflow-y:auto;transform:translateX(100%);transition:transform var(--transition-slow);padding:var(--space-4)}.mobile-nav.active{transform:translateX(0)}.mobile-nav-header{padding-bottom:var(--space-4);margin-bottom:var(--space-4);border-bottom:1px solid var(--color-border-light)}.mobile-nav-logo{display:inline-block}.mobile-nav-logo img{height:45px;width:auto;max-width:150px;object-fit:contain}.mobile-nav-menu{list-style:none;margin:0;padding:0}.mobile-nav-menu li{margin:0;border-bottom:1px solid var(--color-border-light)}.mobile-nav-menu a{display:block;padding:var(--space-4);font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--color-neutral-800);text-decoration:none;transition:all var(--transition-fast)}.mobile-nav-menu a:hover, .mobile-nav-menu .current-menu-item > a{color:var(--color-primary);background-color:var(--color-primary-50)}.mobile-nav-menu .sub-menu{list-style:none;padding-left:var(--space-4);background:var(--color-neutral-50)}.mobile-nav-menu .sub-menu a{font-size:var(--text-base);padding:var(--space-3) var(--space-4)}.mobile-nav-cta{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.mobile-nav-phone{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-neutral-900);text-decoration:none;background:var(--color-neutral-50);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.mobile-nav-phone svg{width:24px;height:24px;color:var(--color-primary)}/* Desktop breakpoint */ @media (min-width:1024px){.main-nav{display:block}.mobile-menu-toggle{display:none}.mobile-nav{display:none}.header-phone{display:flex}}/* ========================================================================== Buttons ========================================================================== */ .btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);line-height:var(--leading-tight);text-decoration:none;text-align:center;border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn svg{width:18px;height:18px;flex-shrink:0}/* Primary Button */ .btn--primary{background-color:var(--color-primary);color:#ffffff;border-color:var(--color-primary)}.btn--primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#ffffff}/* Secondary Button */ .btn--secondary{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn--secondary:hover{background-color:var(--color-primary);color:#ffffff}/* White Button */ .btn--white{background-color:#ffffff;color:var(--color-primary);border-color:#ffffff}.btn--white:hover{background-color:var(--color-neutral-100);border-color:var(--color-neutral-100);color:var(--color-primary-hover)}/* Ghost Button */ .btn--ghost{background-color:transparent;color:var(--color-neutral-700);border-color:var(--color-border)}.btn--ghost:hover{background-color:var(--color-neutral-100);border-color:var(--color-neutral-300);color:var(--color-neutral-900)}/* Dark Button */ .btn--dark{background-color:var(--color-neutral-900);color:#ffffff;border-color:var(--color-neutral-900)}.btn--dark:hover{background-color:var(--color-neutral-800);border-color:var(--color-neutral-800);color:#ffffff}/* Button Sizes */ .btn--sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.btn--lg{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.btn--xl{padding:var(--space-5) var(--space-8);font-size:var(--text-lg)}/* Full Width */ .btn--block{width:100%}/* ========================================================================== Hero Section ========================================================================== */ .hero{position:relative;padding:calc(var(--header-height) + var(--space-12)) 0 var(--space-12);background-color:var(--hero-bg-color, var(--color-neutral-900));background-image:var(--hero-bg-image, none);background-size:cover;background-position:center;background-repeat:no-repeat;color:#ffffff;overflow:hidden}/* Hero overlay for background images */ .hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-color:var(--hero-overlay-color, rgba(23, 23, 23, 0.85));pointer-events:none}/* Optional texture overlay */ .hero::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" x="0" y="0" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" fill-opacity="0.02"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');pointer-events:none;opacity:0.5}.hero__inner{position:relative;z-index:1;text-align:center}.hero__content{max-width:800px;margin:0 auto}.hero__badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--space-6);backdrop-filter:blur(10px)}.hero__badge svg{width:16px;height:16px;color:var(--color-primary)}.hero__title{font-size:var(--text-4xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight);margin-bottom:var(--space-6);color:#ffffff}.hero__title span{color:var(--color-primary)}.hero__text{font-size:var(--text-lg);color:var(--color-neutral-300);margin-bottom:var(--space-8);max-width:650px;margin-left:auto;margin-right:auto}.hero__buttons{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}.hero__stats{display:grid;grid-template-columns:repeat(2, 1fr);gap:var(--space-4);margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid rgba(255,255,255,0.1);max-width:900px;margin-left:auto;margin-right:auto}.hero__stat{text-align:center}.hero__stat-value{font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:#ffffff;line-height:var(--leading-none);margin-bottom:var(--space-1)}.hero__stat-value span{color:var(--color-primary)}.hero__stat-label{font-size:var(--text-sm);color:var(--color-neutral-400)}@media (min-width:640px){.hero__stats{grid-template-columns:repeat(4, 1fr)}}@media (min-width:768px){.hero{padding:calc(var(--header-height) + var(--space-16)) 0 var(--space-16)}.hero__title{font-size:var(--text-5xl)}}@media (min-width:1024px){.hero{padding:calc(var(--header-height) + var(--space-20)) 0 var(--space-20)}.hero__title{font-size:var(--text-6xl)}.hero__stat{text-align:center}}/* Hero Slider */ .hero-slider{position:relative}.hero-slider__track{position:relative;min-height:320px}.hero-slide{position:absolute;top:0;left:0;width:100%;opacity:0;visibility:hidden;transition:opacity 0.6s ease, visibility 0.6s ease, transform 0.6s ease;transform:translateY(20px)}.hero-slide--active{position:relative;opacity:1;visibility:visible;transform:translateY(0)}/* Slide content animations */ .hero-slide .hero__badge, .hero-slide .hero__title, .hero-slide .hero__text, .hero-slide .hero__buttons{opacity:0;transform:translateY(20px);transition:opacity 0.5s ease, transform 0.5s ease}.hero-slide--active .hero__badge{opacity:1;transform:translateY(0);transition-delay:0.1s}.hero-slide--active .hero__title{opacity:1;transform:translateY(0);transition-delay:0.2s}.hero-slide--active .hero__text{opacity:1;transform:translateY(0);transition-delay:0.3s}.hero-slide--active .hero__buttons{opacity:1;transform:translateY(0);transition-delay:0.4s}/* Slider Dots */ .hero-slider__dots{display:flex;justify-content:center;gap:var(--space-2);margin-top:var(--space-8)}.hero-slider__dot{position:relative;width:40px;height:4px;background:rgba(255,255,255,0.3);border:none;border-radius:2px;cursor:pointer;overflow:hidden;transition:background 0.3s ease;padding:0}.hero-slider__dot:hover{background:rgba(255,255,255,0.5)}.hero-slider__dot--active{background:rgba(255,255,255,0.3)}.hero-slider__dot-progress{position:absolute;top:0;left:0;height:100%;width:100%;background:var(--color-primary);border-radius:2px;transform:scaleX(0);transform-origin:left center;will-change:transform}.hero-slider__dot--active .hero-slider__dot-progress{animation:sliderProgress 6s linear forwards}@keyframes sliderProgress{from{transform:scaleX(0)}to{transform:scaleX(1)}}/* Slider Arrows */ .hero-slider__arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:50%;color:#ffffff;cursor:pointer;transition:all 0.3s ease;z-index:10;backdrop-filter:blur(10px);opacity:0;visibility:hidden}.hero-slider:hover .hero-slider__arrow{opacity:1;visibility:visible}.hero-slider__arrow:hover{background:var(--color-primary);border-color:var(--color-primary);transform:translateY(-50%) scale(1.1)}.hero-slider__arrow--prev{left:-60px}.hero-slider__arrow--next{right:-60px}.hero-slider__arrow svg{width:24px;height:24px}/* Mobile adjustments */ @media (max-width:1200px){.hero-slider__arrow--prev{left:0}.hero-slider__arrow--next{right:0}.hero-slider__arrow{opacity:0.7;visibility:visible}}@media (max-width:640px){.hero-slider__track{min-height:380px}.hero-slider__arrow{width:36px;height:36px}.hero-slider__arrow svg{width:20px;height:20px}.hero-slider__dot{width:30px}}/* ========================================================================== Services Grid ========================================================================== */ .services-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}.service-card{position:relative;padding:var(--space-6);background:#ffffff;border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base)}.service-card:hover{border-color:var(--color-primary-200);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.service-card__icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-primary-50);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.service-card__icon svg{width:28px;height:28px;color:var(--color-primary)}.service-card__title{font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--space-3)}.service-card__text{color:var(--color-text-light);margin-bottom:var(--space-4);font-size:var(--text-sm)}.service-card__link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary)}.service-card__link svg{width:16px;height:16px;transition:transform var(--transition-fast)}.service-card:hover .service-card__link svg{transform:translateX(4px)}/* Featured service card */ .service-card--featured{background:linear-gradient(135deg, var(--color-primary-700) 0%, var(--color-primary-800) 100%);border-color:transparent;color:#ffffff}.service-card--featured .service-card__icon{background:rgba(255,255,255,0.2)}.service-card--featured .service-card__icon svg{color:#ffffff}.service-card--featured .service-card__title{color:#ffffff}.service-card--featured .service-card__text{color:var(--color-primary-100)}.service-card--featured .service-card__link{color:#ffffff}.service-card--featured:hover{transform:translateY(-4px);box-shadow:var(--shadow-2xl)}/* Service Card Scroll Animations */ .service-card{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease, transform 0.6s ease, border-color 0.2s ease, box-shadow 0.2s ease}.service-card--visible{opacity:1;transform:translateY(0)}.service-card--featured{opacity:0;transform:translateY(30px)}.service-card--featured.service-card--visible{opacity:1;transform:translateY(0)}.service-card--featured:hover{transform:translateY(-4px)}@media (min-width:640px){.services-grid{grid-template-columns:repeat(2, 1fr)}}@media (min-width:1024px){.services-grid{grid-template-columns:repeat(3, 1fr)}}/* ========================================================================== Section Headers ========================================================================== */ .section-header{max-width:700px;margin-bottom:var(--space-10);opacity:0;transform:translateY(20px);transition:opacity 0.6s ease, transform 0.6s ease}.section-header--visible{opacity:1;transform:translateY(0)}.section-header--center{text-align:center;margin-left:auto;margin-right:auto}.section-header__label{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:var(--space-3)}.section-header__title{margin-bottom:var(--space-4)}.section-header__text{font-size:var(--text-lg);color:var(--color-text-light)}.section--dark .section-header__text{color:var(--color-neutral-400)}@media (min-width:768px){.section-header{margin-bottom:var(--space-12)}}/* ========================================================================== Trust Badges / Credentials ========================================================================== */ .trust-badges{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-6);padding:var(--space-8) 0}.trust-badge{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center}.trust-badge__icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-neutral-100);border-radius:var(--radius-lg)}.trust-badge__icon img{max-width:48px;max-height:48px}.trust-badge__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-light)}@media (min-width:768px){.trust-badges{gap:var(--space-10)}}/* ========================================================================== CTA Banner ========================================================================== */ .cta-banner{position:relative;padding:var(--space-10) var(--space-6);background:linear-gradient(135deg, var(--color-primary-700) 0%, var(--color-primary-900) 100%);border-radius:var(--radius-2xl);color:#ffffff;text-align:center;overflow:hidden}.cta-banner::before{content:'';position:absolute;top:-50%;right:-50%;width:100%;height:200%;background:radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 60%);pointer-events:none}.cta-banner__content{position:relative;z-index:1;max-width:600px;margin:0 auto}.cta-banner__title{font-size:var(--text-2xl);margin-bottom:var(--space-4);color:#ffffff}.cta-banner__text{font-size:var(--text-base);color:var(--color-primary-100);margin-bottom:var(--space-6)}.cta-banner__buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-3)}@media (min-width:768px){.cta-banner{padding:var(--space-16) var(--space-10)}.cta-banner__title{font-size:var(--text-4xl)}.cta-banner__text{font-size:var(--text-lg)}}/* ========================================================================== Features List ========================================================================== */ .features-list{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.feature-item{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--color-neutral-50);border-radius:var(--radius-lg)}.feature-item__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-primary);border-radius:var(--radius-md);flex-shrink:0}.feature-item__icon svg{width:20px;height:20px;color:#ffffff}.feature-item__content{flex:1}.feature-item__title{font-size:var(--text-base);font-weight:var(--font-semibold);margin-bottom:var(--space-1)}.feature-item__text{font-size:var(--text-sm);color:var(--color-text-light);margin:0}@media (min-width:768px){.features-list{grid-template-columns:repeat(2, 1fr)}}/* ========================================================================== Testimonials ========================================================================== */ .testimonials-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}/* Subtle Testimonial Grid */ .testimonials-grid--subtle{gap:var(--space-4)}.testimonial-card{padding:var(--space-6);background:#ffffff;border:1px solid var(--color-border);border-radius:var(--radius-xl)}/* Subtle Testimonial Card */ .testimonial-card--subtle{padding:var(--space-5);background:#ffffff;border:1px solid var(--color-border-light);border-radius:var(--radius-lg);transition:box-shadow var(--transition-fast), border-color var(--transition-fast)}.testimonial-card--subtle:hover{border-color:var(--color-border);box-shadow:var(--shadow-sm)}.testimonial-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.testimonial-card__stars{display:flex;gap:var(--space-1);margin-bottom:var(--space-4)}.testimonial-card__stars--small{gap:2px;margin-bottom:0}.testimonial-card__stars--small svg{width:14px;height:14px;color:#FBBC05}.testimonial-card__stars svg{width:20px;height:20px;color:var(--color-warning);fill:var(--color-warning)}.testimonial-card__google{opacity:0.5;transition:opacity var(--transition-fast)}.testimonial-card--subtle:hover .testimonial-card__google{opacity:0.8}.testimonial-card__text{font-size:var(--text-base);color:var(--color-text);margin-bottom:var(--space-4);font-style:italic}.testimonial-card__text--subtle{font-size:var(--text-sm);font-style:normal;color:var(--color-text-light);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.testimonial-card__author{display:flex;align-items:center;gap:var(--space-3)}.testimonial-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-3);border-top:1px solid var(--color-border-light)}.testimonial-card__avatar{width:48px;height:48px;background:var(--color-primary-100);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);color:var(--color-primary)}.testimonial-card__name{font-weight:var(--font-semibold);color:var(--color-neutral-900)}.testimonial-card__footer .testimonial-card__name{font-size:var(--text-sm);font-weight:var(--font-medium)}.testimonial-card__company{font-size:var(--text-sm);color:var(--color-text-muted)}.testimonial-card__time{font-size:var(--text-xs);color:var(--color-text-muted)}/* Testimonial Card Animations */ .testimonial-card{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease, transform 0.6s ease}.testimonial-card--visible{opacity:1;transform:translateY(0)}@media (min-width:768px){.testimonials-grid{grid-template-columns:repeat(2, 1fr)}}@media (min-width:1024px){.testimonials-grid{grid-template-columns:repeat(3, 1fr)}}/* Testimonial Card Enhancements */ .testimonial-card__avatar-img{width:48px;height:48px;border-radius:var(--radius-full);object-fit:cover}/* Reviews Summary - Compact Style */ .reviews-summary{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);margin-top:var(--space-4)}.reviews-summary--compact{flex-direction:row;justify-content:center;gap:var(--space-3);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:#ffffff;border-radius:var(--radius-lg);border:1px solid var(--color-border-light);display:inline-flex}.reviews-summary--compact .google-icon{flex-shrink:0}.reviews-summary__info{display:flex;align-items:center;gap:var(--space-2)}.reviews-summary__rating{display:flex;align-items:center;gap:var(--space-3)}.reviews-summary__score{font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:var(--color-neutral-900);line-height:1}.reviews-summary__stars{display:flex;gap:2px}.reviews-summary__stars svg{width:16px;height:16px;color:#FBBC05;fill:#FBBC05}.reviews-summary__text{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap}.reviews-summary__count{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}/* Reviews CTA */ .reviews-cta{text-align:center;margin-top:var(--space-8)}.reviews-cta__link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast)}.reviews-cta__link:hover{color:var(--color-neutral-900)}.reviews-cta__link svg{width:16px;height:16px}/* ========================================================================== Testimonials Carousel ========================================================================== */ .testimonials-carousel{position:relative;overflow:hidden;padding:0 var(--space-4)}.testimonials-carousel__track{display:flex;transition:transform 0.5s ease}.testimonials-carousel__slide{flex:0 0 100%;padding:0 var(--space-2)}@media (min-width:640px){.testimonials-carousel__slide{flex:0 0 50%}}@media (min-width:1024px){.testimonials-carousel__slide{flex:0 0 33.333%}}.testimonials-carousel__slide .testimonial-card{opacity:1;transform:none;height:100%}/* Carousel Navigation */ .testimonials-carousel__nav{display:flex;justify-content:center;align-items:center;gap:var(--space-4);margin-top:var(--space-6)}.testimonials-carousel__btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);color:var(--color-neutral-600)}.testimonials-carousel__btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.testimonials-carousel__btn:disabled{opacity:0.3;cursor:not-allowed}.testimonials-carousel__btn svg{width:20px;height:20px}/* Carousel Dots */ .testimonials-carousel__dots{display:flex;gap:var(--space-2)}.testimonials-carousel__dot{width:8px;height:8px;background:var(--color-neutral-300);border:none;border-radius:var(--radius-full);cursor:pointer;padding:0;transition:all var(--transition-fast)}.testimonials-carousel__dot:hover{background:var(--color-neutral-400)}.testimonials-carousel__dot--active{width:24px;background:var(--color-primary)}/* Auto-play indicator */ .testimonials-carousel__progress{position:absolute;bottom:0;left:0;height:3px;background:linear-gradient(90deg, var(--color-primary), var(--color-grey-logo));border-radius:var(--radius-full);animation:carousel-progress 5s linear infinite}@keyframes carousel-progress{0%{width:0%}100%{width:100%}}/* ========================================================================== Services Carousel (About Page) ========================================================================== */ .services-carousel{position:relative;overflow:hidden;padding:0 var(--space-4)}.services-carousel__track{display:flex;transition:transform 0.5s ease}.services-carousel__slide{flex:0 0 100%;padding:0 var(--space-2)}@media (min-width:640px){.services-carousel__slide{flex:0 0 50%}}@media (min-width:1024px){.services-carousel__slide{flex:0 0 33.333%}}.services-carousel__slide .service-card{height:100%}.services-carousel__nav{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-6)}.services-carousel__btn{width:44px;height:44px;border-radius:var(--radius-full);background:#fff;border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);color:var(--color-text)}.services-carousel__btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.services-carousel__dots{display:flex;gap:var(--space-2)}.services-carousel__dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-neutral-300);border:none;cursor:pointer;transition:all var(--transition-fast);padding:0}.services-carousel__dot--active{background:var(--color-primary);width:24px}/* Reviews Attribution (Legacy) */ .reviews-attribution{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--space-4);margin-top:var(--space-10);padding-top:var(--space-6);border-top:1px solid var(--color-border-light)}.reviews-attribution__link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast)}.reviews-attribution__link:hover{color:var(--color-neutral-900)}.reviews-attribution__link svg{width:20px;height:20px}/* Review Stars */ .review-stars{display:flex;gap:var(--space-1)}.review-stars svg{width:20px;height:20px;color:var(--color-warning);fill:var(--color-warning)}.review-stars .star-empty svg{color:var(--color-neutral-300);fill:var(--color-neutral-300)}/* ========================================================================== Why Choose Section - Redesigned ========================================================================== */ .why-choose-section{overflow:hidden}.why-choose-grid{display:grid;grid-template-columns:1fr;gap:var(--space-12);align-items:start}.why-choose-content{max-width:540px}.why-choose-content .section-header__label{margin-bottom:var(--space-3)}.why-choose-content .section-header__title{margin-bottom:var(--space-4)}.why-choose-text{font-size:var(--text-lg);color:var(--color-text-light);line-height:var(--leading-relaxed);margin-bottom:var(--space-8)}.why-choose-stats{display:flex;gap:var(--space-8);margin-bottom:var(--space-8);padding:var(--space-6) 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.why-choose-stat__value{font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:var(--color-neutral-900);line-height:1;margin-bottom:var(--space-1)}.why-choose-stat__value span{color:var(--color-primary)}.why-choose-stat__label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--font-medium)}/* Feature Cards */ .why-choose-features{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.feature-card{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-5);background:#ffffff;border-radius:var(--radius-xl);border:1px solid var(--color-border);transition:all var(--transition-base)}.feature-card:hover{border-color:var(--color-primary-200);box-shadow:var(--shadow-md);transform:translateX(4px)}.feature-card--animated{opacity:0;transform:translateY(20px);animation:fadeInUp 0.6s ease forwards;animation-delay:var(--delay, 0s)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.feature-card__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-50);border-radius:var(--radius-lg);flex-shrink:0}.feature-card__icon svg{width:24px;height:24px;color:var(--color-primary)}.feature-card__icon--accent{background:var(--color-primary)}.feature-card__icon--accent svg{color:#ffffff}.feature-card__content{flex:1}.feature-card__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-neutral-900);margin-bottom:var(--space-1)}.feature-card__text{font-size:var(--text-sm);color:var(--color-text-light);margin:0;line-height:var(--leading-relaxed)}@media (min-width:640px){.why-choose-features{grid-template-columns:repeat(2, 1fr)}}@media (min-width:1024px){.why-choose-grid{grid-template-columns:1fr 1.2fr;gap:var(--space-16);align-items:center}.why-choose-stat__value{font-size:var(--text-5xl)}}/* ========================================================================== Contact Section - Redesigned ========================================================================== */ .contact-section{overflow:hidden}.contact-wrapper{display:grid;grid-template-columns:1fr;gap:var(--space-10)}.contact-content{max-width:540px}.contact-content .section-header__label{margin-bottom:var(--space-3)}.contact-content .section-header__title{margin-bottom:var(--space-4)}.contact-intro{font-size:var(--text-lg);color:var(--color-text-light);margin-bottom:var(--space-8)}.contact-cards{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.contact-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:#ffffff;border:1px solid var(--color-border);border-radius:var(--radius-xl);text-decoration:none;color:inherit;transition:all var(--transition-base);opacity:0;transform:translateX(-20px)}.contact-card--visible{opacity:1;transform:translateX(0)}.contact-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateX(4px)}.contact-card--visible:hover{transform:translateX(4px)}.contact-card--phone{background:var(--color-primary);border-color:var(--color-primary);color:#ffffff}.contact-card--phone:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#ffffff;transform:translateX(4px)}.contact-card--phone .contact-card__icon{background:rgba(255,255,255,0.2)}.contact-card--phone .contact-card__icon svg{color:#ffffff}.contact-card--phone .contact-card__label{color:rgba(255,255,255,0.8)}.contact-card__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-50);border-radius:var(--radius-lg);flex-shrink:0}.contact-card__icon svg{width:24px;height:24px;color:var(--color-primary)}.contact-card__content{flex:1;min-width:0}.contact-card__label{display:block;font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:var(--space-1)}.contact-card__value{display:block;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-neutral-900)}.contact-card--phone .contact-card__value{color:#ffffff}.contact-card > svg{width:18px;height:18px;color:var(--color-neutral-400);flex-shrink:0;transition:transform var(--transition-fast)}.contact-card:hover > svg{transform:translateX(4px)}.contact-card--phone > svg{color:rgba(255,255,255,0.7)}/* Contact Hours */ .contact-hours{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-neutral-100);border-radius:var(--radius-lg)}.contact-hours__icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0}.contact-hours__icon svg{width:20px;height:20px;color:var(--color-primary)}.contact-hours__content{flex:1}.contact-hours__title{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-neutral-900);margin-bottom:var(--space-2)}.contact-hours__grid{display:grid;grid-template-columns:auto 1fr;gap:var(--space-1) var(--space-3);font-size:var(--text-sm);color:var(--color-text-light)}/* Contact Map Wrapper */ .contact-map-wrapper{display:flex;flex-direction:column;gap:var(--space-3)}.contact-map{aspect-ratio:16/12;border-radius:var(--radius-2xl);overflow:hidden;background:var(--color-neutral-100);box-shadow:var(--shadow-lg)}.contact-map iframe{width:100%;height:100%;border:0}.contact-map-link{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast)}.contact-map-link:hover{color:var(--color-primary)}.contact-map-link svg{width:16px;height:16px}@media (min-width:1024px){.contact-wrapper{grid-template-columns:1fr 1.1fr;gap:var(--space-12);align-items:start}.contact-map{aspect-ratio:auto;min-height:480px}}/* ========================================================================== Forms ========================================================================== */ .form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-neutral-700);margin-bottom:var(--space-2)}.form-input, .form-textarea, .form-select{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-primary);font-size:var(--text-base);color:var(--color-text);background:#ffffff;border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.form-input:focus, .form-textarea:focus, .form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-100)}.form-input::placeholder, .form-textarea::placeholder{color:var(--color-neutral-400)}.form-textarea{min-height:120px;resize:vertical}/* ========================================================================== Footer ========================================================================== */ .site-footer{background:var(--color-neutral-900);color:var(--color-neutral-300);padding:0 0 var(--space-6)}/* Footer CTA Banner */ .footer-cta{display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-10) 0;margin-bottom:var(--space-10);border-bottom:1px solid var(--color-neutral-800);text-align:center}.footer-cta__content{display:flex;flex-direction:column;gap:var(--space-2)}.footer-cta__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:#ffffff;margin:0}.footer-cta__text{font-size:var(--text-base);color:var(--color-neutral-400);margin:0}.footer-cta__actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}@media (min-width:768px){.footer-cta{flex-direction:row;align-items:center;justify-content:space-between;text-align:left}.footer-cta__actions{justify-content:flex-end}}/* Outline White Button */ .btn--outline-white{background:transparent;color:#ffffff;border:1px solid var(--color-neutral-600)}.btn--outline-white:hover{background:var(--color-neutral-800);border-color:var(--color-neutral-500)}.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8);margin-bottom:var(--space-10)}.footer-brand{max-width:280px}.footer-logo{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);text-decoration:none}.footer-logo img, .footer-logo-img{height:44px;width:auto;max-width:140px;object-fit:contain;object-position:left center;filter:brightness(0) invert(1)}.footer-logo-text{font-size:var(--text-xl);font-weight:var(--font-bold);color:#ffffff}.footer-description{font-size:var(--text-sm);color:var(--color-neutral-400);margin-bottom:var(--space-4);line-height:var(--leading-relaxed)}.footer-contact-compact{margin-top:var(--space-4)}.footer-contact-compact a{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-neutral-400);text-decoration:none;transition:color var(--transition-fast)}.footer-contact-compact a:hover{color:#ffffff}.footer-contact-compact svg{width:16px;height:16px;flex-shrink:0}.footer-social{display:flex;gap:var(--space-2);margin-top:var(--space-4)}.footer-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-neutral-800);border-radius:var(--radius-md);color:var(--color-neutral-400);transition:all var(--transition-fast)}.footer-social a:hover{background:var(--color-neutral-700);color:#ffffff}.footer-social svg{width:18px;height:18px}.footer-nav h4{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-neutral-400);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:var(--space-4)}.footer-nav ul{list-style:none;margin:0;padding:0}.footer-nav li{margin-bottom:var(--space-2)}.footer-nav a{font-size:var(--text-sm);color:var(--color-neutral-300);text-decoration:none;transition:color var(--transition-fast)}.footer-nav a:hover{color:#ffffff}/* Footer Hours */ .footer-hours__list{display:flex;flex-direction:column;gap:var(--space-2)}.footer-hours__row{display:flex;justify-content:space-between;font-size:var(--text-sm);color:var(--color-neutral-400)}.footer-hours__row span:last-child{color:var(--color-neutral-300)}.footer-contact-item{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);font-size:var(--text-sm)}.footer-contact-item svg{width:18px;height:18px;color:var(--color-neutral-500);flex-shrink:0;margin-top:2px}.footer-contact-item a{color:var(--color-neutral-300);text-decoration:none}.footer-contact-item a:hover{color:#ffffff}.footer-bottom{padding-top:var(--space-6);border-top:1px solid var(--color-neutral-800);display:flex;flex-direction:column;gap:var(--space-4);font-size:var(--text-xs);color:var(--color-neutral-400);/* Changed from 500 for better contrast */}.footer-bottom p{margin:0}.footer-bottom a{color:var(--color-neutral-300);/* Changed from 400 for better contrast */ text-decoration:underline;/* Added underline so links don't rely only on color */ text-decoration-thickness:1px;text-underline-offset:2px;transition:color var(--transition-fast)}.footer-bottom a:hover{color:#ffffff}.footer-legal{display:flex;flex-wrap:wrap;gap:var(--space-4)}.footer-credit{color:var(--color-neutral-400);/* Changed from 600 for WCAG AA contrast */}.footer-credit a{color:var(--color-neutral-300);/* Changed from 500 for better contrast */ text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.footer-credit a:hover{color:#ffffff}@media (min-width:640px){.footer-grid{grid-template-columns:repeat(2, 1fr)}.footer-brand{grid-column:span 2}.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center;flex-wrap:wrap}}@media (min-width:1024px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr}.footer-brand{grid-column:span 1}}/* ========================================================================== Page Templates ========================================================================== */ /* Page Header */ .page-header{padding:calc(var(--header-height) + var(--space-10)) 0 var(--space-10);background:var(--color-neutral-900);color:#ffffff}.page-header__title{font-size:var(--text-3xl);color:#ffffff;margin-bottom:var(--space-4)}.page-header__text{font-size:var(--text-lg);color:var(--color-neutral-300);max-width:600px}/* Badge in page header needs specific styles */ .page-header .hero__badge{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.3);color:#ffffff}@media (min-width:768px){.page-header{padding:calc(var(--header-height) + var(--space-16)) 0 var(--space-16)}.page-header__title{font-size:var(--text-5xl)}}/* Breadcrumbs */ .breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:var(--text-sm);margin-bottom:var(--space-4)}.breadcrumbs a{color:var(--color-neutral-400);text-decoration:none}.breadcrumbs a:hover{color:#ffffff}.breadcrumbs span{color:var(--color-neutral-500)}.breadcrumbs .current{color:#ffffff}/* Page Content */ .page-content{padding:var(--space-10) 0}.page-content--narrow{max-width:var(--container-narrow);margin:0 auto}@media (min-width:768px){.page-content{padding:var(--space-16) 0}}/* ========================================================================== Blog / Posts ========================================================================== */ .posts-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}.post-card{background:#ffffff;border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base)}.post-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.post-card__image{aspect-ratio:16/10;overflow:hidden}.post-card__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.post-card:hover .post-card__image img{transform:scale(1.05)}.post-card__content{padding:var(--space-5)}.post-card__meta{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-2)}.post-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.post-card__title a{color:var(--color-neutral-900);text-decoration:none}.post-card__title a:hover{color:var(--color-primary)}.post-card__excerpt{font-size:var(--text-sm);color:var(--color-text-light)}@media (min-width:640px){.posts-grid{grid-template-columns:repeat(2, 1fr)}}@media (min-width:1024px){.posts-grid{grid-template-columns:repeat(3, 1fr)}}/* Single Post */ .single-post{max-width:var(--container-narrow);margin:0 auto}.single-post__header{margin-bottom:var(--space-8)}.single-post__meta{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-3)}.single-post__title{font-size:var(--text-3xl);margin-bottom:var(--space-4)}.single-post__featured{margin-bottom:var(--space-8);border-radius:var(--radius-xl);overflow:hidden}.single-post__content{font-size:var(--text-lg);line-height:var(--leading-relaxed)}.single-post__content h2{margin-top:var(--space-10);margin-bottom:var(--space-4)}.single-post__content h3{margin-top:var(--space-8);margin-bottom:var(--space-3)}.single-post__content p{margin-bottom:var(--space-5)}.single-post__content ul, .single-post__content ol{margin-bottom:var(--space-5)}.single-post__content img{border-radius:var(--radius-lg);margin:var(--space-6) 0}@media (min-width:768px){.single-post__title{font-size:var(--text-4xl)}}/* ========================================================================== 404 Page ========================================================================== */ .error-404{text-align:center;padding:var(--space-16) 0}.error-404__code{font-size:8rem;font-weight:var(--font-extrabold);line-height:1;color:var(--color-primary);opacity:0.2;margin-bottom:var(--space-4)}.error-404__title{font-size:var(--text-3xl);margin-bottom:var(--space-4)}.error-404__text{font-size:var(--text-lg);color:var(--color-text-light);margin-bottom:var(--space-8)}.error-404__buttons{display:flex;justify-content:center;gap:var(--space-4)}/* ========================================================================== Utilities ========================================================================== */ .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-muted{color:var(--color-text-muted)}.bg-primary{background-color:var(--color-primary)}.bg-alt{background-color:var(--color-bg-alt)}.bg-dark{background-color:var(--color-bg-dark)}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.mt-8{margin-top:var(--space-8)}.mb-8{margin-bottom:var(--space-8)}.hidden{display:none}@media (min-width:768px){.md\:hidden{display:none}.md\:block{display:block}.md\:flex{display:flex}}@media (min-width:1024px){.lg\:hidden{display:none}.lg\:block{display:block}.lg\:flex{display:flex}}/* ========================================================================== WordPress Specific ========================================================================== */ /* Alignments */ .alignleft{float:left;margin-right:var(--space-6);margin-bottom:var(--space-4)}.alignright{float:right;margin-left:var(--space-6);margin-bottom:var(--space-4)}.aligncenter{display:block;margin-left:auto;margin-right:auto;margin-bottom:var(--space-4)}.alignwide{max-width:var(--container-wide);margin-left:auto;margin-right:auto}.alignfull{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw)}/* Captions */ .wp-caption{max-width:100%}.wp-caption-text{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2)}/* Galleries */ .wp-block-gallery{display:grid;grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));gap:var(--space-4)}/* Pagination */ .nav-links{display:flex;justify-content:center;gap:var(--space-2);margin-top:var(--space-10)}.nav-links a, .nav-links span{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 var(--space-3);background:#ffffff;border:1px solid var(--color-border);border-radius:var(--radius-md);font-weight:var(--font-medium);color:var(--color-text);text-decoration:none;transition:all var(--transition-fast)}.nav-links a:hover{border-color:var(--color-primary);color:var(--color-primary)}.nav-links .current{background:var(--color-primary);border-color:var(--color-primary);color:#ffffff}/* Screen reader text */ .screen-reader-text{clip:rect(1px, 1px, 1px, 1px);position:absolute !important;height:1px;width:1px;overflow:hidden}/* ========================================================================== Page Content Images ========================================================================== */ /* Content Image Block */ .content-image{margin:var(--space-8) 0;border-radius:var(--radius-xl);overflow:hidden}.content-image img{width:100%;height:auto;display:block}.content-image--rounded{border-radius:var(--radius-2xl)}/* Image with caption */ .content-image figcaption{padding:var(--space-3) var(--space-4);background:var(--color-neutral-50);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}/* Page Image Placeholder */ .page-image-placeholder{position:relative;width:100%;background:linear-gradient(135deg, var(--color-neutral-100) 0%, var(--color-neutral-200) 100%);border-radius:var(--radius-xl);overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:200px}.page-image-placeholder--sm{min-height:150px}.page-image-placeholder--md{min-height:250px}.page-image-placeholder--lg{min-height:350px}.page-image-placeholder--hero{min-height:400px;border-radius:0}.page-image-placeholder__icon{color:var(--color-neutral-400);opacity:0.5}.page-image-placeholder__icon svg{width:48px;height:48px}/* Two Column Image + Content Layout */ .content-with-image{display:grid;grid-template-columns:1fr;gap:var(--space-8);align-items:center;margin:var(--space-10) 0}.content-with-image--reverse{direction:rtl}.content-with-image--reverse > *{direction:ltr}.content-with-image__image{border-radius:var(--radius-xl);overflow:hidden}.content-with-image__image img{width:100%;height:auto;display:block}.content-with-image__content h2{margin-bottom:var(--space-4)}.content-with-image__content p{color:var(--color-text-light);margin-bottom:var(--space-4)}.content-with-image__content p:last-child{margin-bottom:0}@media (min-width:768px){.content-with-image{grid-template-columns:1fr 1fr;gap:var(--space-12)}.page-image-placeholder--hero{min-height:500px}}/* Image Gallery Grid */ .image-gallery{display:grid;grid-template-columns:repeat(2, 1fr);gap:var(--space-4);margin:var(--space-8) 0}.image-gallery--three{grid-template-columns:repeat(3, 1fr)}.image-gallery__item{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}.image-gallery__item img{width:100%;height:100%;object-fit:cover}@media (max-width:639px){.image-gallery--three{grid-template-columns:repeat(2, 1fr)}.image-gallery--three .image-gallery__item:last-child{grid-column:span 2}}/* Service Page Feature Image */ .service-hero-image{position:relative;margin:var(--space-6) 0 var(--space-8);border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:16/9;max-height:400px}@media (min-width:768px){.service-hero-image{margin:calc(-1 * var(--space-10)) 0 var(--space-10)}}.service-hero-image img{width:100%;height:100%;object-fit:cover}.service-hero-image--placeholder{background:linear-gradient(135deg, var(--color-neutral-800) 0%, var(--color-neutral-900) 100%);display:flex;align-items:center;justify-content:center}.service-hero-image--placeholder .page-image-placeholder__icon{color:var(--color-neutral-500);opacity:1}/* ========================================================================== Contact Page Styles ========================================================================== */ .contact-hero{display:grid;grid-template-columns:1fr;gap:var(--space-8);align-items:start}@media (min-width:1024px){.contact-hero{grid-template-columns:1fr 1.2fr;gap:var(--space-12)}}/* Contact Cards - Contact Page Specific */ .contact-hero .contact-cards{display:flex;flex-direction:column;gap:var(--space-4)}@media (min-width:576px){.contact-hero .contact-cards{display:grid;grid-template-columns:repeat(2, 1fr)}}.contact-hero .contact-card{display:block;background:#fff;padding:var(--space-5);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);text-align:center;transition:all var(--transition-base);opacity:1;transform:none}.contact-hero .contact-card:hover{border-color:var(--color-primary-200);box-shadow:var(--shadow-md);transform:none}/* Featured card - horizontal on mobile, centered on desktop */ .contact-hero .contact-card--featured{display:flex;align-items:center;gap:var(--space-4);text-align:left;background:linear-gradient(135deg, var(--color-primary), var(--color-primary-700));border:none;color:#fff;padding:var(--space-4)}.contact-hero .contact-card--featured .contact-card__icon{flex-shrink:0;margin-bottom:0}.contact-hero .contact-card--featured .contact-card__content{flex:1;min-width:0}.contact-hero .contact-card--featured .contact-card__value{word-break:break-word;white-space:normal;overflow:visible;text-overflow:clip}@media (min-width:576px){.contact-hero .contact-card--featured{grid-column:span 2;flex-direction:column;text-align:center;padding:var(--space-5)}.contact-hero .contact-card--featured .contact-card__icon{margin-bottom:var(--space-3)}.contact-hero .contact-card--featured .contact-card__content{width:100%}}.contact-hero .contact-card__icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-50);border-radius:var(--radius-full);margin-bottom:var(--space-3);color:var(--color-primary)}.contact-hero .contact-card--featured .contact-card__icon{background:rgba(255,255,255,0.2);color:#fff}.contact-hero .contact-card__label{font-size:var(--text-xs);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:0.05em;color:var(--color-text-muted);margin-bottom:var(--space-1)}.contact-hero .contact-card--featured .contact-card__label{color:var(--color-primary-100)}.contact-hero .contact-card__value{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-neutral-900);margin:0;white-space:normal;overflow:visible}.contact-hero .contact-card__value a{color:inherit;text-decoration:none}.contact-hero .contact-card__value a:hover{color:var(--color-primary)}.contact-hero .contact-card--featured .contact-card__value{color:#fff;font-size:var(--text-2xl)}.contact-hero .contact-card--featured .contact-card__value a:hover{color:var(--color-primary-100)}.contact-hero .contact-card__sub{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2)}.contact-hero .contact-card--featured .contact-card__sub{color:var(--color-primary-100)}/* Team Contacts */ .team-contacts{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-4)}.team-contact{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-neutral-50);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-light);text-decoration:none;transition:all var(--transition-fast)}.team-contact:hover{background:var(--color-primary-50);color:var(--color-primary)}.team-contact__name{font-weight:var(--font-medium);color:var(--color-neutral-900)}/* Contact Form Redesign */ .contact-form-wrapper{background:#fff;padding:var(--space-5);border-radius:var(--radius-2xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-lg)}@media (min-width:576px){.contact-form-wrapper{padding:var(--space-8)}}.contact-form-header{text-align:center;margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-light)}.contact-form-header h2{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.contact-form-header p{color:var(--color-text-muted);margin:0}/* Opening Hours Box */ .hours-box{background:var(--color-neutral-50);padding:var(--space-5);border-radius:var(--radius-xl);margin-top:var(--space-6)}.hours-box__title{font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:0.05em;color:var(--color-text-muted);margin-bottom:var(--space-3)}.hours-box__row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px dashed var(--color-border-light);font-size:var(--text-sm)}.hours-box__row:last-child{border-bottom:none}.hours-box__day{color:var(--color-text-light)}.hours-box__time{font-weight:var(--font-medium);color:var(--color-neutral-900)}.hours-box__time--closed{color:var(--color-text-muted)}/* Directions Tip */ .directions-tip{display:flex;align-items:flex-start;gap:var(--space-3);background:linear-gradient(135deg, var(--color-primary-50), #fff);padding:var(--space-4);border-radius:var(--radius-lg);border-left:4px solid var(--color-primary);margin-top:var(--space-4)}.directions-tip__icon{flex-shrink:0;color:var(--color-primary)}.directions-tip__text{font-size:var(--text-sm);color:var(--color-neutral-700);margin:0}/* ========================================================================== Ireland Map & Areas Served Styles ========================================================================== */ .ireland-map-section{display:grid;grid-template-columns:1fr;gap:var(--space-8);align-items:center}@media (min-width:768px){.ireland-map-section{grid-template-columns:1fr 1.2fr;gap:var(--space-12)}}.ireland-map-container{max-width:280px;margin:0 auto}.ireland-map{width:100%;height:auto;display:block}/* Coverage Info */ .coverage-info__title{font-size:var(--text-2xl);font-weight:var(--font-bold);margin-bottom:var(--space-4)}.coverage-info__text{color:var(--color-text-light);margin-bottom:var(--space-4)}.coverage-badges{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-4)}.coverage-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-light)}.coverage-badge svg{color:var(--color-primary);width:16px;height:16px}/* Area Cards */ .area-cards-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:var(--space-4)}.area-card{background:#fff;padding:var(--space-5);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);transition:all var(--transition-base)}.area-card:hover{border-color:var(--color-primary-200);box-shadow:var(--shadow-md)}.area-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.area-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-primary);margin:0}.area-card__time{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-neutral-100);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.area-card__time svg{width:14px;height:14px}.area-card__places{font-size:var(--text-sm);color:var(--color-text-light);line-height:var(--leading-relaxed);margin:0}/* Coverage Info */ .coverage-info{text-align:left}.coverage-info__title{font-size:var(--text-2xl);font-weight:var(--font-bold);margin-bottom:var(--space-4)}.coverage-info__text{color:var(--color-text-light);margin-bottom:var(--space-6)}.coverage-badges{display:flex;flex-wrap:wrap;gap:var(--space-2)}.coverage-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-light)}.coverage-badge svg{color:var(--color-primary);width:16px;height:16px}/* ========================================================================== Mobile Optimisations ========================================================================== */ /* Responsive 2-column grid */ .content-grid-2col{display:grid;grid-template-columns:1fr;gap:var(--space-8);align-items:center}.form-grid-2col{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media (min-width:768px){.content-grid-2col{grid-template-columns:1fr 1fr}.form-grid-2col{grid-template-columns:1fr 1fr}}/* Prevent horizontal overflow on mobile */ @media (max-width:767px){html, body{overflow-x:hidden}/* Ensure all containers don't overflow */ .container, .section, table{max-width:100%;overflow-x:auto}/* Fix tables on mobile */ table{display:block;font-size:var(--text-sm)}/* Fix grid layouts that might overflow */ [style*="grid-template-columns:1fr 1fr"], [style*="grid-template-columns:repeat"]{grid-template-columns:1fr !important}/* Mobile nav - submenu collapsed by default */ .mobile-nav-menu .sub-menu{display:none;padding-left:var(--space-4);background:var(--color-neutral-50)}.mobile-nav-menu .menu-item-has-children.submenu-open > .sub-menu{display:block}.mobile-nav-menu .menu-item-has-children > a{display:flex;justify-content:space-between;align-items:center}.mobile-nav-menu .menu-item-has-children > a::after{content:'+';font-weight:var(--font-bold);font-size:var(--text-lg);color:var(--color-neutral-500);transition:transform var(--transition-fast)}.mobile-nav-menu .menu-item-has-children.submenu-open > a::after{content:'−'}/* Compact mobile footer */ .footer-cta{padding:var(--space-6) 0;margin-bottom:var(--space-6)}.footer-cta__title{font-size:var(--text-xl)}.footer-cta__text{font-size:var(--text-sm)}.footer-grid{gap:var(--space-6);margin-bottom:var(--space-6)}.footer-brand{max-width:100%}.footer-description{margin-bottom:var(--space-2)}.footer-nav h4{margin-bottom:var(--space-2);font-size:var(--text-sm)}.footer-nav ul{display:flex;flex-wrap:wrap;gap:var(--space-1) var(--space-4)}.footer-nav li{margin:0}.footer-nav a{font-size:var(--text-sm);padding:var(--space-1) 0}.footer-hours__list{font-size:var(--text-sm)}.footer-hours__row{padding:var(--space-1) 0}.footer-social{margin-top:var(--space-3)}.footer-bottom{padding-top:var(--space-4);gap:var(--space-2);text-align:center}.footer-legal{justify-content:center}/* Contact page form - prevent overflow */ .contact-form-wrapper{max-width:100%}/* Smart 2 page - table fix */ .page-template-page-smart-2-tachograph table{font-size:var(--text-xs)}.page-template-page-smart-2-tachograph th, .page-template-page-smart-2-tachograph td{padding:var(--space-2) !important}}/* ========================================================================== Print Styles ========================================================================== */ @media print{.site-header, .site-footer, .mobile-nav, .btn, .nav-links{display:none !important}body{font-size:12pt;line-height:1.5;color:#000;background:#fff}a{color:#000;text-decoration:underline}.container{max-width:100%;padding:0}}