/*
Theme Name: Pojištění-24 Pro
Theme URI: https://pojisteni-24.cz
Author: PureLog s.r.o.
Description: Moderní WordPress šablona pro srovnávač pojištění. Plně editovatelné sekce, barevné schéma přes Customizer, affiliate kalkulačky.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: pojisteni24
Tags: insurance, finance, comparison, responsive, custom-colors, custom-logo, custom-menu, featured-images, widgets
*/

/* ============================================================
   BAREVNÉ SCHÉMA — přepsatelné přes Customizer
   ============================================================ */
:root {
  --c-primary:        #7c3aed;
  --c-primary-dark:   #5b21b6;
  --c-primary-light:  #a78bfa;
  --c-secondary:      #0ea5e9;
  --c-secondary-dark: #0284c7;
  --c-accent:         #f59e0b;
  --c-accent-dark:    #d97706;

  /* Derived */
  --c-primary-10:  rgba(124,58,237,.10);
  --c-primary-20:  rgba(124,58,237,.20);
  --c-secondary-10:rgba(14,165,233,.10);
  --c-grad:        linear-gradient(135deg, var(--c-primary), var(--c-secondary));
  --c-grad-rev:    linear-gradient(135deg, var(--c-secondary), var(--c-primary));

  /* Neutrals */
  --c-white:       #ffffff;
  --c-bg:          #f8f7ff;
  --c-bg-card:     #ffffff;
  --c-border:      #e8e5f0;
  --c-text:        #1a1625;
  --c-text-2:      #6b6580;
  --c-text-3:      #9b95b0;
  --c-dark:        #0f0c1a;

  /* Shadows */
  --shadow-xs: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-sm: 0 4px 12px rgba(0,0,0,.08);
  --shadow-md: 0 8px 32px rgba(0,0,0,.12);
  --shadow-lg: 0 20px 64px rgba(0,0,0,.16);
  --shadow-p:  0 8px 40px var(--c-primary-20);

  /* Spacing */
  --sp-1:  4px;  --sp-2:  8px;   --sp-3: 12px;  --sp-4: 16px;
  --sp-5: 20px;  --sp-6: 24px;   --sp-8: 32px;  --sp-10:40px;
  --sp-12:48px;  --sp-16:64px;   --sp-20:80px;  --sp-24:96px;

  /* Radius */
  --r-sm: 8px; --r-md: 14px; --r-lg: 20px; --r-xl: 28px; --r-2xl: 40px; --r-full: 9999px;

  /* Typography */
  --font-head: 'Montserrat', 'Segoe UI', sans-serif;
  --font-body: 'Montserrat', 'Segoe UI', sans-serif;

  /* Layout */
  --header-h: 72px;
  --max-w: 1200px;
  --max-w-wide: 1400px;

  /* Transitions */
  --t-fast: .15s ease;
  --t-base: .28s ease;
  --t-slow: .5s cubic-bezier(.16,1,.3,1);
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{font-family:var(--font-body);font-size:1rem;line-height:1.75;color:var(--c-text);background:var(--c-bg);overflow-x:hidden;}
img,video{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;transition:color var(--t-fast);}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);font-weight:700;line-height:1.2;color:var(--c-text);}
input,select,textarea{font-family:inherit;}

/* ============================================================
   UTILITIES
   ============================================================ */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--sp-8);}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;}
.grad-text{background:var(--c-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:13px 30px;border-radius:var(--r-full);
  font-size:.95rem;font-weight:600;line-height:1;
  transition:all var(--t-base);cursor:pointer;border:2px solid transparent;
  white-space:nowrap;text-decoration:none;letter-spacing:.01em;
}
.btn:focus-visible{outline:3px solid var(--c-primary-light);outline-offset:3px;}

.btn-primary{background:var(--c-grad);color:#fff;box-shadow:0 4px 20px var(--c-primary-20);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--c-primary-20);filter:brightness(1.08);color:#fff;}
.btn-primary:active{transform:translateY(0);}

.btn-secondary{background:var(--c-white);color:var(--c-primary);border-color:var(--c-primary);box-shadow:var(--shadow-sm);}
.btn-secondary:hover{background:var(--c-primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-p);}

.btn-ghost{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.35);backdrop-filter:blur(4px);}
.btn-ghost:hover{background:rgba(255,255,255,.25);color:#fff;transform:translateY(-2px);}

.btn-white{background:#fff;color:var(--c-primary);box-shadow:var(--shadow-md);}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:var(--c-primary-dark);}

.btn-lg{padding:16px 40px;font-size:1.05rem;}
.btn-sm{padding:9px 20px;font-size:.85rem;}

.btn-group{display:flex;flex-wrap:wrap;gap:var(--sp-3);align-items:center;}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section-wrap{padding:var(--sp-20) 0;}
.section-head{text-align:center;margin-bottom:var(--sp-12);}
.section-tag{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:var(--c-primary-10);color:var(--c-primary);
  padding:5px 16px;border-radius:var(--r-full);
  font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:var(--sp-4);border:1px solid var(--c-primary-20);
}
.section-title{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;margin-bottom:var(--sp-4);}
.section-sub{font-size:1.05rem;color:var(--c-text-2);max-width:580px;margin:0 auto;}

/* ============================================================
   HEADER
   ============================================================ */
#masthead{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--c-border);
  box-shadow:0 1px 0 rgba(0,0,0,.04);
  transition:box-shadow var(--t-base);
}
#masthead.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.1);}
.hdr-inner{display:flex;align-items:center;height:var(--header-h);gap:var(--sp-8);}

/* Logo */
.site-logo{display:flex;align-items:center;flex-shrink:0;}
.site-logo img{height:42px;width:auto;}
.site-logo__text{
  font-size:1.25rem;font-weight:800;
  background:var(--c-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* Nav */
.site-nav{flex:1;display:flex;justify-content:center;}
.site-nav ul{display:flex;align-items:center;gap:var(--sp-1);}
.site-nav a{
  display:block;padding:7px 13px;font-size:.88rem;font-weight:500;
  color:var(--c-text-2);border-radius:var(--r-sm);transition:all var(--t-fast);
}
.site-nav a:hover,.site-nav .current-menu-item>a{color:var(--c-primary);background:var(--c-primary-10);}

/* Header right */
.hdr-right{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0;}

/* Hamburger */
.hbg{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;border-radius:var(--r-sm);}
.hbg span{display:block;width:22px;height:2px;background:var(--c-text);border-radius:2px;transition:all var(--t-base);}
.hbg.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hbg.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hbg.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile drawer */
.mob-nav{
  position:fixed;inset:var(--header-h) 0 0 0;
  background:var(--c-white);z-index:999;
  padding:var(--sp-8);overflow-y:auto;
  display:flex;flex-direction:column;gap:var(--sp-2);
  transform:translateX(100%);transition:transform var(--t-slow);
}
.mob-nav.open{transform:translateX(0);}
.mob-nav a{
  display:block;padding:14px var(--sp-4);font-size:1.1rem;font-weight:600;
  color:var(--c-text);border-radius:var(--r-md);border-bottom:1px solid var(--c-border);
  transition:all var(--t-fast);
}
.mob-nav a:hover{color:var(--c-primary);background:var(--c-primary-10);border-bottom-color:transparent;}
.mob-nav .btn-primary{margin-top:var(--sp-6);justify-content:center;}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;overflow:hidden;
  background:var(--c-bg);
  padding:var(--sp-20) 0 var(--sp-16);
}
/* Editable BG image */
.hero__bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  transition:opacity var(--t-base);
}
.hero__bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(255,255,255,.95) 50%,rgba(255,255,255,.5) 100%);
}
/* Decorative blobs */
.hero::before{
  content:'';position:absolute;top:-120px;right:-80px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,var(--c-primary-10) 0%,transparent 70%);
  pointer-events:none;z-index:1;
}
.hero__inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-16);align-items:center;
}
.hero__badge{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:var(--c-grad);color:#fff;
  padding:6px 18px;border-radius:var(--r-full);
  font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:var(--sp-6);box-shadow:var(--shadow-p);
}
.hero__title{
  font-size:clamp(2rem,4.5vw,3.4rem);font-weight:800;line-height:1.12;
  margin-bottom:var(--sp-6);
}
.hero__desc{font-size:1.05rem;color:var(--c-text-2);margin-bottom:var(--sp-10);max-width:520px;line-height:1.8;}
.hero__stats{
  display:flex;gap:var(--sp-10);margin-top:var(--sp-10);
  padding-top:var(--sp-8);border-top:1px solid var(--c-border);
}
.hero__stat-num{
  font-size:1.9rem;font-weight:800;
  background:var(--c-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero__stat-lbl{font-size:.82rem;color:var(--c-text-3);margin-top:2px;}

/* Hero visual – editable image */
.hero__visual{position:relative;display:flex;align-items:center;justify-content:center;}
.hero__img-wrap{
  position:relative;width:100%;max-width:480px;
  border-radius:var(--r-2xl);overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero__img-wrap img{width:100%;height:380px;object-fit:cover;display:block;}
.hero__img-placeholder{
  width:100%;height:380px;
  background:linear-gradient(135deg,var(--c-primary-10),var(--c-secondary-10));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:var(--sp-4);
}
.hero__img-placeholder span{font-size:5rem;}
.hero__img-placeholder p{font-size:.85rem;color:var(--c-text-2);}

/* Floating badge cards */
.hero__float{
  position:absolute;background:#fff;border-radius:var(--r-lg);
  padding:var(--sp-3) var(--sp-5);box-shadow:var(--shadow-md);
  display:flex;align-items:center;gap:var(--sp-3);
  font-size:.85rem;font-weight:600;animation:floatIn .7s ease backwards;
}
.hero__float--a{bottom:15%;left:-14%;animation-delay:.3s;}
.hero__float--b{top:10%;right:-14%;animation-delay:.5s;}
.hero__float-icon{font-size:1.6rem;}
.hero__float-val{color:var(--c-primary);font-size:1.1rem;font-weight:800;display:block;}
@keyframes floatIn{from{opacity:0;transform:translateY(16px) scale(.9);}to{opacity:1;transform:none;}}

/* ============================================================
   TRUST BAR
   ============================================================ */
.trust-bar{background:var(--c-dark);padding:var(--sp-5) 0;}
.trust-bar__row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--sp-10);}
.trust-bar__item{
  display:flex;align-items:center;gap:var(--sp-2);
  font-size:.82rem;font-weight:500;color:rgba(255,255,255,.65);
}
.trust-bar__item em{color:rgba(255,255,255,.35);font-style:normal;margin:0 var(--sp-5);}

/* ============================================================
   CATEGORY SECTION
   ============================================================ */
.cat-section {
  padding: 64px 0 72px;
  background: var(--c-white);
}
.cat-section + .cat-section {
  border-top: 1px solid var(--c-border);
}

/* Category heading row */
.cat-head {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 40px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--c-border);
}
.cat-head__icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: var(--c-grad);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  flex-shrink: 0;
  box-shadow: var(--shadow-p);
}
.cat-head__title {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 800;
  line-height: 1.2;
}

/* SERVICE CARDS GRID */
.srv-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-5);
}

/* Service card */
.srv-card{
  background:var(--c-bg-card);border-radius:var(--r-lg);
  border:1.5px solid var(--c-border);
  overflow:hidden;transition:all var(--t-base);
  display:flex;flex-direction:column;
  position:relative;
}
.srv-card::after{
  content:'';position:absolute;inset:0;
  background:var(--c-grad);opacity:0;
  transition:opacity var(--t-base);border-radius:var(--r-lg);pointer-events:none;z-index:0;
}
.srv-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-p);border-color:transparent;}
.srv-card:hover::after{opacity:1;}
.srv-card:hover .srv-card__body,
.srv-card:hover .srv-card__title,
.srv-card:hover .srv-card__desc,
.srv-card:hover .srv-card__emoji{color:#fff !important;-webkit-text-fill-color:#fff !important;}
.srv-card:hover .srv-card__btn{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.5);color:#fff;box-shadow:none;}

/* Image inside card */
.srv-card__img{
  width:100%;height:180px;object-fit:cover;
  display:block;position:relative;z-index:1;
  transition:transform var(--t-slow);
}
.srv-card:hover .srv-card__img{transform:scale(1.04);}
.srv-card__img-wrap{overflow:hidden;position:relative;z-index:1;}
.srv-card__emoji-wrap{
  height:120px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--c-primary-10),var(--c-secondary-10));
  position:relative;z-index:1;
}
.srv-card__emoji{font-size:3.5rem;transition:all var(--t-base);}

.srv-card__body{
  padding:var(--sp-5) var(--sp-6) var(--sp-6);
  display:flex;flex-direction:column;gap:var(--sp-3);flex:1;
  position:relative;z-index:1;
}
.srv-card__title{
  font-size:1.05rem;font-weight:700;
  background:var(--c-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  transition:all var(--t-base);
}
.srv-card__desc{font-size:.88rem;color:var(--c-text-2);flex:1;line-height:1.65;transition:color var(--t-base);}
.srv-card__btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 20px;border-radius:var(--r-full);
  font-size:.85rem;font-weight:600;
  background:var(--c-grad);color:#fff;
  box-shadow:0 4px 14px var(--c-primary-20);
  transition:all var(--t-base);border:2px solid transparent;
  align-self:flex-start;
}
.srv-card__btn:hover{transform:translateY(-2px);filter:brightness(1.08);color:#fff;}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-band{padding:var(--sp-16) 0;background:var(--c-bg);}
.cta-band__inner{
  background:var(--c-grad);border-radius:var(--r-2xl);
  padding:var(--sp-12) var(--sp-16);
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-8);
  position:relative;overflow:hidden;
}
.cta-band__inner::before{
  content:'';position:absolute;top:-60%;right:-5%;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 65%);pointer-events:none;
}
.cta-band__inner::after{
  content:'';position:absolute;bottom:-80%;left:5%;
  width:350px;height:350px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.07) 0%,transparent 65%);pointer-events:none;
}
.cta-band__content{position:relative;z-index:1;}
.cta-band__title{font-size:clamp(1.2rem,2.5vw,1.7rem);font-weight:800;color:#fff;margin-bottom:var(--sp-2);}
.cta-band__sub{color:rgba(255,255,255,.8);font-size:1rem;}
.cta-band__cta{position:relative;z-index:1;flex-shrink:0;}

/* ============================================================
   MAGAZINE GRID
   ============================================================ */
.mag-section{padding:var(--sp-20) 0;background:var(--c-bg);}
.mag-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);}

.mag-card{
  background:var(--c-white);border-radius:var(--r-lg);
  border:1.5px solid var(--c-border);overflow:hidden;
  display:flex;flex-direction:column;
  transition:all var(--t-base);
}
.mag-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--c-primary);}
.mag-card__img-wrap{position:relative;overflow:hidden;}
.mag-card__img{width:100%;height:200px;object-fit:cover;display:block;transition:transform var(--t-slow);}
.mag-card:hover .mag-card__img{transform:scale(1.05);}
.mag-card__img-placeholder{
  height:200px;background:linear-gradient(135deg,var(--c-primary-10),var(--c-secondary-10));
  display:flex;align-items:center;justify-content:center;font-size:3.5rem;
}
.mag-card__cat{
  position:absolute;top:var(--sp-4);left:var(--sp-4);
  background:var(--c-grad);color:#fff;
  padding:4px 12px;border-radius:var(--r-full);font-size:.72rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
}
.mag-card__body{padding:var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-3);flex:1;}
.mag-card__title{font-size:1.05rem;font-weight:700;line-height:1.4;color:var(--c-text);}
.mag-card__title a{color:inherit;}
.mag-card__title a:hover{color:var(--c-primary);}
.mag-card__excerpt{font-size:.88rem;color:var(--c-text-2);line-height:1.7;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.mag-card__read{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  font-size:.85rem;font-weight:600;color:var(--c-primary);
  margin-top:var(--sp-2);transition:gap var(--t-fast);
}
.mag-card__read:hover{gap:var(--sp-3);color:var(--c-primary-dark);}

/* ============================================================
   INSURERS LOGOS
   ============================================================ */
.logos-section{padding:var(--sp-16) 0;background:var(--c-white);border-top:1px solid var(--c-border);}
.logos-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4);
}
.logo-card{
  background:var(--c-bg);border-radius:var(--r-md);
  padding:var(--sp-5);border:1.5px solid var(--c-border);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-2);
  min-height:100px;transition:all var(--t-base);
}
.logo-card:hover{border-color:var(--c-primary);box-shadow:var(--shadow-p);transform:translateY(-3px);background:var(--c-white);}
.logo-card img{max-height:50px;max-width:120px;width:auto;object-fit:contain;filter:grayscale(30%);transition:filter var(--t-base);}
.logo-card:hover img{filter:grayscale(0%);}
.logo-card__name{font-size:.75rem;font-weight:600;color:var(--c-text-3);text-align:center;line-height:1.3;}

/* ============================================================
   ACCORDION
   ============================================================ */
.acc-section{padding:var(--sp-20) 0;background:var(--c-bg);}
.acc-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);max-width:1000px;margin:0 auto;}

.acc-item{
  background:var(--c-white);border-radius:var(--r-lg);
  border:1.5px solid var(--c-border);overflow:hidden;
  transition:border-color var(--t-base),box-shadow var(--t-base);
}
.acc-item.open{border-color:var(--c-primary);box-shadow:var(--shadow-p);}
.acc-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--sp-5) var(--sp-6);cursor:pointer;gap:var(--sp-4);
  transition:background var(--t-fast);
}
.acc-hdr:hover{background:var(--c-bg);}
.acc-title{font-size:.98rem;font-weight:600;color:var(--c-text);}
.acc-icon{
  width:30px;height:30px;border-radius:var(--r-full);flex-shrink:0;
  background:var(--c-grad);display:flex;align-items:center;justify-content:center;
  transition:transform var(--t-base);
}
.acc-icon svg{width:14px;height:14px;fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round;transition:transform var(--t-base);}
.acc-item.open .acc-icon{transform:rotate(45deg);}
.acc-body{
  display:none;padding:0 var(--sp-6) var(--sp-6);
  border-top:1px solid var(--c-border);
}
.acc-item.open .acc-body{display:block;}
.acc-body a{
  display:block;padding:7px 0;font-size:.88rem;font-weight:500;
  color:var(--c-text-2);border-bottom:1px solid var(--c-bg);
  transition:all var(--t-fast);
}
.acc-body a:last-child{border-bottom:none;}
.acc-body a:hover{color:var(--c-primary);padding-left:8px;}

/* ============================================================
   FEATURES / WHY US
   ============================================================ */
.feat-section{padding:var(--sp-20) 0;background:var(--c-white);}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);}
.feat-card{
  padding:var(--sp-8);border-radius:var(--r-lg);
  border:1.5px solid var(--c-border);background:var(--c-white);
  transition:all var(--t-base);
}
.feat-card:hover{border-color:var(--c-primary);transform:translateY(-4px);box-shadow:var(--shadow-p);}
.feat-icon{
  width:58px;height:58px;border-radius:var(--r-md);
  background:var(--c-grad);
  display:flex;align-items:center;justify-content:center;
  font-size:1.7rem;margin-bottom:var(--sp-5);
  box-shadow:var(--shadow-p);
}
.feat-title{font-size:1.1rem;font-weight:700;margin-bottom:var(--sp-3);}
.feat-desc{font-size:.9rem;color:var(--c-text-2);line-height:1.75;}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-section{padding:var(--sp-20) 0;background:var(--c-bg);}
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-6);}
.testi-card{
  background:var(--c-white);border-radius:var(--r-lg);padding:var(--sp-8);
  border:1.5px solid var(--c-border);display:flex;gap:var(--sp-5);align-items:flex-start;
  transition:all var(--t-base);
}
.testi-card:hover{border-color:var(--c-primary);box-shadow:var(--shadow-p);}
.testi-avatar{
  width:72px;height:72px;border-radius:var(--r-full);object-fit:cover;
  flex-shrink:0;border:3px solid var(--c-primary);
}
.testi-avatar-placeholder{
  width:72px;height:72px;border-radius:var(--r-full);flex-shrink:0;
  background:var(--c-grad);display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;border:3px solid var(--c-white);box-shadow:var(--shadow-p);
}
.testi-name{font-size:.95rem;font-weight:700;margin-bottom:4px;}
.testi-stars{color:var(--c-accent);font-size:.85rem;letter-spacing:2px;margin-bottom:var(--sp-3);}
.testi-text{font-size:.92rem;color:var(--c-text-2);line-height:1.7;font-style:italic;}
.testi-text::before{content:'\201E';}
.testi-text::after{content:'\201C';}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final-cta{
  padding:var(--sp-20) 0;text-align:center;
  background:var(--c-grad);position:relative;overflow:hidden;
}
.final-cta::before,.final-cta::after{
  content:'';position:absolute;border-radius:50%;pointer-events:none;
}
.final-cta::before{top:-40%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 65%);}
.final-cta::after{bottom:-50%;left:-5%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 65%);}
.final-cta__inner{position:relative;z-index:1;}
.final-cta__title{font-size:clamp(1.5rem,3.5vw,2.3rem);font-weight:800;color:#fff;margin-bottom:var(--sp-4);}
.final-cta__sub{color:rgba(255,255,255,.8);font-size:1.05rem;margin-bottom:var(--sp-10);}
.final-cta .btn-group{justify-content:center;}

/* ============================================================
   CONTACT SECTION
   ============================================================ */
.contact-section{padding:var(--sp-20) 0;background:var(--c-white);text-align:center;}
.contact-wrap{
  background:var(--c-bg);border-radius:var(--r-2xl);
  padding:var(--sp-12) var(--sp-16);max-width:720px;margin:0 auto;
  border:1.5px solid var(--c-border);
}
.contact-wrap h2{font-size:1.5rem;margin-bottom:var(--sp-8);}
.form-group{margin-bottom:var(--sp-5);}
.form-label{display:block;font-size:.88rem;font-weight:600;margin-bottom:var(--sp-2);color:var(--c-text);}
.form-control{
  width:100%;padding:13px 18px;border-radius:var(--r-md);
  border:1.5px solid var(--c-border);background:var(--c-white);
  font-size:.95rem;color:var(--c-text);outline:none;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.form-control:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-10);}
textarea.form-control{min-height:130px;resize:vertical;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);}

/* ============================================================
   SIDEBAR
   ============================================================ */
.widget{
  background:var(--c-bg);border-radius:var(--r-lg);
  padding:var(--sp-6);margin-bottom:var(--sp-5);
  border:1.5px solid var(--c-border);
}
.widget-title{font-size:.95rem;font-weight:700;margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:2px solid var(--c-primary);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: var(--c-dark);
  font-size: .88rem;
  line-height: 1.6;
}

/* Top area */
.footer-top {
  padding: 64px 0 48px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  align-items: start;
}

/* Brand column */
.footer-brand { }
.footer-logo-img {
  height: 40px;
  width: auto;
  display: block;
  margin-bottom: 20px;
  filter: brightness(8) saturate(0);
  opacity: .9;
}
.footer-logo-text {
  display: inline-block;
  font-size: 1.3rem;
  font-weight: 800;
  margin-bottom: 20px;
  background: var(--c-grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.footer-desc {
  color: rgba(255,255,255,.4);
  font-size: .85rem;
  line-height: 1.75;
  max-width: 250px;
  margin-bottom: 24px;
}
.footer-social {
  display: flex;
  gap: 8px;
}
.footer-social-link {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.55);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--t-fast);
  border: 1px solid rgba(255,255,255,.06);
}
.footer-social-link:hover {
  background: var(--c-grad);
  color: #fff;
  border-color: transparent;
}

/* Nav columns */
.footer-nav-col { }
.footer-nav-heading {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.22);
  margin: 0 0 20px 0;
  padding: 0;
}
.footer-nav-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.footer-nav-list li {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.footer-nav-list a {
  color: rgba(255,255,255,.45);
  font-size: .86rem;
  display: block;
  padding: 4px 0;
  transition: all var(--t-fast);
  text-decoration: none;
}
.footer-nav-list a:hover {
  color: var(--c-primary-light);
  padding-left: 6px;
}

/* Bottom bar */
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.07);
  padding: 20px 0;
}
.footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.footer-copy {
  font-size: .78rem;
  color: rgba(255,255,255,.25);
  line-height: 1.6;
  margin: 0;
}
.footer-legal {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}
.footer-legal a {
  font-size: .78rem;
  color: rgba(255,255,255,.25);
  transition: color var(--t-fast);
  text-decoration: none;
}
.footer-legal a:hover {
  color: var(--c-primary-light);
}

/* ============================================================
   PAGE LAYOUTS
   ============================================================ */
.page-hero{
  background:linear-gradient(135deg,var(--c-bg) 0%,var(--c-white) 100%);
  padding:var(--sp-16) 0 var(--sp-10);border-bottom:1px solid var(--c-border);
}
.page-hero__breadcrumb{font-size:.82rem;color:var(--c-text-3);margin-bottom:var(--sp-4);}
.page-hero__breadcrumb a{color:var(--c-primary);}
.page-hero__breadcrumb a:hover{text-decoration:underline;}
.page-hero__title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;margin-bottom:var(--sp-4);}
.page-hero__excerpt{font-size:1.05rem;color:var(--c-text-2);max-width:600px;}

.page-layout{display:grid;grid-template-columns:1fr 320px;gap:var(--sp-12);padding:var(--sp-12) 0 var(--sp-20);}
.page-layout--full{grid-template-columns:1fr;}

.entry-content h2{font-size:1.55rem;font-weight:700;margin:var(--sp-8) 0 var(--sp-4);}
.entry-content h3{font-size:1.25rem;font-weight:700;margin:var(--sp-6) 0 var(--sp-3);}
.entry-content p{color:var(--c-text-2);line-height:1.85;margin-bottom:var(--sp-5);}
.entry-content ul,.entry-content ol{margin:var(--sp-4) 0 var(--sp-5) var(--sp-6);}
.entry-content li{color:var(--c-text-2);margin-bottom:var(--sp-2);}
.entry-content a{color:var(--c-primary);}
.entry-content a:hover{text-decoration:underline;}
.entry-content strong{color:var(--c-text);}
.entry-content img{border-radius:var(--r-lg);margin:var(--sp-6) 0;}

/* ============================================================
   SCROLL TOP + ANIMATIONS
   ============================================================ */
.scroll-top-btn{
  position:fixed;bottom:28px;right:28px;z-index:998;
  width:46px;height:46px;border-radius:var(--r-full);
  background:var(--c-grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);cursor:pointer;border:none;
  opacity:0;transform:translateY(16px);transition:all var(--t-base);font-size:1.1rem;
}
.scroll-top-btn.show{opacity:1;transform:translateY(0);}
.scroll-top-btn:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}

.fade-up{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease;}
.fade-up.in{opacity:1;transform:none;}
.fade-up:nth-child(2){transition-delay:.1s;}
.fade-up:nth-child(3){transition-delay:.2s;}
.fade-up:nth-child(4){transition-delay:.3s;}
.fade-up:nth-child(5){transition-delay:.4s;}
.fade-up:nth-child(6){transition-delay:.5s;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .srv-grid{grid-template-columns:repeat(2,1fr);}
  .hero__inner{grid-template-columns:1fr;}
  .hero__visual{display:none;}
}
@media(max-width:900px){
  .mag-grid{grid-template-columns:repeat(2,1fr);}
  .logos-grid{grid-template-columns:repeat(3,1fr);}
  .page-layout{grid-template-columns:1fr;}
  .feat-grid{grid-template-columns:repeat(2,1fr);}
  .acc-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  :root{--sp-20:60px;}
  .site-nav,.hdr-right .btn-primary{display:none;}
  .hbg{display:flex;}
  .cta-band__inner{flex-direction:column;text-align:center;padding:var(--sp-10);}
  .testi-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:40px;}
  .footer-desc{max-width:100%;}
  .footer-bottom-inner{flex-direction:column;text-align:center;}
  .form-grid{grid-template-columns:1fr;}
  .contact-wrap{padding:var(--sp-8);}
}
@media(max-width:580px){
  .logos-grid{grid-template-columns:repeat(2,1fr);}
  .mag-grid{grid-template-columns:1fr;}
  .srv-grid{grid-template-columns:1fr;}
  .feat-grid{grid-template-columns:1fr;}
  .hero__stats{flex-wrap:wrap;gap:var(--sp-6);}
  .footer-legal{flex-direction:column;align-items:center;gap:8px;}
}
@media print{
  #masthead,.scroll-top-btn,.mob-nav{display:none!important;}
}
