/*
Theme Name: Crawford Electrical Solutions
Theme URI: https://www.crawfordelectricalsolutions.co.uk
Author: Welch Marketing Ltd
Author URI: https://www.welchmarketing.co.uk
Description: Custom WordPress theme for Crawford Electrical Solutions. Red, white, and blue brand. Services, locations, service-location combo pages, full admin control, schema, SEO-ready.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPLv2 or later
Text Domain: crawford
*/

:root {
    /* ── Brand colours from logo ── */
    --c-red: #E82028;
    --c-red-dark: #C41A20;
    --c-red-light: #FF3B42;
    --c-blue: #0080B8;
    --c-blue-dark: #006694;
    --c-blue-light: #00A0E0;
    --c-navy: #0A1628;
    --c-white: #FFFFFF;
    --c-off-white: #F5F7FA;
    --c-light-grey: #E4E8EE;
    --c-mid-grey: #8896A8;
    --c-dark-grey: #3A4455;
    --c-text: #1E2A3A;
    --c-text-light: #5A6880;
    --c-success: #22C55E;

    /* Aliases for primary/accent */
    --c-primary: var(--c-blue);
    --c-primary-dark: var(--c-navy);
    --c-accent: var(--c-red);
    --c-accent-dark: var(--c-red-dark);

    --font-heading: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --space-xs: 0.25rem; --space-sm: 0.5rem; --space-md: 1rem; --space-lg: 1.5rem;
    --space-xl: 2rem; --space-2xl: 3rem; --space-3xl: 4rem; --space-4xl: 6rem;
    --container: 1200px;
    --radius: 8px; --radius-lg: 12px; --radius-xl: 16px;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 14px rgba(0,0,0,0.08);
    --shadow-lg: 0 8px 30px rgba(0,0,0,0.12);
    --ease: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--c-text);background:var(--c-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-blue);text-decoration:none;transition:color var(--ease)}
a:hover{color:var(--c-red)}

/* ── Typography ── */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;color:var(--c-navy)}
h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:var(--space-lg)}
h2{font-size:clamp(1.6rem,3vw,2.25rem);margin-bottom:var(--space-md)}
h3{font-size:clamp(1.2rem,2.5vw,1.7rem);margin-bottom:var(--space-md)}
h4{font-size:1.2rem;margin-bottom:var(--space-sm)}
p{margin-bottom:var(--space-md)}p:last-child{margin-bottom:0}

/* ── Layout ── */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--space-lg)}
.section{padding:var(--space-4xl) 0}
.section--grey{background:var(--c-off-white)}
.section--dark{background:var(--c-navy);color:var(--c-white)}
.section--dark h2,.section--dark h3,.section--dark h4{color:var(--c-white)}
.section--blue{background:var(--c-blue);color:var(--c-white)}
.section--blue h2{color:var(--c-white)}
.section__header{text-align:center;max-width:700px;margin:0 auto var(--space-3xl)}
.section__subtitle{display:inline-block;font-family:var(--font-heading);font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--c-red);margin-bottom:var(--space-sm)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:0.85rem 1.75rem;font-family:var(--font-heading);font-size:0.95rem;font-weight:600;line-height:1;border:2px solid transparent;border-radius:var(--radius);cursor:pointer;transition:all var(--ease);white-space:nowrap;text-decoration:none}
.btn--red{background:var(--c-red);color:var(--c-white);border-color:var(--c-red)}
.btn--red:hover{background:var(--c-red-dark);border-color:var(--c-red-dark);color:var(--c-white);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--blue{background:var(--c-blue);color:var(--c-white);border-color:var(--c-blue)}
.btn--blue:hover{background:var(--c-blue-dark);border-color:var(--c-blue-dark);color:var(--c-white)}
.btn--white{background:var(--c-white);color:var(--c-navy);border-color:var(--c-white)}
.btn--white:hover{background:var(--c-off-white);color:var(--c-red)}
.btn--outline-white{background:transparent;color:var(--c-white);border-color:rgba(255,255,255,0.5)}
.btn--outline-white:hover{background:var(--c-white);color:var(--c-navy)}
.btn--outline{background:transparent;color:var(--c-blue);border-color:var(--c-blue)}
.btn--outline:hover{background:var(--c-blue);color:var(--c-white)}
.btn--phone{background:var(--c-success);color:var(--c-white);border-color:var(--c-success)}
.btn--phone:hover{background:#16a34a;border-color:#16a34a;color:var(--c-white)}
.btn--sm{padding:0.6rem 1.2rem;font-size:0.85rem}
.btn--lg{padding:1rem 2.25rem;font-size:1.05rem}

/* ── Header ── */
.site-header{position:sticky;top:0;z-index:1000;background:var(--c-white);box-shadow:var(--shadow-sm)}
.header__top{background:var(--c-navy);color:rgba(255,255,255,0.85);font-size:0.82rem;padding:6px 0}
.header__top .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-sm)}
.header__top a{color:rgba(255,255,255,0.85)}
.header__top a:hover{color:var(--c-red)}
.header__top-links{display:flex;gap:var(--space-lg);list-style:none}
.header__top-links li{display:flex;align-items:center;gap:4px}
.header__top-links svg{width:13px;height:13px;stroke:var(--c-red);fill:none}

.header__main{padding:var(--space-md) 0}
.header__main .container{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg)}
.site-logo{flex-shrink:0}
.site-logo img{height:55px;width:auto}
.site-logo__text{display:flex;flex-direction:column;line-height:1.15;text-decoration:none}
.site-logo__text strong{font-family:var(--font-heading);font-size:1.3rem;font-weight:800;color:var(--c-navy)}
.site-logo__text span{font-family:var(--font-heading);font-size:0.8rem;font-weight:700;color:var(--c-red);letter-spacing:0.08em;text-transform:uppercase}

.header__nav{display:none}
.header__nav ul{display:flex;list-style:none}
.header__nav a{display:block;padding:var(--space-sm) var(--space-md);font-family:var(--font-heading);font-weight:600;font-size:0.88rem;color:var(--c-text);transition:color var(--ease)}
.header__nav a:hover,.header__nav .current-menu-item>a{color:var(--c-red)}
.header__nav .sub-menu{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:500px;background:var(--c-white);box-shadow:0 12px 40px rgba(0,0,0,0.15);border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:var(--space-md);z-index:100;flex-wrap:wrap;border-top:3px solid var(--c-red);opacity:0;pointer-events:none;transition:opacity 0.25s ease,transform 0.25s ease}
.header__nav li{position:relative}
.header__nav li:hover>.sub-menu{display:flex;opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.header__nav .sub-menu li{width:50%}
.header__nav .sub-menu a{padding:9px var(--space-md);font-size:0.84rem;font-weight:500;border-radius:var(--radius);transition:background var(--ease),color var(--ease)}
.header__nav .sub-menu a:hover{background:var(--c-off-white);color:var(--c-red)}

.header__cta{display:none}
.menu-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:none;cursor:pointer}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--c-navy);position:relative;transition:background var(--ease)}
.menu-toggle span::before,.menu-toggle span::after{content:'';position:absolute;width:100%;height:2px;background:var(--c-navy);left:0;transition:transform var(--ease)}
.menu-toggle span::before{top:-7px}.menu-toggle span::after{top:7px}
.menu-toggle.active span{background:transparent}
.menu-toggle.active span::before{transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span::after{transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:var(--c-white);flex-direction:column}
.mobile-nav.active{display:flex}
.mobile-nav__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--c-light-grey);flex-shrink:0}
.mobile-nav__close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--c-light-grey);border-radius:var(--radius);cursor:pointer}
.mobile-nav__close svg{width:20px;height:20px;stroke:var(--c-navy)}
.mobile-nav__body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0}
.mobile-nav ul{list-style:none}
.mobile-nav__body>ul>li{border-bottom:1px solid var(--c-light-grey)}
.mobile-nav__body>ul>li.has-children{display:flex;flex-wrap:wrap}
.mobile-nav__body>ul>li.has-children>a{flex:1}
.mobile-nav a{display:block;padding:14px var(--space-lg);font-family:var(--font-heading);font-weight:600;font-size:1rem;color:var(--c-navy);text-decoration:none}
.mobile-nav a:active{color:var(--c-red);background:var(--c-off-white)}
.submenu-toggle{width:56px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-left:1px solid var(--c-light-grey);cursor:pointer;flex-shrink:0}
.submenu-toggle svg{width:16px;height:16px;stroke:var(--c-mid-grey);fill:none;transition:transform var(--ease),stroke var(--ease)}
.submenu-toggle.open{background:var(--c-red)}
.submenu-toggle.open svg{transform:rotate(180deg);stroke:var(--c-white)}
.mobile-nav .sub-menu{display:none;width:100%;background:var(--c-off-white)}
.mobile-nav .sub-menu.open{display:block}
.mobile-nav .sub-menu a{padding:12px var(--space-lg) 12px var(--space-2xl);font-weight:500;font-size:0.92rem;color:var(--c-text-light);border-top:1px solid rgba(0,0,0,0.04)}
.mobile-nav .sub-menu a:active{color:var(--c-red)}
.mobile-nav__footer{flex-shrink:0;padding:var(--space-md) var(--space-lg);border-top:1px solid var(--c-light-grey);display:flex;gap:var(--space-sm);background:var(--c-off-white)}

/* ── Hero ── */
.hero{position:relative;background:linear-gradient(135deg,#061224 0%,#0A1E38 40%,#0C2844 100%);color:var(--c-white);padding:var(--space-4xl) 0;overflow:hidden;min-height:520px;display:flex;align-items:center}
.hero--has-image::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,18,36,0.92),rgba(10,30,56,0.8));z-index:1}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero .container{position:relative;z-index:2}
.hero__content{max-width:660px}
.hero__badge{display:inline-flex;align-items:center;gap:var(--space-sm);background:rgba(232,32,40,0.12);border:1px solid rgba(232,32,40,0.3);padding:5px var(--space-md);border-radius:50px;font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--c-red-light);margin-bottom:var(--space-lg)}
.hero__badge svg{width:14px;height:14px;fill:var(--c-red)}
.hero h1{color:var(--c-white);font-size:clamp(2.2rem,5vw,3.5rem);margin-bottom:var(--space-md)}
.hero__text{font-size:1.1rem;line-height:1.8;color:rgba(255,255,255,0.85);margin-bottom:var(--space-xl)}
.hero__actions{display:flex;flex-wrap:wrap;gap:var(--space-md)}
/* Red accent bar at bottom of hero */
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--c-red);z-index:3}

/* ── Trust Bar ── */
.trust-bar{background:var(--c-white);padding:var(--space-xl) 0;border-bottom:1px solid var(--c-light-grey)}
.trust-bar .container{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--space-2xl)}
.trust-bar__item{display:flex;align-items:center;gap:var(--space-sm)}
.trust-bar__item img{height:55px;width:auto;object-fit:contain;filter:grayscale(20%);transition:filter var(--ease)}
.trust-bar__item:hover img{filter:grayscale(0%)}
.trust-bar__placeholder-badge{display:flex;align-items:center;justify-content:center;width:120px;height:55px;border-radius:var(--radius);color:#fff;font-family:var(--font-heading);font-weight:700;font-size:0.78rem;letter-spacing:0.05em;text-transform:uppercase;opacity:0.85;transition:opacity var(--ease)}
.trust-bar__placeholder-badge:hover{opacity:1}

/* ── Service Cards ── */
.services-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.service-card{background:var(--c-white);border:1px solid var(--c-light-grey);border-radius:var(--radius-lg);padding:var(--space-2xl);transition:all var(--ease);position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--c-red);transform:scaleY(0);transition:transform var(--ease);transform-origin:top}
.service-card:hover{box-shadow:var(--shadow-lg);border-color:transparent;transform:translateY(-2px)}
.service-card:hover::before{transform:scaleY(1)}
.service-card__icon{width:52px;height:52px;background:rgba(0,128,184,0.1);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-lg)}
.service-card__icon svg{width:26px;height:26px;stroke:var(--c-blue);fill:none}
.service-card h3{font-size:1.15rem}.service-card h3 a{color:var(--c-navy)}.service-card h3 a:hover{color:var(--c-red)}
.service-card p{color:var(--c-text-light);font-size:0.92rem}
.service-card__link{display:inline-flex;align-items:center;gap:4px;font-weight:600;font-size:0.88rem;color:var(--c-red);margin-top:var(--space-md)}
.service-card__link:hover{gap:8px;color:var(--c-red-dark)}
.service-card--featured{border-color:var(--c-red);background:linear-gradient(to bottom right,rgba(232,32,40,0.03),transparent)}
.service-card--featured .service-card__badge{position:absolute;top:var(--space-md);right:var(--space-md);background:var(--c-red);color:var(--c-white);font-size:0.68rem;font-weight:700;text-transform:uppercase;padding:4px 8px;border-radius:var(--radius);letter-spacing:0.05em}

/* ── Features Grid ── */
.features-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.feature-item{text-align:center;padding:var(--space-xl)}
.feature-item__icon{width:64px;height:64px;background:rgba(0,128,184,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}
.feature-item__icon svg{width:28px;height:28px;stroke:var(--c-blue);fill:none}
.feature-item h3{font-size:1.1rem}
.feature-item p{font-size:0.9rem;color:var(--c-text-light)}

/* ── Testimonials ── */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.testimonial-card{background:var(--c-white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-md);border-top:3px solid var(--c-red)}
.testimonial-card__stars{display:flex;gap:2px;margin-bottom:var(--space-md)}
.testimonial-card__stars svg{width:18px;height:18px;fill:var(--c-red)}
.testimonial-card blockquote{font-style:italic;color:var(--c-text);margin-bottom:var(--space-md);line-height:1.8}
.testimonial-card cite{font-style:normal;font-weight:600;color:var(--c-navy);font-size:0.9rem}
.testimonial-card cite span{display:block;font-weight:400;color:var(--c-text-light);font-size:0.82rem}

/* ── CTA ── */
.cta-section{background:var(--c-blue);color:var(--c-white);padding:var(--space-3xl) 0;text-align:center}
.cta-section h2{color:var(--c-white)}
.cta-section p{color:rgba(255,255,255,0.9);max-width:600px;margin:0 auto var(--space-xl)}
.cta-section__actions{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--space-md)}
.cta-banner{background:linear-gradient(135deg,var(--c-blue),var(--c-blue-dark));border-radius:var(--radius-xl);padding:var(--space-2xl);color:var(--c-white);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-md)}
.cta-banner h3{color:var(--c-white)}

/* ── Areas ── */
.areas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}
.area-card{background:var(--c-white);border:1px solid var(--c-light-grey);border-radius:var(--radius);padding:var(--space-lg);text-align:center;transition:all var(--ease)}
.area-card:hover{border-color:var(--c-red);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.area-card a{font-weight:600;color:var(--c-navy)}.area-card a:hover{color:var(--c-red)}

/* ── FAQ ── */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--c-light-grey)}
.faq-item__question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) 0;background:none;border:none;cursor:pointer;font-family:var(--font-heading);font-size:1.02rem;font-weight:600;color:var(--c-navy);text-align:left;gap:var(--space-md)}
.faq-item__question svg{width:20px;height:20px;flex-shrink:0;stroke:var(--c-red);fill:none;transition:transform var(--ease)}
.faq-item.active .faq-item__question svg{transform:rotate(180deg)}
.faq-item__answer{display:block;overflow:hidden;max-height:0;padding-bottom:0;opacity:0;color:var(--c-text-light);line-height:1.8}
.faq-item.active .faq-item__answer{max-height:500px;opacity:1;padding-bottom:var(--space-lg)}

/* ── Forms ── */
.form-group{margin-bottom:var(--space-lg)}
.form-group label{display:block;font-family:var(--font-heading);font-weight:600;font-size:0.88rem;margin-bottom:4px;color:var(--c-navy)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:0.75rem var(--space-md);font-family:var(--font-body);font-size:0.95rem;border:1px solid var(--c-light-grey);border-radius:var(--radius);transition:border-color var(--ease),box-shadow var(--ease);background:var(--c-white);color:var(--c-text)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--c-blue);box-shadow:0 0 0 3px rgba(0,128,184,0.12)}
.form-group textarea{min-height:130px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr;gap:var(--space-md)}
.form-message{padding:var(--space-md);border-radius:var(--radius);margin-bottom:var(--space-lg);font-weight:500}
.form-message--success{background:rgba(34,197,94,0.1);color:#166534;border:1px solid rgba(34,197,94,0.2)}
.form-message--error{background:rgba(239,68,68,0.1);color:#991b1b;border:1px solid rgba(239,68,68,0.2)}

/* ── Footer ── */
.site-footer{background:var(--c-navy);color:rgba(255,255,255,0.8);padding:var(--space-4xl) 0 0}
.footer__grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);margin-bottom:var(--space-3xl)}
.footer__col h4{color:var(--c-white);font-size:1rem;margin-bottom:var(--space-lg);position:relative;padding-bottom:var(--space-sm)}
.footer__col h4::after{content:'';position:absolute;bottom:0;left:0;width:40px;height:3px;background:var(--c-red)}
.footer__col p{font-size:0.88rem;line-height:1.8}
.footer__col ul{list-style:none}.footer__col ul li{margin-bottom:var(--space-sm)}
.footer__col ul a{color:rgba(255,255,255,0.7);font-size:0.88rem}.footer__col ul a:hover{color:var(--c-red)}
.footer__contact-item{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md);align-items:flex-start}
.footer__contact-item svg{width:17px;height:17px;stroke:var(--c-red);fill:none;flex-shrink:0;margin-top:3px}
.footer__contact-item a{color:rgba(255,255,255,0.8)}.footer__contact-item a:hover{color:var(--c-red)}
.footer__accreditations{display:flex;flex-wrap:wrap;gap:var(--space-lg);align-items:center;margin-top:var(--space-lg);padding:var(--space-md);background:rgba(255,255,255,0.08);border-radius:var(--radius)}
.footer__accreditations img{height:48px;width:auto;opacity:0.9;transition:opacity var(--ease);background:var(--c-white);padding:6px 10px;border-radius:4px}
.footer__accreditations img:hover{opacity:1}
.footer__bottom{border-top:1px solid rgba(255,255,255,0.1);padding:var(--space-lg) 0;font-size:0.82rem}
.footer__bottom .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-sm)}
.footer__bottom a{color:rgba(255,255,255,0.5)}.footer__bottom a:hover{color:var(--c-red)}

/* ── Sidebar ── */
.sidebar__widget{background:var(--c-off-white);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-xl)}
.sidebar__widget h4{margin-bottom:var(--space-md)}
.sidebar__widget ul{list-style:none}.sidebar__widget ul li{margin-bottom:var(--space-sm)}
.sidebar__widget ul a{color:var(--c-text);font-size:0.88rem}.sidebar__widget ul a:hover{color:var(--c-red)}
.sidebar__widget--cta{background:var(--c-navy);color:var(--c-white);border-radius:var(--radius-lg);padding:var(--space-xl)}
.sidebar__widget--cta h4{color:var(--c-white)}.sidebar__widget--cta p{font-size:0.88rem;margin-bottom:var(--space-md)}

/* ── Mobile CTA ── */
.mobile-cta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:999;background:var(--c-navy);padding:var(--space-sm);gap:var(--space-sm);box-shadow:0 -4px 20px rgba(0,0,0,0.25)}
.mobile-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:var(--space-sm) var(--space-md);font-family:var(--font-heading);font-weight:700;font-size:0.85rem;border-radius:var(--radius);text-align:center;text-decoration:none}
.mobile-cta__call{background:var(--c-success);color:var(--c-white)!important}
.mobile-cta__quote{background:var(--c-red);color:var(--c-white)!important}
.mobile-cta svg{width:16px;height:16px}

/* ── Breadcrumbs ── */
.breadcrumbs{padding:var(--space-md) 0;background:var(--c-off-white);border-bottom:1px solid var(--c-light-grey)}
.breadcrumbs__list{display:flex;flex-wrap:wrap;gap:var(--space-xs);list-style:none;font-size:0.82rem}
.breadcrumbs__list li::after{content:'›';margin-left:var(--space-xs);color:var(--c-mid-grey)}
.breadcrumbs__list li:last-child::after{display:none}
.breadcrumbs__list a{color:var(--c-text-light)}.breadcrumbs__list a:hover{color:var(--c-red)}
.breadcrumbs__list li:last-child{color:var(--c-navy);font-weight:600}

/* ── Page Hero ── */
.page-hero{background:var(--c-navy);color:var(--c-white);padding:var(--space-3xl) 0;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,18,36,0.95),rgba(10,30,56,0.85));z-index:1}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:var(--c-white);margin-bottom:var(--space-sm)}
.page-hero p{color:rgba(255,255,255,0.85);font-size:1.05rem;max-width:700px}

.page-content{padding:var(--space-3xl) 0}
.page-content h2{margin-top:var(--space-2xl)}
.page-content ul,.page-content ol{margin-bottom:var(--space-md);padding-left:var(--space-xl)}
.page-content li{margin-bottom:var(--space-sm)}
.content-with-sidebar{display:grid;grid-template-columns:1fr;gap:var(--space-2xl)}
.sidebar{order:2}

/* ── Blog ── */
.blog-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.blog-card{border:1px solid var(--c-light-grey);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--ease)}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.blog-card__image{aspect-ratio:16/9;overflow:hidden}
.blog-card__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--ease)}
.blog-card:hover .blog-card__image img{transform:scale(1.05)}
.blog-card__content{padding:var(--space-xl)}
.blog-card__meta{font-size:0.78rem;color:var(--c-text-light);margin-bottom:var(--space-sm)}
.blog-card h3 a{color:var(--c-navy)}.blog-card h3 a:hover{color:var(--c-red)}

/* ── 404 ── */
.error-404{text-align:center;padding:var(--space-4xl) 0}
.error-404__number{font-size:clamp(5rem,15vw,10rem);font-weight:800;color:var(--c-light-grey);line-height:1;font-family:var(--font-heading)}

/* ── Responsive ── */
@media(min-width:576px){.form-row{grid-template-columns:1fr 1fr}.areas-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.services-grid{grid-template-columns:repeat(2,1fr)}.features-grid{grid-template-columns:repeat(2,1fr)}.testimonials-grid{grid-template-columns:repeat(2,1fr)}.blog-grid{grid-template-columns:repeat(2,1fr)}.footer__grid{grid-template-columns:repeat(2,1fr)}.content-with-sidebar{grid-template-columns:1fr 320px}.sidebar{order:0}.mobile-cta{display:none}body{padding-bottom:0}}
@media(min-width:1024px){.header__nav{display:block}.header__cta{display:flex;gap:var(--space-sm);align-items:center}.menu-toggle{display:none}.services-grid{grid-template-columns:repeat(3,1fr)}.features-grid{grid-template-columns:repeat(4,1fr)}.footer__grid{grid-template-columns:1.5fr 1fr 1fr 1.5fr}.areas-grid{grid-template-columns:repeat(5,1fr)}.blog-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:767px){body{padding-bottom:65px}}

/* ── Utilities ── */
.text-center{text-align:center}.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}

/* ══════════════════════════════════════
   Scroll Animations
   ══════════════════════════════════════ */
/* Base hidden state — elements start invisible and offset */
.anim{opacity:0;transition:opacity 0.7s ease,transform 0.7s ease}
.anim-up{transform:translateY(30px)}
.anim-left{transform:translateX(-30px)}
.anim-right{transform:translateX(30px)}
.anim-scale{transform:scale(0.95)}
/* Visible state — triggered by IntersectionObserver */
.anim.is-visible{opacity:1;transform:translateY(0) translateX(0) scale(1)}
/* Stagger delays for grid children */
.anim-delay-1{transition-delay:0.1s}
.anim-delay-2{transition-delay:0.2s}
.anim-delay-3{transition-delay:0.3s}
.anim-delay-4{transition-delay:0.4s}
.anim-delay-5{transition-delay:0.5s}
.anim-delay-6{transition-delay:0.6s}

/* Hero entrance */
.hero__badge{opacity:0;transform:translateY(15px);animation:heroFadeUp 0.6s 0.2s ease forwards}
.hero h1{opacity:0;transform:translateY(20px);animation:heroFadeUp 0.6s 0.4s ease forwards}
.hero__text{opacity:0;transform:translateY(20px);animation:heroFadeUp 0.6s 0.6s ease forwards}
.hero__actions{opacity:0;transform:translateY(20px);animation:heroFadeUp 0.6s 0.8s ease forwards}

@keyframes heroFadeUp{
    to{opacity:1;transform:translateY(0)}
}

/* Trust bar logos slide in */
.trust-bar__item{opacity:0;transform:translateY(10px);animation:trustFade 0.5s ease forwards}
.trust-bar__item:nth-child(1){animation-delay:0.1s}
.trust-bar__item:nth-child(2){animation-delay:0.2s}
.trust-bar__item:nth-child(3){animation-delay:0.3s}
.trust-bar__item:nth-child(4){animation-delay:0.4s}
.trust-bar__item:nth-child(5){animation-delay:0.5s}
.trust-bar__item:nth-child(6){animation-delay:0.6s}
@keyframes trustFade{to{opacity:1;transform:translateY(0)}}

/* Service card hover lift */
.service-card{transition:all 0.4s cubic-bezier(0.25,0.46,0.45,0.94)}
.service-card:hover{transform:translateY(-6px);box-shadow:0 12px 35px rgba(0,0,0,0.12)}
.service-card__icon svg{transition:transform 0.3s ease}
.service-card:hover .service-card__icon svg{transform:scale(1.15)}

/* Feature items — subtle float */
.feature-item__icon{transition:transform 0.4s ease,box-shadow 0.4s ease}
.feature-item:hover .feature-item__icon{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,128,184,0.15)}

/* Testimonial cards */
.testimonial-card{transition:transform 0.4s ease,box-shadow 0.4s ease}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:0 12px 35px rgba(0,0,0,0.12)}

/* Area cards */
.area-card{transition:all 0.3s cubic-bezier(0.25,0.46,0.45,0.94)}
.area-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,0.1);border-color:var(--c-red)}

/* FAQ expand animation */
.faq-item__answer{overflow:hidden;max-height:0;padding-bottom:0;opacity:0;transition:max-height 0.4s ease,opacity 0.3s ease,padding-bottom 0.3s ease}
.faq-item.active .faq-item__answer{max-height:500px;opacity:1;padding-bottom:var(--space-lg);display:block}

/* CTA section subtle pulse on buttons */
.cta-section .btn--red{transition:all 0.3s ease,box-shadow 0.3s ease}
.cta-section .btn--red:hover{box-shadow:0 6px 20px rgba(232,32,40,0.35)}

/* Section subtitle line animation */
.section__subtitle{position:relative;padding-bottom:8px}
.section__subtitle::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--c-red);transition:width 0.6s ease}
.section__subtitle.is-visible::after,.section__header:hover .section__subtitle::after{width:40px}

/* Buttons — micro-interaction */
.btn{position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,0.15);border-radius:50%;transform:translate(-50%,-50%);transition:width 0.5s ease,height 0.5s ease}
.btn:active::after{width:300px;height:300px}

/* Reduce motion for accessibility */
@media(prefers-reduced-motion:reduce){
    .anim,.hero__badge,.hero h1,.hero__text,.hero__actions,.trust-bar__item{opacity:1;transform:none;animation:none;transition:none}
    .faq-item__answer{transition:none}
}
