/*
Theme Name: VitaCall
Theme URI: https://vitacall.co.uk
Author: VitaCall
Description: Professional Communication Services - Call Centre, Dispatch, and Digital Solutions
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: vitacall
*/

:root {
  --primary: #6e412a;
  --primary-light: #8b5e3c;
  --primary-fg: #faf0e6;
  --secondary: #e3c193;
  --secondary-fg: #3d2516;
  --accent: #ffe4b5;
  --accent-fg: #3d2516;
  --background: #fdfbf7;
  --foreground: #3d2516;
  --card: #ffffff;
  --card-fg: #3d2516;
  --muted: #f0e6d6;
  --muted-fg: #6b5744;
  --border: #e0d0bb;
  --radius: 0.5rem;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}

body {
  font-family:'Inter',sans-serif;
  background-color:var(--background);
  color:var(--foreground);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:
    linear-gradient(to right,rgba(110,65,42,0.03)1px,transparent 1px),
    linear-gradient(to bottom,rgba(110,65,42,0.03)1px,transparent 1px);
  background-size:40px 40px;
  background-attachment:fixed;
}

h1,h2,h3,h4,h5,h6 {
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  color:var(--primary);
  line-height:1.2;
}

a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}

.container{max-width:1200px;margin:0 auto;padding:0 1rem;}
@media(min-width:768px){.container{padding:0 1.5rem;}}

/* ===== BUTTONS ===== */
.btn {
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.75rem 1.75rem;border-radius:var(--radius);
  font-weight:600;font-size:1rem;cursor:pointer;
  transition:all 0.3s;border:none;text-decoration:none;
}
.btn-primary{background:var(--primary);color:var(--primary-fg);}
.btn-primary:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 8px 25px rgba(110,65,42,0.2);}
.btn-secondary{background:var(--secondary);color:var(--secondary-fg);}
.btn-secondary:hover{background:#d4ae7a;}
.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary);}
.btn-outline:hover{background:rgba(227,193,147,0.1);transform:translateY(-2px);}
.btn-lg{padding:1.1rem 2.5rem;font-size:1.25rem;}
.btn-full{width:100%;justify-content:center;}
.btn-round{border-radius:9999px;}

/* ===== BLINKING CTA ===== */
@keyframes pulse-bright{
  0%,100%{opacity:1;filter:brightness(1);}
  50%{opacity:0.8;filter:brightness(1.2);}
}
.blinking-cta{animation:pulse-bright 1s ease-in-out infinite!important;}

/* ===== ANIMATIONS ===== */
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-20px);}}
@keyframes reveal{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(calc(-50% - 1rem));}}
@keyframes bounce-x{0%,100%{transform:translateX(0);}50%{transform:translateX(10px);}}
@keyframes spin{to{transform:rotate(360deg);}}

.animate-float{animation:float 6s ease-in-out infinite;}
.animate-reveal{animation:reveal 0.8s cubic-bezier(0.16,1,0.3,1) forwards;}
.animate-scroll{animation:scroll 40s linear infinite;}
.animate-scroll:hover{animation-play-state:paused;}
.animate-bounce-x{animation:bounce-x 2s ease-in-out infinite;}
.animate-pulse{animation:pulse-bright 2s ease-in-out infinite;}
.animate-spin{animation:spin 1s linear infinite;}

/* ===== TOP BAR ===== */
.top-bar{background:var(--primary);color:var(--primary-fg);padding:0.5rem 0;border-bottom:1px solid rgba(255,255,255,0.1);font-size:0.85rem;}
.top-bar a{color:var(--primary-fg);transition:color 0.3s;}
.top-bar a:hover{color:var(--secondary);}
.top-bar-inner{display:flex;justify-content:space-between;align-items:center;}
.top-bar-contact{display:flex;align-items:center;gap:1rem;}
.top-bar-social{display:flex;gap:0.75rem;}
.top-bar-social a{font-size:1rem;}

/* ===== HEADER ===== */
.site-header{position:sticky;top:0;z-index:50;background:rgba(253,251,247,0.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px;}
.site-logo img{height:40px;width:auto;}

/* Desktop Nav */
.main-nav{display:none;}
@media(min-width:768px){.main-nav{display:flex;align-items:center;gap:1.5rem;}}
.main-nav a{font-size:0.875rem;font-weight:500;color:var(--muted-fg);transition:color 0.3s;}
.main-nav a:hover,.main-nav a.active{color:var(--primary);}

/* Services Dropdown */
.nav-dropdown{position:relative;}
.nav-dropdown-trigger{display:flex;align-items:center;gap:0.25rem;cursor:default;padding:1rem 0;font-size:0.875rem;font-weight:500;color:var(--muted-fg);transition:color 0.3s;}
.nav-dropdown-trigger:hover{color:var(--primary);}
.nav-dropdown-trigger svg{transition:transform 0.2s;width:16px;height:16px;}
.nav-dropdown:hover .nav-dropdown-trigger svg{transform:rotate(180deg);}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);width:220px;background:var(--card);border:1px solid var(--border);border-radius:0.75rem;padding:0.5rem 0;opacity:0;visibility:hidden;transition:all 0.2s;box-shadow:0 10px 40px rgba(0,0,0,0.08);z-index:100;}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;}
.nav-dropdown-menu a{display:block;padding:0.625rem 1rem;font-size:0.875rem;font-weight:500;color:var(--foreground);transition:all 0.2s;}
.nav-dropdown-menu a:hover{background:var(--muted);color:var(--primary);}

.header-cta{display:none;}
@media(min-width:768px){.header-cta{display:block;}}

/* Mobile Menu */
.mobile-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;color:var(--foreground);font-size:1.5rem;}
@media(min-width:768px){.mobile-toggle{display:none;}}

.mobile-menu{position:fixed;top:0;right:-100%;width:300px;height:100vh;background:var(--card);z-index:200;padding:2rem 1.5rem;transition:right 0.3s;overflow-y:auto;box-shadow:-5px 0 30px rgba(0,0,0,0.1);}
.mobile-menu.open{right:0;}
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:199;display:none;}
.mobile-overlay.open{display:block;}

.mobile-menu-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--foreground);position:absolute;top:1rem;right:1rem;}
.mobile-nav{display:flex;flex-direction:column;gap:1rem;margin-top:3rem;}
.mobile-nav>a{font-size:1.125rem;font-weight:600;color:var(--foreground);}
.mobile-services-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;font-size:1.125rem;font-weight:600;color:var(--muted-fg);cursor:pointer;padding:0;text-align:left;transition:color 0.3s;}
.mobile-services-toggle:hover{color:var(--primary);}
.mobile-services-toggle svg{transition:transform 0.3s;width:20px;height:20px;}
.mobile-services-toggle.open svg{transform:rotate(180deg);}
.mobile-services-list{display:none;flex-direction:column;gap:0.25rem;padding-left:1rem;margin-top:0.5rem;}
.mobile-services-list.open{display:flex;}
.mobile-services-list a{font-size:1rem;color:var(--muted-fg);padding:0.25rem 0;transition:color 0.3s;}
.mobile-services-list a:hover{color:var(--primary);}

/* ===== SECTIONS ===== */
.section{padding:6rem 0;}
.section-muted{background:rgba(240,230,214,0.2);}
.section-muted-light{background:rgba(240,230,214,0.1);}
.section-primary{background:var(--primary);color:var(--primary-fg);}
.section-title{text-align:center;margin-bottom:4rem;}
.section-title h2{font-size:2.25rem;letter-spacing:-0.025em;}
@media(min-width:768px){.section-title h2{font-size:3rem;}}
.section-title .divider{width:6rem;height:6px;background:var(--secondary);border-radius:9999px;margin:1rem auto 0;}
.section-title p{max-width:700px;margin:1rem auto 0;font-size:1.125rem;color:var(--muted-fg);font-weight:500;}

/* ===== GRID ===== */
.grid{display:grid;gap:2rem;}
.grid-2{grid-template-columns:1fr;}
.grid-3{grid-template-columns:1fr;}
.grid-4{grid-template-columns:1fr;}
@media(min-width:640px){.grid-2{grid-template-columns:repeat(2,1fr);}.grid-4{grid-template-columns:repeat(2,1fr);}}
@media(min-width:768px){.grid-3{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1024px){.grid-2{grid-template-columns:repeat(2,1fr);}.grid-3{grid-template-columns:repeat(3,1fr);}.grid-4{grid-template-columns:repeat(4,1fr);}}

/* ===== CARDS ===== */
.card{background:var(--card);border:1px solid var(--border);border-radius:2rem;padding:2.5rem;box-shadow:0 2px 8px rgba(0,0,0,0.02);transition:all 0.5s;}
.card:hover{box-shadow:0 15px 40px rgba(0,0,0,0.08);transform:translateY(-8px);}
.card-center{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem;}
.card-icon{padding:1.25rem;border-radius:1rem;background:rgba(227,193,147,0.1);color:var(--primary);transition:all 0.7s;display:inline-flex;}
.card:hover .card-icon{background:var(--primary);color:var(--primary-fg);}
.card-icon svg{width:40px;height:40px;}
.card h3{font-size:1.5rem;}
.card p{color:var(--muted-fg);font-weight:500;line-height:1.7;}

/* ===== HERO ===== */
.hero{padding:4rem 0;overflow:hidden;position:relative;}
@media(min-width:1024px){.hero{padding:8rem 0;}}
.hero-grid{display:grid;gap:3rem;align-items:center;}
@media(min-width:1024px){.hero-grid{grid-template-columns:1fr 1fr;gap:2rem;}}
.hero h1{font-size:2.5rem;letter-spacing:-0.04em;}
@media(min-width:640px){.hero h1{font-size:3.5rem;}}
@media(min-width:1280px){.hero h1{font-size:4.5rem;}}
.hero h1 span{color:var(--secondary);text-shadow:0 1px 3px rgba(0,0,0,0.1);}
.hero-desc{max-width:600px;color:var(--muted-fg);font-size:1.125rem;font-weight:500;}
.hero-quote{margin-top:1rem;padding:0.5rem 0 0.5rem 1rem;border-left:4px solid var(--secondary);background:rgba(227,193,147,0.05);border-radius:0 0.5rem 0.5rem 0;font-style:italic;color:var(--muted-fg);}
.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;padding-top:1rem;}
.hero-image{position:relative;}
.hero-image img{border-radius:2.5rem;box-shadow:0 32px 64px rgba(0,0,0,0.15);aspect-ratio:4/3;object-fit:cover;width:100%;}
.hero-image:hover img{transform:scale(1.02);transition:transform 2s;}
.hero-badge{position:absolute;bottom:-1.5rem;left:-1.5rem;background:rgba(255,255,255,0.9);backdrop-filter:blur(20px);padding:1.5rem;border-radius:1rem;box-shadow:0 8px 30px rgba(0,0,0,0.08);display:none;}
@media(min-width:768px){.hero-badge{display:flex;align-items:center;gap:1rem;}}
.hero-badge-icon{width:48px;height:48px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;color:var(--primary);}
.hero-badge-text small{font-size:0.75rem;font-weight:700;color:var(--muted-fg);text-transform:uppercase;letter-spacing:0.1em;}
.hero-badge-text p{font-size:1.125rem;font-weight:800;color:var(--primary);}

/* Scrolling Carousel */
.scroll-track{display:flex;gap:2rem;width:max-content;}

/* ===== SERVICE PAGE HERO ===== */
.service-hero{padding:6rem 0;}
.service-hero-grid{display:grid;gap:4rem;align-items:center;}
@media(min-width:1024px){.service-hero-grid{grid-template-columns:1fr 1fr;}}
.service-hero h1{font-size:2rem;letter-spacing:-0.03em;}
@media(min-width:640px){.service-hero h1{font-size:2.5rem;}}

/* Benefit Items */
.benefit-item{display:flex;align-items:flex-start;gap:1rem;}
.benefit-item-icon{margin-top:0.25rem;padding:0.5rem;border-radius:0.5rem;background:rgba(227,193,147,0.1);color:var(--primary);transition:all 0.3s;flex-shrink:0;}
.benefit-item:hover .benefit-item-icon{background:var(--primary);color:white;}
.benefit-item p{font-size:1.125rem;}
.benefit-item strong{font-weight:700;}

/* Service Detail Sections */
.detail-grid{display:grid;gap:4rem;align-items:center;}
@media(min-width:1024px){.detail-grid{grid-template-columns:1fr 1fr;}}
.detail-grid.reverse .detail-content{order:1;}
.detail-grid.reverse .detail-images{order:2;}
@media(min-width:1024px){.detail-grid.reverse .detail-content{order:2;}.detail-grid.reverse .detail-images{order:1;}}
.detail-content h3{font-size:1.875rem;margin-bottom:1rem;}
.detail-content p{font-size:1.125rem;color:var(--muted-fg);line-height:1.7;margin-bottom:1rem;}
.detail-content .label{font-weight:700;color:var(--primary);font-size:1.25rem;}
.sub-list{list-style:none;padding:0;margin-top:0.75rem;display:flex;flex-direction:column;gap:0.75rem;}
.sub-list li{display:flex;align-items:center;gap:0.75rem;font-weight:500;color:var(--muted-fg);}
.sub-list li svg{color:var(--secondary);width:20px;height:20px;flex-shrink:0;}
.detail-images{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.detail-images img{border-radius:1rem;box-shadow:0 4px 20px rgba(0,0,0,0.06);}
.detail-images img:nth-child(2){margin-top:2rem;}
.detail-images img:nth-child(3){margin-top:-2rem;}

/* Process Steps / How It Works */
.process-row{display:flex;flex-direction:column;align-items:center;gap:2rem;}
@media(min-width:1024px){.process-row{flex-direction:row;gap:1rem;}}
.process-step{flex:1;text-align:center;padding:2rem;background:var(--card);border-radius:2rem;border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,0.02);}
.process-step-icon{display:inline-flex;padding:1rem;background:rgba(227,193,147,0.1);color:var(--primary);border-radius:1rem;margin-bottom:0.5rem;}
.process-step h3{font-size:1.125rem;margin-bottom:0.5rem;}
.process-step p{color:var(--muted-fg);}
.process-arrow{display:none;color:var(--secondary);}
@media(min-width:1024px){.process-arrow{display:block;}}
.process-arrow svg{width:32px;height:32px;}

/* ===== FAQ ===== */
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:1rem;overflow:hidden;transition:border-color 0.3s;}
.faq-item:hover{border-color:rgba(110,65,42,0.3);}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;cursor:pointer;list-style:none;font-weight:700;font-size:1.125rem;color:var(--primary);transition:color 0.3s;}
.faq-item summary:hover{color:var(--secondary);}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary svg{transition:transform 0.3s;width:20px;height:20px;flex-shrink:0;}
.faq-item[open] summary svg{transform:rotate(180deg);}
.faq-item .faq-answer{padding:0 1.5rem 1.5rem;color:var(--muted-fg);line-height:1.7;font-weight:500;}

/* ===== CTA SECTION ===== */
.cta-section{text-align:center;max-width:800px;margin:0 auto;}
.cta-section h2{font-size:2rem;margin-bottom:1rem;}
@media(min-width:768px){.cta-section h2{font-size:2.5rem;}}
.cta-section p{font-size:1.25rem;color:var(--muted-fg);font-weight:500;margin-bottom:2rem;}
.cta-section.light p{color:rgba(250,240,230,0.8);}

/* ===== FORMS ===== */
.form-group{margin-bottom:1.5rem;}
.form-group label{display:block;font-size:0.875rem;font-weight:500;margin-bottom:0.5rem;}
.form-control{width:100%;height:40px;padding:0 0.75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--background);font-family:inherit;font-size:1rem;transition:border-color 0.3s;}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(110,65,42,0.1);}
textarea.form-control{height:auto;min-height:150px;padding:0.75rem;resize:vertical;}
.form-row{display:grid;gap:1.5rem;}
@media(min-width:768px){.form-row{grid-template-columns:1fr 1fr;}}

/* ===== CONTACT INFO ===== */
.contact-info-item{display:flex;gap:1.5rem;align-items:flex-start;}
.contact-info-icon{padding:1rem;background:rgba(227,193,147,0.2);border-radius:0.75rem;color:var(--primary);flex-shrink:0;}
.contact-info-icon svg{width:24px;height:24px;}
.contact-info-item h3{font-size:1.25rem;font-weight:700;font-family:'Montserrat',sans-serif;}
.contact-info-item p{color:var(--muted-fg);}
.contact-info-item small{font-size:0.875rem;color:var(--muted-fg);}

/* ===== FOOTER ===== */
.site-footer{border-top:1px solid var(--border);background:rgba(240,230,214,0.3);}
.footer-inner{padding:3rem 0 4rem;}
.footer-grid{display:grid;gap:2rem;}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(4,1fr);}}
.footer-col h4{font-size:1rem;font-weight:600;color:var(--foreground);margin-bottom:1rem;}
.footer-col p{font-size:0.875rem;color:var(--muted-fg);}
.footer-col ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:0.5rem;}
.footer-col ul a{font-size:0.875rem;color:var(--muted-fg);transition:color 0.3s;}
.footer-col ul a:hover{color:var(--primary);}
.footer-col .footer-contact{display:flex;align-items:center;gap:0.5rem;font-size:0.875rem;color:var(--muted-fg);}
.footer-bottom{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);text-align:center;font-size:0.875rem;color:var(--muted-fg);}

/* ===== TESTIMONIAL CARD ===== */
.testimonial-card{width:400px;flex-shrink:0;background:var(--card);border:1px solid var(--border);padding:2rem;border-radius:2rem;box-shadow:0 2px 8px rgba(0,0,0,0.02);transition:all 0.3s;}
.testimonial-card:hover{box-shadow:0 8px 25px rgba(0,0,0,0.06);}
.testimonial-card .quote{font-size:1.125rem;font-style:italic;line-height:1.7;margin-bottom:1.5rem;}
.testimonial-card .author{display:flex;align-items:center;gap:1rem;}
.testimonial-card .avatar{width:48px;height:48px;border-radius:50%;background:rgba(110,65,42,0.1);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--primary);}
.testimonial-card .name{font-weight:700;}
.testimonial-card .role{font-size:0.875rem;color:var(--muted-fg);}

/* ===== EXPERTISE LOGOS ===== */
.expertise-card{display:flex;align-items:center;justify-content:center;padding:5rem;background:white;border-radius:3rem;border:1px solid var(--border);width:550px;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,0.02);transition:all 0.5s;}
.expertise-card:hover{border-color:rgba(110,65,42,0.3);box-shadow:0 15px 40px rgba(0,0,0,0.08);transform:translateY(-16px);}
.expertise-card img{max-height:256px;max-width:100%;object-fit:contain;filter:grayscale(100%);transition:filter 0.5s;transform:scale(1.5);}
.expertise-card:hover img{filter:grayscale(0);}

/* ===== SERVICE PAGE IMAGE ===== */
.service-image{border-radius:3rem;overflow:hidden;box-shadow:0 32px 64px rgba(0,0,0,0.1);aspect-ratio:1;position:relative;}
.service-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.7s;}
.service-image:hover img{transform:scale(1.05);}
.service-image-pair{display:grid;gap:1.5rem;}
.service-image-pair img{border-radius:2rem;box-shadow:0 8px 30px rgba(0,0,0,0.06);}

/* ===== JOB CARDS ===== */
.job-card{padding:1.5rem;border-radius:0.75rem;border:1px solid var(--border);background:var(--card);transition:all 0.3s;}
.job-card:hover{border-color:rgba(110,65,42,0.5);box-shadow:0 8px 25px rgba(0,0,0,0.06);}
.job-card-inner{display:flex;flex-direction:column;gap:1rem;}
@media(min-width:768px){.job-card-inner{flex-direction:row;align-items:center;justify-content:space-between;}}
.job-card h3{font-size:1.25rem;transition:color 0.3s;}
.job-card:hover h3{color:var(--primary);}
.job-card .meta{display:flex;gap:1rem;font-size:0.875rem;color:var(--muted-fg);}
.job-card p{color:var(--muted-fg);margin-top:0.5rem;}

/* ===== CUSTOMER CARD ===== */
.customer-card{text-align:center;padding:3rem 1.5rem;background:var(--card);border:1px solid var(--border);border-radius:1rem;overflow:hidden;transition:border-color 0.3s;}
.customer-card:hover{border-color:rgba(110,65,42,0.5);}
.customer-icon{width:80px;height:80px;border-radius:1rem;background:rgba(227,193,147,0.1);color:var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;transition:all 0.3s;}
.customer-card:hover .customer-icon{transform:scale(1.1);background:var(--primary);color:var(--primary-fg);}
.customer-icon svg{width:40px;height:40px;}
.customer-card h3{font-size:1.25rem;font-weight:700;margin-bottom:0.5rem;}
.customer-card .industry{font-size:0.75rem;font-weight:700;color:rgba(110,65,42,0.8);text-transform:uppercase;letter-spacing:0.1em;}
.customer-card .location{font-size:0.75rem;color:var(--muted-fg);margin-top:0.25rem;}

/* ===== CASE STUDY CARD ===== */
.case-study-card{background:var(--card);border:1px solid var(--border);border-radius:2rem;padding:2.5rem;box-shadow:0 2px 8px rgba(0,0,0,0.02);transition:all 0.5s;}
.case-study-card:hover{box-shadow:0 15px 40px rgba(0,0,0,0.08);transform:translateY(-8px);border-color:rgba(110,65,42,0.5);}
.case-study-icon{padding:1rem;width:fit-content;border-radius:1rem;background:rgba(227,193,147,0.1);color:var(--primary);transition:all 0.5s;margin-bottom:1.5rem;}
.case-study-card:hover .case-study-icon{background:var(--primary);color:var(--primary-fg);}
.case-study-card h2{font-size:1.875rem;margin-bottom:0.5rem;transition:color 0.3s;}
.case-study-card:hover h2{color:var(--primary);}
.case-study-card .client{font-size:0.875rem;font-weight:700;color:var(--secondary);text-transform:uppercase;letter-spacing:0.1em;}
.result-box{background:rgba(110,65,42,0.05);padding:1rem;border-radius:0.75rem;border-left:4px solid var(--primary);margin:1rem 0;}
.result-box p{font-size:1.125rem;font-weight:700;color:var(--primary);font-style:italic;}
.case-study-link{display:flex;align-items:center;gap:0.5rem;font-size:1.125rem;font-weight:700;color:var(--primary);margin-top:1rem;transition:transform 0.3s;}
.case-study-card:hover .case-study-link{transform:translateX(8px);}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:300;display:none;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:var(--card);border-radius:1rem;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;position:relative;}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--muted-fg);}
.modal h2{font-size:1.5rem;margin-bottom:0.5rem;}
.modal p{color:var(--muted-fg);margin-bottom:1.5rem;}

/* ===== TOAST ===== */
.toast{position:fixed;top:1rem;right:1rem;background:var(--primary);color:var(--primary-fg);padding:1rem 1.5rem;border-radius:0.75rem;z-index:400;display:none;box-shadow:0 10px 30px rgba(0,0,0,0.2);max-width:400px;}
.toast.show{display:block;animation:reveal 0.3s ease-out;}
.toast.error{background:#dc2626;}
.toast h4{font-weight:700;margin-bottom:0.25rem;}
.toast p{font-size:0.875rem;opacity:0.9;}

/* ===== UTILITIES ===== */
.text-center{text-align:center;}
.text-primary{color:var(--primary);}
.text-muted{color:var(--muted-fg);}
.text-lg{font-size:1.125rem;}
.text-xl{font-size:1.25rem;}
.text-2xl{font-size:1.5rem;}
.font-bold{font-weight:700;}
.font-black{font-weight:900;}
.mt-1{margin-top:0.25rem;}
.mt-2{margin-top:0.5rem;}
.mt-4{margin-top:1rem;}
.mt-8{margin-top:2rem;}
.mb-4{margin-bottom:1rem;}
.mb-8{margin-bottom:2rem;}
.pt-4{padding-top:1rem;}
.max-w-3xl{max-width:48rem;margin-left:auto;margin-right:auto;}
.max-w-4xl{max-width:56rem;margin-left:auto;margin-right:auto;}
.space-y-4>*+*{margin-top:1rem;}
.space-y-6>*+*{margin-top:1.5rem;}
.space-y-8>*+*{margin-top:2rem;}
.space-y-32>*+*{margin-top:8rem;}
.overflow-hidden{overflow:hidden;}
.rounded-2xl{border-radius:1rem;}
.shadow-xl{box-shadow:0 20px 50px rgba(0,0,0,0.1);}
.italic{font-style:italic;}

/* SVG Icons (inline) */
.icon{width:1em;height:1em;display:inline-block;vertical-align:middle;}
.icon-sm{width:16px;height:16px;}
.icon-md{width:24px;height:24px;}
.icon-lg{width:40px;height:40px;}

/* ===== RESPONSIVE ===== */
@media(max-width:767px){
  .hero h1{font-size:2rem;}
  .section{padding:3rem 0;}
  .section-title h2{font-size:1.75rem;}
  .card{padding:1.5rem;}
  .testimonial-card{width:300px;}
  .expertise-card{width:300px;padding:3rem;}
  .expertise-card img{transform:scale(1);}
  .detail-images{grid-template-columns:1fr;}
  .detail-images img:nth-child(2){margin-top:0;}
  .detail-images img:nth-child(3){margin-top:0;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
