/* ===================================================
   CANNALYTIC PROFILING — DESIGN SYSTEM
   =================================================== */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=Saira:wght@300;400;500;600;700&display=swap');

/* ── Tokens ── */
:root {
  --thm-base:   #68a834;
  --thm-secnd:  #35083c;   /* dark plum */
  --thm-secnd-2: #6b2077;  /* lighter plum — gradient accent */
  --thm-deep:   #200525;   /* deepest — footer bg */
  --thm-body:   #7c8083;
  --thm-light:  #f5f7f9;
  --thm-white:  #ffffff;
  --thm-badge:  #2b75fc;
  --thm-border: rgba(53,8,60,0.12);

  --font-body:    'DM Sans', sans-serif;
  --font-head:    'Saira', sans-serif;

  --container: 1230px;
  --pad-section: 90px;
  --radius: 0px;
  --shadow: 0 8px 40px rgba(53,8,60,0.10);
  --shadow-card: 0 4px 24px rgba(53,8,60,0.08);
  --transition: 0.3s cubic-bezier(.4,0,.2,1);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-y:scroll;scrollbar-gutter:stable;}
body{font-family:var(--font-body);font-size:18px;line-height:1.6;color:var(--thm-body);background:var(--thm-white);-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{text-decoration:none;color:inherit;transition:var(--transition);}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,textarea,select{font-family:inherit;}

/* ── Global Typography ── */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-head);
  color:var(--thm-secnd);
  line-height:1.15;
  font-weight:400;
}
h1{font-size:clamp(36px,5vw,62px);}
h2{font-size:clamp(26px,3.5vw,42px);}
h3{font-size:clamp(20px,2.5vw,28px);}
h4{font-size:clamp(17px,1.8vw,22px);}
p{margin-bottom:18px;}
p:last-child{margin-bottom:0;}
strong{color:var(--thm-secnd);font-weight:600;}


/* ── Container ── */
.container{max-width:var(--container);margin:0 auto;padding:0 20px;}

/* ── Utility ── */
.clearfix::after{content:'';display:table;clear:both;}

/* ================================================================
   HEADER
   ================================================================ */
.site-header{position:relative;z-index:999;}

/* Top bar */
.header-topbar{background:var(--thm-secnd);padding:9px 0;}
.header-topbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.topbar-left{display:flex;align-items:center;gap:24px;}
.topbar-badge{font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.7);}
.topbar-badge span{color:var(--thm-base);margin-right:6px;}
.topbar-contact{display:flex;align-items:center;gap:20px;}
.topbar-contact a{font-family:var(--font-head);font-size:12px;color:rgba(255,255,255,0.8);display:flex;align-items:center;gap:6px;}
.topbar-contact a:hover{color:var(--thm-base);}
.topbar-contact i{font-size:13px;color:var(--thm-base);}

/* Main nav */
.header-main{background:var(--thm-white);border-bottom:1px solid var(--thm-border);position:sticky;top:0;z-index:998;transition:var(--transition);box-shadow:0 2px 16px rgba(0,0,0,0.06);}
.header-main .container{display:flex;align-items:center;justify-content:space-between;height:76px;}

/* Logo */
.site-logo img{height:48px;width:auto;}

/* Nav */
.main-nav ul{display:flex;align-items:center;gap:8px;}
.main-nav ul li a{font-family:var(--font-head);font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--thm-secnd);padding:8px 16px;border-radius:4px;position:relative;transition:var(--transition);}
.main-nav ul li a::after{content:'';position:absolute;bottom:0;left:50%;right:50%;height:2px;background:var(--thm-base);transition:var(--transition);}
.main-nav ul li a:hover::after,
.main-nav ul li.active a::after{left:16px;right:16px;}
.main-nav ul li a:hover,
.main-nav ul li.active a{color:var(--thm-base);}

/* Nav CTA */
.nav-cta{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--thm-white);background:var(--thm-base);padding:12px 26px;border-radius:3px;white-space:nowrap;transition:var(--transition);}
.nav-cta:hover{background:var(--thm-secnd);color:var(--thm-white);}

/* Mobile hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--thm-secnd);border-radius:2px;transition:var(--transition);}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.active span:nth-child(2){opacity:0;}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile nav — always hidden by default, revealed via JS toggle */
.mobile-nav{display:none;}
.mobile-nav.open{display:block;}

/* ================================================================
   PAGE TITLE BANNER
   ================================================================ */
.page-title-banner{background:var(--thm-secnd);position:relative;padding:70px 0;overflow:hidden;}
.page-title-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--thm-deep) 0%,var(--thm-secnd) 45%,var(--thm-secnd-2) 100%);z-index:0;}
.page-title-banner .container{position:relative;z-index:1;}
.page-title-banner h1{font-family:var(--font-head);font-size:42px;font-weight:400;color:var(--thm-white);margin-bottom:12px;line-height:1.2;}
.breadcrumb{display:flex;align-items:center;gap:10px;}
.breadcrumb a{font-family:var(--font-head);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.6);}
.breadcrumb a:hover{color:var(--thm-base);}
.breadcrumb span{color:rgba(255,255,255,0.35);font-size:11px;}
.breadcrumb .current{font-family:var(--font-head);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--thm-base);}

/* Decorative line on banner */
.page-title-banner::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--thm-base) 0%,transparent 100%);z-index:1;}

/* ================================================================
   SECTION SHARED
   ================================================================ */
.section{padding:var(--pad-section) 0;}

.sec-label{font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--thm-base);display:block;margin-bottom:12px;}
.sec-title{font-family:var(--font-head);font-size:clamp(26px,3.5vw,42px);font-weight:400;color:var(--thm-secnd);line-height:1.15;margin-bottom:10px;}
.sec-title span{color:var(--thm-base);}
.sec-subtitle{font-family:var(--font-head);font-size:clamp(16px,2vw,20px);font-weight:300;color:var(--thm-body);line-height:1.5;margin-bottom:0;}
.sec-line{width:54px;height:3px;background:var(--thm-base);margin:18px 0 30px;}
.sec-line.center{margin-left:auto;margin-right:auto;}
.sec-line.white{background:rgba(255,255,255,0.5);}

/* ================================================================
   BUTTONS
   ================================================================ */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:14px 36px;border-radius:3px;transition:var(--transition);cursor:pointer;border:2px solid transparent;}
.btn-primary{background:var(--thm-secnd);color:var(--thm-white);border-color:var(--thm-secnd);}
.btn-primary:hover{background:var(--thm-deep);border-color:var(--thm-deep);color:var(--thm-white);}
.btn-green{background:var(--thm-base);color:var(--thm-white);border-color:var(--thm-base);}
.btn-green:hover{background:#579228;border-color:#579228;color:var(--thm-white);}
.btn-outline{background:transparent;color:var(--thm-white);border-color:rgba(255,255,255,0.5);}
.btn-outline:hover{background:rgba(255,255,255,0.1);border-color:var(--thm-white);}
.btn-outline-dark{background:transparent;color:var(--thm-secnd);border-color:var(--thm-secnd);}
.btn-outline-dark:hover{background:var(--thm-secnd);color:var(--thm-white);}

/* ================================================================
   GRID SYSTEM
   ================================================================ */
.row{display:grid;gap:30px;}
.row-2{grid-template-columns:repeat(2,1fr);}
.row-3{grid-template-columns:repeat(3,1fr);}
.row-4{grid-template-columns:repeat(4,1fr);}
.row-cols-50-50{grid-template-columns:1fr 1fr;}
.row-cols-60-40{grid-template-columns:3fr 2fr;}
.row-cols-40-60{grid-template-columns:2fr 3fr;}

/* ================================================================
   CARDS
   ================================================================ */
.card{background:var(--thm-white);box-shadow:var(--shadow-card);transition:var(--transition);overflow:hidden;}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.card-body{padding:30px;}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{background:linear-gradient(160deg,var(--thm-deep) 0%,var(--thm-secnd) 100%);}
.footer-top{padding:70px 0 40px;}
.footer-top .container{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:50px;}
.footer-widget h3{font-family:var(--font-head);font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--thm-white);margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,0.08);position:relative;}
.footer-widget h3::after{content:'';position:absolute;bottom:-1px;left:0;width:36px;height:1px;background:var(--thm-base);}
.footer-contact-item{display:flex;gap:14px;margin-bottom:18px;}
.footer-contact-item .icon{width:36px;height:36px;flex-shrink:0;background:rgba(255,255,255,0.05);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--thm-base);}
.footer-contact-item .text h4{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:3px;}
.footer-contact-item .text p,.footer-contact-item .text a{font-size:15px;color:rgba(255,255,255,0.75);line-height:1.5;}
.footer-contact-item .text a:hover{color:var(--thm-base);}
.footer-links ul li{margin-bottom:10px;}
.footer-links ul li a{font-size:14px;color:rgba(255,255,255,0.6);display:flex;align-items:center;gap:8px;transition:var(--transition);}
.footer-links ul li a::before{content:'→';color:var(--thm-base);font-size:12px;}
.footer-links ul li a:hover{color:var(--thm-base);padding-left:4px;}
.footer-subscribe p{font-size:14px;color:rgba(255,255,255,0.6);margin-bottom:18px;line-height:1.6;}
.footer-subscribe-form{display:flex;border:1px solid rgba(255,255,255,0.12);border-radius:3px;overflow:hidden;}
.footer-subscribe-form input{flex:1;padding:12px 16px;background:rgba(255,255,255,0.05);color:var(--thm-white);font-size:14px;border:none;outline:none;}
.footer-subscribe-form input::placeholder{color:rgba(255,255,255,0.35);}
.footer-subscribe-form button{padding:12px 18px;background:var(--thm-base);color:var(--thm-white);font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;transition:var(--transition);border:none;cursor:pointer;}
.footer-subscribe-form button:hover{background:#579228;}
.footer-social{display:flex;gap:10px;margin-top:20px;}
.footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.10);display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,0.6);transition:var(--transition);}
.footer-social a:hover{background:var(--thm-base);border-color:var(--thm-base);color:var(--thm-white);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding:20px 0;}
.footer-bottom .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.footer-copyright p{font-size:13px;color:rgba(255,255,255,0.4);}
.footer-copyright a{color:var(--thm-base);}
.footer-bottom-nav{display:flex;gap:24px;}
.footer-bottom-nav a{font-family:var(--font-head);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.4);transition:var(--transition);}
.footer-bottom-nav a:hover{color:var(--thm-base);}

/* ================================================================
   SCROLL TOP
   ================================================================ */
.scroll-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;background:var(--thm-base);color:var(--thm-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;opacity:0;pointer-events:none;transition:var(--transition);z-index:9999;box-shadow:0 4px 18px rgba(104,168,52,0.4);border:none;}
.scroll-top.visible{opacity:1;pointer-events:all;}
.scroll-top:hover{background:var(--thm-secnd);transform:translateY(-3px);}

/* ================================================================
   FORMS
   ================================================================ */
.form-group{margin-bottom:22px;}
.form-group label{display:block;font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--thm-secnd);margin-bottom:8px;}
.form-control{width:100%;padding:14px 18px;border:1.5px solid var(--thm-border);border-radius:3px;font-family:var(--font-body);font-size:15px;color:var(--thm-secnd);background:var(--thm-white);transition:var(--transition);outline:none;}
.form-control:focus{border-color:var(--thm-base);box-shadow:0 0 0 3px rgba(104,168,52,0.1);}
.form-control::placeholder{color:rgba(124,128,131,0.6);}
textarea.form-control{resize:vertical;min-height:130px;}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2368a834' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px;}

/* ================================================================
   ANIMATIONS
   ================================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes countUp{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}

.animate-up{animation:fadeUp 0.7s ease both;}
.animate-up-d1{animation-delay:0.1s;}
.animate-up-d2{animation-delay:0.2s;}
.animate-up-d3{animation-delay:0.3s;}
.animate-up-d4{animation-delay:0.4s;}

/* ================================================================
   HIGHLIGHTS BAR
   ================================================================ */
.highlights-bar{background:linear-gradient(90deg,var(--thm-deep) 0%,var(--thm-secnd) 50%,var(--thm-secnd-2) 100%);padding:0;}
.highlights-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.highlight-item{padding:30px 32px;border-right:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;gap:18px;transition:var(--transition);}
.highlight-item:last-child{border-right:none;}
.highlight-item:hover{background:rgba(255,255,255,0.05);}
.highlight-icon{width:48px;height:48px;background:rgba(255,255,255,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--thm-base);flex-shrink:0;}
.highlight-text span{font-family:var(--font-head);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.5);display:block;margin-bottom:3px;}
.highlight-text strong{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--thm-white);}

/* ================================================================
   STATS COUNTER
   ================================================================ */
.stats-section{background:var(--thm-base);padding:80px 0;}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;}
.stat-item{text-align:center;padding:0 40px;border-right:1px solid rgba(255,255,255,0.2);position:relative;}
.stat-item:last-child{border-right:none;}
.stat-icon{display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--thm-white);opacity:0.85;}
.stat-number{font-family:var(--font-head);font-size:68px;font-weight:700;color:var(--thm-white);line-height:1;display:block;margin-bottom:8px;}
.stat-label{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.8);display:block;margin-bottom:12px;}
.stat-desc{font-size:14px;line-height:1.6;color:rgba(255,255,255,0.7);max-width:200px;margin:0 auto;}

/* ================================================================
   SERVICE CARDS
   ================================================================ */
.service-card{position:relative;overflow:hidden;border-radius:0;}
.service-card-image{position:relative;overflow:hidden;height:230px;}
.service-card-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition);}
.service-card:hover .service-card-image img{transform:scale(1.05);}
.service-card-icon{position:absolute;bottom:-20px;right:24px;width:50px;height:50px;background:var(--thm-base);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--thm-white);box-shadow:0 4px 16px rgba(104,168,52,0.4);}
.service-card-body{background:var(--thm-white);padding:28px 28px 24px;box-shadow:var(--shadow-card);transition:var(--transition);}
.service-card:hover .service-card-body{background:var(--thm-secnd);}
.service-card-body h3{font-family:var(--font-head);font-size:20px;font-weight:600;color:var(--thm-secnd);margin-bottom:10px;transition:var(--transition);}
.service-card:hover .service-card-body h3{color:var(--thm-white);}
.service-card-body p{font-size:14px;line-height:1.65;color:var(--thm-body);transition:var(--transition);}
.service-card:hover .service-card-body p{color:rgba(255,255,255,0.75);}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.testimonials-section{position:relative;padding:var(--pad-section) 0;}
.testimonials-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--thm-deep) 0%,var(--thm-secnd) 55%,var(--thm-secnd-2) 100%);z-index:0;}
.testimonials-bg::before{content:'';position:absolute;inset:0;background:url('https://staging.cannalyticprofiling.co.nz/wp-content/uploads/2022/12/testimonial-bg.jpg') center/cover;opacity:0.08;}
.testimonials-section .container{position:relative;z-index:1;}
.testimonial-card{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);padding:48px 52px;text-align:center;max-width:740px;margin:0 auto;}
.testimonial-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;margin:0 auto 20px;border:3px solid var(--thm-base);}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover;}
.testimonial-text{font-size:18px;font-style:italic;line-height:1.7;color:rgba(255,255,255,0.85);margin-bottom:28px;}
.testimonial-stars{color:var(--thm-base);font-size:16px;letter-spacing:3px;display:block;margin-bottom:14px;}
.testimonial-name{font-family:var(--font-head);font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--thm-white);}
.testimonial-role{font-size:13px;color:rgba(255,255,255,0.5);}

/* Testimonial nav dots */
.testimonial-dots{display:flex;justify-content:center;gap:8px;margin-top:32px;}
.testimonial-dots button{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.25);border:none;cursor:pointer;transition:var(--transition);}
.testimonial-dots button.active{width:24px;border-radius:4px;background:var(--thm-base);}

/* ================================================================
   PRICING
   ================================================================ */
.pricing-card{border:2px solid var(--thm-border);padding:40px 38px;position:relative;transition:var(--transition);}
.pricing-card.featured{border-color:var(--thm-base);background:var(--thm-secnd);}
.pricing-card.featured *:not(button){color:var(--thm-white)!important;}
.pricing-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--thm-base);color:var(--thm-white);font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 14px;border-radius:20px;}
.pricing-icon{font-size:32px;color:var(--thm-base);margin-bottom:18px;}
.pricing-card h3{font-family:var(--font-head);font-size:20px;font-weight:600;color:var(--thm-secnd);margin-bottom:8px;}
.pricing-card .subtitle{font-size:14px;color:var(--thm-body);margin-bottom:24px;}
.price{font-family:var(--font-head);font-size:52px;font-weight:700;color:var(--thm-secnd);line-height:1;}
.price-unit{font-family:var(--font-head);font-size:15px;font-weight:300;color:var(--thm-body);}
.pricing-features{margin:24px 0;}
.pricing-features li{padding:9px 0;border-bottom:1px solid var(--thm-border);font-size:14px;color:var(--thm-body);display:flex;align-items:center;gap:10px;}
.pricing-features li::before{content:'✓';color:var(--thm-base);font-weight:700;font-size:13px;}

/* ================================================================
   FAQ ACCORDION
   ================================================================ */
.faq-item{border:1px solid var(--thm-border);margin-bottom:10px;border-radius:3px;overflow:hidden;}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:none;cursor:pointer;text-align:left;transition:var(--transition);}
.faq-question h4{font-family:var(--font-head);font-size:16px;font-weight:600;color:var(--thm-secnd);line-height:1.4;}
.faq-question .faq-icon{width:28px;height:28px;background:var(--thm-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--thm-secnd);flex-shrink:0;transition:var(--transition);}
.faq-item.active .faq-question{background:var(--thm-secnd);}
.faq-item.active .faq-question h4{color:var(--thm-white);}
.faq-item.active .faq-question .faq-icon{background:var(--thm-base);color:var(--thm-white);transform:rotate(45deg);}
.faq-answer{overflow:hidden;max-height:0;transition:max-height 0.35s ease;}
.faq-item.active .faq-answer{max-height:400px;}
.faq-answer-inner{padding:22px 24px;background:var(--thm-light);font-size:15px;line-height:1.7;color:var(--thm-body);}

/* ================================================================
   BLOG GRID
   ================================================================ */
.blog-card{background:var(--thm-white);box-shadow:var(--shadow-card);overflow:hidden;transition:var(--transition);}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.blog-card-image{height:220px;overflow:hidden;position:relative;}
.blog-card-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition);}
.blog-card:hover .blog-card-image img{transform:scale(1.05);}
.blog-card-overlay{position:absolute;inset:0;background:rgba(53,8,60,0);display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.blog-card:hover .blog-card-overlay{background:rgba(53,8,60,0.5);}
.blog-card-overlay a{width:46px;height:46px;background:var(--thm-base);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--thm-white);font-size:16px;opacity:0;transform:scale(0.7);transition:var(--transition);}
.blog-card:hover .blog-card-overlay a{opacity:1;transform:scale(1);}
.blog-card-cat{position:absolute;top:16px;left:16px;background:var(--thm-base);color:var(--thm-white);font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:2px;}
.blog-card-body{padding:26px;}
.blog-card-meta{display:flex;align-items:center;gap:16px;margin-bottom:12px;}
.blog-card-meta span{font-family:var(--font-head);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:rgba(124,128,131,0.8);}
.blog-card-meta i{color:var(--thm-base);font-size:12px;}
.blog-card h3{font-family:var(--font-head);font-size:18px;font-weight:600;color:var(--thm-secnd);line-height:1.4;margin-bottom:16px;}
.blog-card h3 a:hover{color:var(--thm-base);}
.blog-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--thm-border);}
.read-more{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--thm-base);display:flex;align-items:center;gap:6px;}
.read-more:hover{color:var(--thm-secnd);gap:10px;}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:50px;}
.pagination a,.pagination span{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border:2px solid var(--thm-border);font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--thm-secnd);border-radius:3px;transition:var(--transition);}
.pagination a:hover,.pagination span.current{background:var(--thm-base);border-color:var(--thm-base);color:var(--thm-white);}
.pagination .prev,.pagination .next{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;width:auto;padding:0 16px;}

/* ================================================================
   CONTACT PAGE
   ================================================================ */
.contact-info-card{background:var(--thm-white);box-shadow:var(--shadow-card);padding:36px 32px;text-align:center;transition:var(--transition);}
.contact-info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.contact-info-card .icon{width:60px;height:60px;background:var(--thm-secnd);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--thm-white);margin:0 auto 18px;}
.contact-info-card h3{font-family:var(--font-head);font-size:16px;font-weight:600;color:var(--thm-secnd);margin-bottom:8px;}
.contact-info-card p,.contact-info-card a{font-size:14px;line-height:1.7;color:var(--thm-body);}
.contact-info-card a:hover{color:var(--thm-base);}
.contact-info-card .link-arrow{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--thm-base);display:inline-flex;align-items:center;gap:6px;margin-top:12px;}
.contact-info-card .link-arrow:hover{gap:10px;}

/* Map section */
.map-wrapper{border-radius:4px;overflow:hidden;box-shadow:var(--shadow-card);}
.map-wrapper iframe{display:block;width:100%;height:440px;border:none;}

/* ================================================================
   ABOUT SECTION (HOME)
   ================================================================ */
.about-image-stack{position:relative;}
.about-image-main{border-radius:0;overflow:hidden;}
.about-image-main img{width:100%;height:auto;display:block;}
.about-experience-badge{position:absolute;bottom:32px;right:-28px;background:var(--thm-base);color:var(--thm-white);padding:28px 32px;text-align:center;min-width:130px;}
.about-experience-badge .number{font-family:var(--font-head);font-size:56px;font-weight:700;line-height:1;display:block;}
.about-experience-badge .text{font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;display:block;margin-top:4px;opacity:0.85;}
.about-feature-item{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--thm-border);}
.about-feature-item:last-child{border-bottom:none;}
.about-feature-icon{width:54px;height:54px;background:rgba(53,8,60,0.08);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--thm-base);flex-shrink:0;}
.about-feature-item h3{font-family:var(--font-head);font-size:17px;font-weight:600;color:var(--thm-secnd);margin-bottom:5px;}
.about-feature-item p{font-size:14px;line-height:1.6;color:var(--thm-body);}

/* Fun facts */
.funfacts-section{background:linear-gradient(135deg,var(--thm-deep) 0%,var(--thm-secnd) 55%,var(--thm-secnd-2) 100%);padding:80px 0;}
.funfacts-grid{display:grid;grid-template-columns:repeat(3,1fr);}
.funfact-item{text-align:center;padding:0 40px;border-right:1px solid rgba(255,255,255,0.1);}
.funfact-item:last-child{border-right:none;}
.funfact-icon{display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--thm-base);}
.funfact-number{font-family:var(--font-head);font-size:64px;font-weight:700;color:var(--thm-white);line-height:1;display:block;margin-bottom:8px;}
.funfact-label{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.6);display:block;}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--thm-deep) 0%,var(--thm-secnd) 50%,var(--thm-secnd-2) 100%);padding:80px 0;}
.cta-band .container{display:flex;align-items:center;justify-content:space-between;gap:40px;}
.cta-band-text h2{font-family:var(--font-head);font-size:36px;font-weight:400;color:var(--thm-white);margin-bottom:10px;}
.cta-band-text p{font-size:16px;color:rgba(255,255,255,0.75);max-width:480px;}
.cta-band-actions{display:flex;gap:16px;flex-shrink:0;}

/* ================================================================
   HERO (HOME)
   ================================================================ */
.hero-slider{position:relative;overflow:hidden;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 0.8s ease;}
.hero-slide.active{position:relative;opacity:1;}
.hero-slide-inner{min-height:600px;display:flex;align-items:center;position:relative;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(30,20,35,0.72) 0%,rgba(60,40,65,0.55) 50%,rgba(80,60,85,0.30) 100%);}
.hero-content{position:relative;z-index:1;max-width:660px;}
.hero-content .tag{display:inline-block;font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--thm-white);background:rgba(104,168,52,0.18);border:1px solid rgba(104,168,52,0.4);border-radius:40px;padding:5px 16px;margin-bottom:22px;}
.hero-content h1,.hero-content h2{font-family:var(--font-head);font-size:54px;font-weight:400;color:var(--thm-white);line-height:1.1;margin-bottom:18px;}
.hero-content h1 span,.hero-content h2 span{color:var(--thm-base);}
.hero-content .hero-tagline{font-family:var(--font-head);font-size:16px;font-weight:300;color:rgba(255,255,255,0.8);margin-bottom:36px;line-height:1.6;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}

/* Slider controls */
.slider-controls{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:10;}
.slider-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.3);border:none;cursor:pointer;transition:var(--transition);}
.slider-dot.active{width:28px;border-radius:5px;background:var(--thm-base);}

/* ================================================================
   NEWSLETTER / POPUP CTA (home)
   ================================================================ */
.newsletter-section{background:var(--thm-light);padding:60px 0;}
.newsletter-inner{background:var(--thm-secnd);border-radius:6px;padding:50px 60px;display:flex;align-items:center;gap:50px;}
.newsletter-text h2{font-family:var(--font-head);font-size:28px;font-weight:400;color:var(--thm-white);margin-bottom:8px;}
.newsletter-text p{font-size:15px;color:rgba(255,255,255,0.65);}
.newsletter-form{flex:1;display:flex;gap:0;border:1px solid rgba(255,255,255,0.15);border-radius:3px;overflow:hidden;}
.newsletter-form input{flex:1;padding:14px 20px;background:rgba(255,255,255,0.08);color:var(--thm-white);font-size:15px;border:none;outline:none;}
.newsletter-form input::placeholder{color:rgba(255,255,255,0.35);}
.newsletter-form button{padding:14px 24px;background:var(--thm-base);color:var(--thm-white);font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:none;cursor:pointer;transition:var(--transition);flex-shrink:0;}
.newsletter-form button:hover{background:#579228;}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1100px){
  .sec-title{font-size:34px;}
  .hero-content h1,.hero-content h2{font-size:44px;}
  .newsletter-inner{flex-direction:column;text-align:center;gap:28px;}
  .cta-band .container{flex-direction:column;text-align:center;}
}

@media(max-width:900px){
  :root{--pad-section:65px;}
  .row-2,.row-cols-50-50,.row-cols-60-40,.row-cols-40-60{grid-template-columns:1fr;}
  .row-3{grid-template-columns:repeat(2,1fr);}
  .row-4{grid-template-columns:repeat(2,1fr);}
  .highlights-grid{grid-template-columns:repeat(2,1fr);}
  .funfacts-grid{grid-template-columns:1fr;gap:36px;}
  .funfact-item{border-right:none!important;border-bottom:1px solid rgba(255,255,255,0.1);padding-bottom:28px;}
  .funfact-item:last-child{border-bottom:none;}
  .stats-grid{grid-template-columns:1fr;gap:40px;}
  .stat-item{border-right:none;}
  .footer-top .container{grid-template-columns:1fr 1fr;}
  .about-experience-badge{right:0;}
  /* Contact: 3-col info cards → 1 col */
  .contact-info-card-grid{grid-template-columns:1fr!important;}
}

@media(max-width:768px){
  :root{--pad-section:50px;}
  .sec-title{font-size:28px;}
  .header-topbar{display:none;}
  .main-nav,.nav-cta{display:none;}
  .nav-toggle{display:flex;}
  .mobile-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--thm-white);box-shadow:var(--shadow);border-top:2px solid var(--thm-base);padding:20px;}
  .mobile-nav.open{display:block;}
  .mobile-nav ul{display:flex;flex-direction:column;gap:4px;}
  .mobile-nav ul li a{display:block;padding:12px 16px;font-family:var(--font-head);font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--thm-secnd);border-radius:4px;}
  .mobile-nav ul li a:hover,.mobile-nav ul li.active a{background:var(--thm-light);color:var(--thm-base);}
  .hero-content h1,.hero-content h2{font-size:32px;}
  .hero-slide-inner{min-height:480px;}
  .row-3,.row-4{grid-template-columns:1fr;}
  .highlights-grid{grid-template-columns:1fr;}
  .footer-top .container{grid-template-columns:1fr;}
  .testimonial-card{padding:28px 22px;}
  .newsletter-inner{padding:28px 22px;}
  /* Contact responsive */
  .map-wrapper iframe{height:280px;}
  .about-experience-badge{position:static;margin-top:16px;}
}

@media(max-width:480px){
  .hero-content h1,.hero-content h2{font-size:26px;}
  .sec-title{font-size:24px;}
  .btn{padding:12px 22px;font-size:11px;}
}
