
  :root{
    /* Brand palette matched to logo */
    --brand-blue: #2B8CCE;
    --brand-blue-deep: #1B6FA6;
    --brand-blue-dark: #0F4C7A;
    --brand-blue-soft: #DFF0FB;
    --brand-green: #7CBF3E;
    --brand-green-deep: #5A9A24;
    --brand-green-soft: #E8F5D8;

    /* Neutrals */
    --cream: #F7FAFC;
    --cream-2: #EBF3F8;
    --white: #FFFFFF;
    --ink: #0E2231;
    --ink-soft: #243645;
    --muted: #5A6B78;
    --line: rgba(14,34,49,0.10);
    --line-strong: rgba(14,34,49,0.22);

    /* Tokens */
    --r-sm: 6px;
    --r-md: 12px;
    --r-lg: 20px;
    --r-xl: 28px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family: 'Outfit', sans-serif;
    font-weight: 400;
    background: var(--cream);
    color: var(--ink);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
  }
  
  .logowidth {
	  max-width:200px
  }
  
  @media (max-width: 960px){
    .logowidth {
		max-width: 150px;
		margin-left: 10px;
	}
  }
  
  
  .serif{font-family:'Fraunces', serif; font-optical-sizing: auto;}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%;height:auto}
  button{font-family: inherit; cursor: pointer;}

  /* ===== REVEAL-ON-SCROLL ===== */
  .reveal{opacity:0; transform: translateY(24px); transition: opacity .9s ease, transform .9s cubic-bezier(.2,.8,.2,1);}
  .reveal.in{opacity:1; transform:none;}

  /* ===== TOP BAR ===== */
  .topbar{
    background: var(--brand-blue-dark);
    color: var(--white);
    font-size: 13px;
    padding: 10px 0;
    letter-spacing: 0.02em;
  }
  .topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
  .topbar a{opacity:.85;transition:opacity .2s}
  .topbar a:hover{opacity:1}
  .topbar .dot{width:6px;height:6px;border-radius:50%;background:var(--brand-green);display:inline-block;margin-right:8px;vertical-align:middle;box-shadow:0 0 0 3px rgba(124,191,62,0.25)}

  .container{max-width:1280px;margin:0 auto;padding:0 28px}

  /* ===== NAV ===== */
  .nav{
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(247,250,252,0.85);
    backdrop-filter: blur(16px) saturate(140%);
    -webkit-backdrop-filter: blur(16px) saturate(140%);
    border-bottom: 1px solid var(--line);
  }
  .nav-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding: 16px 0;
  }
  /* Logo: SVG-based replica of the brand mark */
  .logo-link{display:flex;align-items:center;gap:14px;}
  .logo-mark{
    width: 44px; height: 44px;
    flex-shrink: 0;
  }
  .logo-text{
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 26px;
    color: var(--brand-blue-deep);
    line-height: 1;
    letter-spacing: -0.01em;
  }
  .logo-text small{
    display: block;
    font-family: 'Outfit', sans-serif;
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--brand-green-deep);
    font-weight: 500;
    margin-top: 5px;
  }
  .nav-links{
    display:flex;gap:36px;list-style:none;
  }
  .nav-links a{
    font-size:16px;
    letter-spacing:0.02em;
    position:relative;
    padding:4px 0;
    color: var(--ink);
    font-weight: 500;
    transition: color .2s;
  }
  .nav-links a::after{
    content:'';
    position:absolute;
    left:0;bottom:-2px;
    width:0;height:2px;
    background:var(--brand-green);
    transition:width .3s ease;
  }
  .nav-links a:hover{color:var(--brand-blue-deep)}
  .nav-links a:hover::after{width:100%}
  .nav-cta{
    background: var(--brand-blue);
    color: var(--white);
    padding: 12px 22px;
    border-radius: 100px;
    font-size: 16px;
    letter-spacing: 0.04em;
    font-weight: 500;
    transition: background .25s, transform .2s, box-shadow .25s;
    display:inline-flex;align-items:center;gap:8px;
    box-shadow: 0 8px 24px -10px rgba(43,140,206,0.55);
  }
  .nav-cta:hover{background:var(--brand-blue-deep);transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(43,140,206,0.7)}

  /* ===== HERO ===== */
  .hero{
    padding: 80px 0 80px;
    position:relative;
    overflow: hidden;
  }
  /* Decorative gradient blobs for modern feel */
  .hero::before{
    content:'';position:absolute;
    top: -120px; left: -120px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(43,140,206,0.18) 0%, transparent 70%);
    pointer-events:none;
    animation: floatBlob 14s ease-in-out infinite;
  }
  .hero::after{
    content:'';position:absolute;
    bottom: -150px; right: -100px;
    width: 420px; height: 420px;
    background: radial-gradient(circle, rgba(124,191,62,0.18) 0%, transparent 70%);
    pointer-events:none;
    animation: floatBlob 18s ease-in-out infinite reverse;
  }
  @keyframes floatBlob{
    0%,100%{transform: translate(0,0)}
    50%{transform: translate(40px,30px)}
  }
  .hero-grid{
    display:grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 80px;
    align-items:center;
    position: relative;
    z-index: 1;
  }
  .eyebrow{
    font-size:12px;
    letter-spacing:0.24em;
    text-transform:uppercase;
    color:var(--brand-green-deep);
    font-weight:600;
    display:inline-flex;align-items:center;gap:14px;
    margin-bottom: 28px;
    padding: 8px 16px 8px 12px;
    background: var(--brand-green-soft);
    border-radius: 100px;
  }
  .eyebrow::before{
    content:'';display:inline-block;width:6px;height:6px;background:var(--brand-green);border-radius:50%;
  }
  .hero h1{
    font-family:'Fraunces', serif;
    font-weight:400;
    font-size: clamp(44px, 6vw, 82px);
    line-height: 1.02;
    letter-spacing: -0.03em;
    color: var(--ink);
    margin-bottom: 32px;
  }
  .hero h1 em{
    font-style:italic;
    font-weight:400;
    color: var(--brand-blue);
    position: relative;
  }
  .hero-lead{
    font-size: 18px;
    color: var(--ink-soft);
    max-width: 520px;
    margin-bottom: 40px;
    line-height: 1.65;
  }
  .hero-actions{
    display:flex;gap:16px;align-items:center;flex-wrap:wrap;
  }
  .btn-primary{
    background: var(--brand-blue);
    color: var(--white);
    padding: 18px 32px;
    border-radius: 100px;
    font-size: 16px;
    letter-spacing: 0.04em;
    font-weight: 500;
    transition: background .25s, transform .2s, box-shadow .25s;
    display:inline-flex;align-items:center;gap:10px;
    box-shadow: 0 14px 30px -12px rgba(43,140,206,0.55);
    border: none;
  }
  .btn-primary:hover{background:var(--brand-blue-deep); transform:translateY(-2px); box-shadow:0 18px 38px -12px rgba(43,140,206,0.75);}
  .btn-primary svg{width:16px;height:16px;transition:transform .2s}
  .btn-primary:hover svg{transform:translateX(4px)}
  .btn-ghost{
    color:var(--ink);
    font-size: 16px;
    font-weight:500;
    display:inline-flex;align-items:center;gap:10px;
    padding: 18px 24px;
    border-radius: 100px;
    border: 1.5px solid var(--line-strong);
    background: rgba(255,255,255,0.5);
    transition: all .25s;
  }
  .btn-ghost:hover{color:var(--brand-blue-deep); border-color:var(--brand-blue); background:var(--white)}

  /* Trust row */
  .trust-row{
    display:flex;align-items:center;gap:24px;margin-top:48px;flex-wrap:wrap;
  }
  .trust-item{
    display:flex;align-items:center;gap:10px;
    font-size:16px;color:var(--ink-soft);
  }
  .trust-item .icon-wrap{
    width:36px;height:36px;border-radius:50%;
    background:var(--brand-blue-soft);
    display:flex;align-items:center;justify-content:center;
    color:var(--brand-blue-deep);
    font-weight:600;font-size:14px;
  }
  .stars-gold{color: #F3B724; font-size:14px; letter-spacing:1px;}

  .hero-visual{
    position:relative;
    aspect-ratio: 4/5;
  }
  .hero-visual .main-img{
    width:100%;height:100%;
    border-radius: 260px 260px 20px 20px;
    overflow:hidden;
    position:relative;
    box-shadow: 0 40px 100px -30px rgba(15,76,122,0.35);
  }
  .hero-visual .main-img img{
    width:100%;height:100%;object-fit:cover;
  }
  .hero-visual .overlay-card{
    position:absolute;
    left: -40px;
    bottom: 60px;
    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    padding: 22px 26px;
    border-radius: var(--r-lg);
    border:1px solid rgba(255,255,255,0.8);
    width: 240px;
    box-shadow: 0 20px 50px -15px rgba(15,76,122,0.25);
  }
  .overlay-card .label{
    font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
    color:var(--muted);margin-bottom:8px;font-weight:600;
  }
  .overlay-card .value{
    font-family:'Fraunces',serif;font-size:20px;color:var(--ink);line-height:1.25;font-weight:500;
  }
  .overlay-card .value small{
    font-size:13px;color:var(--muted);font-family:'Outfit';font-weight:400;display:block;margin-top:4px;
  }
  .hero-visual .badge{
    position:absolute;
    top:30px;right:-30px;
    width:150px;height:150px;
    border-radius:50%;
    background: var(--brand-green);
    color: var(--white);
    display:flex;align-items:center;justify-content:center;
    text-align:center;
    font-family:'Fraunces',serif;
    font-size:13px;line-height:1.3;
    padding: 20px;
    transform: rotate(-8deg);
    animation: spin 22s linear infinite;
    box-shadow: 0 16px 40px -10px rgba(90,154,36,0.5);
  }
  @keyframes spin {to { transform: rotate(352deg); }}
  .hero-visual .badge span{display:block;font-weight:500;}
  .hero-visual .badge .big{
    font-size:30px;font-style:italic;font-weight:400;margin: 3px 0;
  }

  /* ===== MARQUEE ===== */
  .marquee{
    padding: 24px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    background: var(--white);
    overflow:hidden;
    position:relative;
  }
  .marquee-track{
    display:flex;gap:56px;
    animation: marquee 40s linear infinite;
    white-space:nowrap;
    width:max-content;
  }
  .marquee-track span{
    font-family:'Fraunces',serif;
    font-style:italic;
    font-weight: 400;
    font-size: 22px;
    color: var(--brand-blue-deep);
    display:flex;align-items:center;gap:56px;
  }
  .marquee-track span::after{
    content:'';
    width:8px;height:8px;border-radius:50%;
    background: var(--brand-green);
  }
  @keyframes marquee{to{transform:translateX(-50%)}}

  /* ===== SECTION HEAD ===== */
  .section{padding: 120px 0;}
  .section-head{
    display:flex;justify-content:space-between;align-items:flex-end;gap:60px;
    margin-bottom: 72px;
  }
  .section-head h2{
    font-family:'Fraunces',serif;
    font-weight:400;
    font-size: clamp(36px, 4.5vw, 60px);
    line-height: 1.05;
    letter-spacing:-0.02em;
    color: var(--ink);
    max-width: 780px;
  }
  .section-head h2 em{font-style:italic;font-weight:400;color:var(--brand-blue)}
  .section-head .side{
    max-width:400px;font-size:16px;color:var(--ink-soft);
    padding-bottom: 8px;
  }

  /* ===== PILLARS ===== */
  .pillars{
	  background:linear-gradient(135deg, var(--brand-blue-dark) 0%, var(--brand-blue-deep) 60%, #0a3a5f 100%);
    color:var(--white);padding:140px 0;
    position:relative;overflow:hidden;
  }
  .pillars::before{
    content:'';position:absolute;
    top:-100px; right:-100px;
    width: 400px; height:400px;
    background: radial-gradient(circle, rgba(124,191,62,0.2) 0%, transparent 70%);
  }
  .pillars .eyebrow{color:var(--brand-green); background:rgba(124,191,62,0.12)}
  .pillars .eyebrow::before{background:var(--brand-green)}
  .pillars h2{color:var(--white)}
  .pillars h2 em{color:var(--brand-green)}
  .pillars .side{color:rgba(255,255,255,0.7)}
  .pillar-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:32px;
    position:relative;z-index:1;
  }
  .pillar{
    position:relative;
    border-radius: var(--r-xl);
    overflow:hidden;
    cursor:pointer;
    display: block;
  }
  .pillar img{
    width:100%;height:100%;object-fit:cover;
    transition: transform 1s ease;
  }
  .pillar:hover img{transform:scale(1.06)}
  .pillar-content{
    position:absolute;inset:0;
    background: linear-gradient(to top, rgba(14,34,49,0.88) 0%, rgba(14,34,49,0.3) 55%, rgba(14,34,49,0) 100%);
    padding: 40px;
    display:flex;flex-direction:column;justify-content:flex-end;
  }
  .pillar-num{
    position:absolute;top:32px;left:40px;
    font-family:'Fraunces',serif;font-style:italic;
    font-size:14px;color:var(--white);opacity:.8;
    letter-spacing:0.1em;
  }
  .pillar h3{
    font-family:'Fraunces',serif;
    font-weight:400;
    font-size: 44px;
    line-height:1;
    letter-spacing:-0.02em;
    margin-bottom: 16px;
  }
  .pillar p{
    color: rgba(255,255,255,0.9);
    margin-bottom: 28px;
    max-width: 420px;
    font-size: 16px;
    line-height: 1.6;
  }
  .pillar-link{
    display:inline-flex;align-items:center;gap:10px;
    font-size:16px;letter-spacing:0.08em;
    font-weight:500;
    padding: 14px 22px;
    border-radius: 100px;
    background: var(--brand-green);
    color: var(--white);
    align-self:flex-start;
    transition: background .25s, transform .2s;
  }
  .pillar-link:hover{background: var(--brand-green-deep); transform: translateY(-2px)}
  .pillar-link svg{width:14px;height:14px;transition:transform .2s}
  .pillar-link:hover svg{transform:translateX(3px)}

  /* ===== SERVICES LIST ===== */
  .services{background:var(--cream);}
  .service-tabs{
    display:inline-flex;
    background: var(--white);
    padding: 6px;
    border-radius: 100px;
    border: 1px solid var(--line);
    margin-bottom: 48px;
    box-shadow: 0 12px 30px -18px rgba(15,76,122,0.25);
    gap: 4px;
  }
  .tab{
    background:transparent;border:none;
    font-family:'Outfit',sans-serif;
    padding: 14px 28px;
    font-size: 16px;
    letter-spacing:0.02em;
    cursor:pointer;
    color: var(--muted);
    border-radius: 100px;
    font-weight:500;
    transition: all .25s ease;
    display:inline-flex;align-items:center;gap:10px;
    white-space: nowrap;
  }
  .tab .count{
    display: inline-flex;
    align-items: center; justify-content: center;
    min-width: 22px; height: 22px;
    padding: 0 7px;
    border-radius: 100px;
    background: var(--cream-2);
    color: var(--muted);
    font-size: 11px; font-weight: 600;
    transition: all .25s;
  }
  .tab:hover{color:var(--ink)}
  .tab.active{
    background: var(--brand-blue);
    color: var(--white);
    box-shadow: 0 10px 22px -8px rgba(43,140,206,0.55);
  }
  .tab.active .count{
    background: rgba(255,255,255,0.25);
    color: var(--white);
  }

/* === 3-column pillars (Fizjoterapia / Osteopatia / Fizjobeauty) === */
  .pillars .pillar-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .pillars .pillar{
    aspect-ratio: 3/4.2;
  }
  .pillars .pillar h3{
    font-size: 36px;
  }
  .pillars .pillar p{
    font-size: 14px;
  }
  @media (max-width: 960px){
    .pillars .pillar-grid{
      grid-template-columns: 1fr;
      gap: 20px;
    }
    .pillars .pillar{aspect-ratio: 4/5;}
    .pillars .pillar h3{font-size: 40px;}
  }

  /* === Osteopathy service list — indication chips === */
  .osteo-section{margin: 12px 0 40px;}
  .osteo-section:last-child{margin-bottom: 0}
  .osteo-section-head{
    display: flex; align-items: baseline; gap: 16px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(14,34,49,0.08);
  }
  .osteo-section-head h4{
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 20px;
    color: var(--ink, #0E2231);
    letter-spacing: -0.01em;
    margin: 0;
  }
  .osteo-section-head .count-pill{
    font-size: 11px;
    letter-spacing: 0.08em;
    background: #DFF0FB;
    color: #0F4C7A;
    padding: 3px 10px;
    border-radius: 100px;
    font-weight: 600;
  }
  .osteo-chips{
    display: flex; flex-wrap: wrap; gap: 8px;
  }
  .osteo-chip{
    display: inline-flex; align-items: center; gap: 8px;
    background: #F7FAFC;
    border: 1px solid rgba(14,34,49,0.10);
    color: #243645;
    font-size: 15px; font-weight: 500;
    padding: 9px 14px 9px 12px;
    border-radius: 100px;
    transition: background .2s, border-color .2s, transform .2s;
  }
  .osteo-chip:hover{
    background: #FFFFFF;
    border-color: #2B8CCE;
    transform: translateY(-1px);
  }
  .osteo-chip::before{
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #7CBF3E;
    flex-shrink: 0;
  }
  .osteo-chip.blue::before{background: #2B8CCE;}
  .osteo-row-intro{
    padding: 32px 32px 24px !important;
  }
  .osteo-row-intro .service-title{margin-bottom: 16px}
  .osteo-row-intro .service-desc{
    font-size: 15px;
    color: #243645;
    line-height: 1.7;
    max-width: 100%;
  }
  .osteo-row-intro .price-note{
    display: inline-flex; align-items: center; gap: 10px;
    margin-top: 18px;
    padding: 10px 16px;
    background: #E8F5D8;
    color: #5A9A24;
    border-radius: 100px;
    font-size: 13px; font-weight: 600;
    letter-spacing: 0.02em;
  }
  .osteo-row-intro .price-note::before{
    content: '';
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #7CBF3E;
  }


  .service-list{display:none;}
  .service-list.active{display:block;animation:fade .4s ease}
  @keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

  .service-row{
    display:grid;
    grid-template-columns: 60px 1.4fr 2fr;
    gap: 40px;
    align-items:flex-start;
    padding: 32px 32px;
    /* No padding-change on hover: fixed padding eliminates shift */
    border-bottom: 1px solid var(--line);
    border-radius: var(--r-lg);
    cursor:pointer;
    transition: background .25s ease, box-shadow .25s ease;
    position: relative;
  }
  .service-row:last-child{border-bottom: none}
  .service-row:hover{
    background: var(--white);
    box-shadow: 0 10px 40px -20px rgba(15,76,122,0.25);
    border-color: transparent;
  }
  .service-row:hover + .service-row{border-top-color: transparent}
  .service-num{
    font-family:'Fraunces',serif;
    font-style:italic;font-weight:400;
    font-size: 32px;
    color:var(--brand-blue);
    line-height:1;
    padding-top: 4px;
  }
  .service-title{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size: 26px;
    line-height: 1.2;
    letter-spacing:-0.01em;
    color: var(--ink);
    margin-bottom: 12px;
  }
  .service-desc{
    font-size: 16px;
    color: var(--ink-soft);
    line-height: 1.65;
  }
  .service-tags{
    display:flex;flex-wrap:wrap;gap:6px;
  }
  .tag{
    font-size: 13px;
    letter-spacing:0.04em;
    background: var(--brand-blue-soft);
    color: var(--brand-blue-deep);
    padding: 5px 11px;
    border-radius: 100px;
  }
  .tag.green{background:var(--brand-green-soft); color:var(--brand-green-deep)}
  .service-cta{
    align-self:center; justify-self: end;
  }
  .service-cta .arrow{
    display:inline-flex;
    width: 52px;height:52px;
    border-radius:50%;
    border: 1.5px solid var(--line-strong);
    align-items:center;justify-content:center;
    transition: all .3s;
    background: transparent;
  }
  .service-row:hover .arrow{
    background:var(--brand-blue);border-color:var(--brand-blue);
    box-shadow: 0 10px 22px -8px rgba(43,140,206,0.55);
  }
  .service-row:hover .arrow svg{stroke:var(--white);transform:translate(2px,-2px)}
  .arrow svg{width:18px;height:18px;stroke:var(--ink);transition:transform .3s, stroke .3s}

  /* ===== ABOUT ===== */
  .about{background:var(--white);position:relative;overflow:hidden;}
  .about-grid{
    display:grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 100px;
    align-items:center;
  }
  .about-visual{position:relative;}
  .about-visual .frame{
    border-radius: var(--r-xl);
    overflow:hidden;
    aspect-ratio: 3/4;
  }
  .about-visual .frame img{width:100%;height:100%;object-fit:cover}
  /* Deco circles behind image */
  .about-visual::before{
    content:'';position:absolute;
    top: -20px; left: -30px;
    width: 140px; height: 140px;
    border: 2px solid var(--brand-green);
    border-radius: 50%;
    opacity: 0.3;
  }
  .about-visual::after{
    content:'';position:absolute;
    bottom: 60px; right: -40px;
    width: 100px; height: 100px;
    background: var(--brand-blue-soft);
    border-radius: 50%;
    opacity: 0.6;
    z-index: -1;
  }
  .about-visual .quote-box{
    position:absolute;
    left: 37px;
	bottom: 40px;
    background: var(--brand-blue);
    color:var(--white);
    padding: 28px 32px;
    border-radius: var(--r-lg);
    max-width:280px;
    font-family:'Fraunces',serif;
    font-style:italic;
    font-size: 17px;
    line-height:1.45;
    font-weight: 400;
    box-shadow: 0 20px 40px -15px rgba(43,140,206,0.45);
  }
  .about-visual .quote-box::before{
    content:'"';
    font-size:72px;
    position:absolute;top:-16px;left:16px;
    color:var(--brand-green);
    font-weight:500;
    line-height:1;
  }
  .about-content h2{
    font-family:'Fraunces',serif;
    font-weight:400;
    font-size: clamp(34px, 4vw, 54px);
    line-height: 1.08;
    letter-spacing:-0.02em;
    margin: 24px 0 32px;
  }
  .about-content h2 em{font-style:italic;font-weight:400;color:var(--brand-blue)}
  .about-content p{
    font-size: 16px;color:var(--ink-soft);
    margin-bottom:20px;line-height:1.7;
  }
  .stats{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap: 40px;
    margin-top: 48px;
    padding-top: 40px;
    border-top: 1px solid var(--line);
  }
  .stat .num{
    font-family:'Fraunces',serif;
    font-weight: 400;
    font-size: 52px;
    color: var(--brand-blue);
    line-height:1;
    letter-spacing:-0.03em;
  }
  .stat .num em{font-style:italic;font-weight:400;color:var(--brand-green)}
  .stat .label{
    font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
    color: var(--muted);
    margin-top: 10px;
    font-weight: 600;
  }

  /* ===== PROCESS ===== */
  .process{background:var(--cream-2);padding: 140px 0;position:relative;overflow:hidden;}
  /* Connecting line behind numbered steps */
  .process-wrap{position:relative;}
  
  .process-list{
    display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
    position:relative; z-index: 1;
  }
  .process-step{
    border-radius: var(--r-lg);
    padding: 32px 28px;
    transition: transform .3s, box-shadow .3s, border-color .3s;
    position:relative;
  }
  .process-step:hover{
    transform: translateY(-6px);
    border-color: var(--brand-blue);
  }
  .step-num-wrap{
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--brand-blue);
    color: var(--white);
    display:flex;align-items:center;justify-content:center;
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size: 22px;
    margin-bottom: 24px;
    box-shadow: 0 10px 22px -8px rgba(43,140,206,0.55);
  }
  .process-step:nth-child(2) .step-num-wrap{background:var(--brand-green);box-shadow: 0 10px 22px -8px rgba(124,191,62,0.55)}
  .process-step:nth-child(3) .step-num-wrap{background:var(--brand-blue-deep);box-shadow: 0 10px 22px -8px rgba(27,111,166,0.55)}
  .process-step:nth-child(4) .step-num-wrap{background:var(--brand-green-deep);box-shadow: 0 10px 22px -8px rgba(90,154,36,0.55)}
  .step-title{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size: 22px;
    margin-bottom: 12px;
    color: var(--ink);
    letter-spacing: -0.01em;
  }
  .step-text{
    font-size:16px;color:var(--ink-soft);line-height:1.6;
  }

  /* ===== TESTIMONIALS / GOOGLE REVIEWS CAROUSEL ===== */
  .testimonials{
    background:linear-gradient(135deg, var(--brand-blue-dark) 0%, var(--brand-blue-deep) 60%, #0a3a5f 100%);
    color:var(--white);padding:140px 0;
    position:relative;overflow:hidden;
  }
  .testimonials::before{
    content:'';position:absolute;
    top:-100px; right:-100px;
    width: 400px; height:400px;
    background: radial-gradient(circle, rgba(124,191,62,0.2) 0%, transparent 70%);
  }
  .testimonials .eyebrow{color:var(--brand-green); background: rgba(124,191,62,0.12)}
  .testimonials .eyebrow::before{background:var(--brand-green)}
  .testimonials h2{color:var(--white)}
  .testimonials h2 em{color:var(--brand-green)}
  .testimonials .side{color:rgba(255,255,255,0.7)}

  .google-badge{
    display: inline-flex; align-items: center; gap: 14px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.15);
    padding: 12px 20px;
    border-radius: 100px;
    backdrop-filter: blur(8px);
    margin-top: 40px;
  }
  .google-badge .g-logo{
    width: 24px; height: 24px;
    flex-shrink: 0;
  }
  .google-badge .g-rating{
    display: flex; align-items: center; gap: 8px;
    font-size: 14px;
  }
  .google-badge .rating-num{
    font-family: 'Fraunces', serif;
    font-size: 20px; font-weight: 500;
    color: var(--white);
  }
  .google-badge .stars-gold{font-size:14px}
  .google-badge .count-text{
    color: rgba(255,255,255,0.75);
    font-size: 16px;
  }

  /* Carousel */
  .reviews-carousel{
    margin-top: 60px;
    position: relative;
    overflow: hidden;
    padding: 20px 0 20px;
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%);
            mask-image: linear-gradient(to right, transparent 0%, black 5%, black 95%, transparent 100%);
  }
  .reviews-track{
    display: flex;
    gap: 24px;
    width: max-content;
    animation: reviewScroll 50s linear infinite;
  }
  .reviews-carousel:hover .reviews-track{animation-play-state: paused}
  @keyframes reviewScroll{
    0%{transform: translateX(0)}
    100%{transform: translateX(calc(-50% - 12px))}
  }

  .review-card{
    width: 380px; flex-shrink: 0;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 32px 30px;
    border-radius: var(--r-xl);
    position:relative;
    transition: transform .3s, background .3s;
    display: flex; flex-direction: column;
  }
  .review-card:hover{
    background: rgba(255,255,255,0.12);
    transform: translateY(-4px);
  }
  .review-head{
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 18px;
  }
  .stars{color: #F3B724; font-size: 16px; letter-spacing: 2px;}
  .g-tag{
    font-size: 11px; color: rgba(255,255,255,0.6);
    display: inline-flex; align-items: center; gap: 6px;
    letter-spacing: 0.05em;
  }
  .g-tag svg{width: 14px; height: 14px}
  .review-text{
    font-size: 16px;
    line-height: 1.6;
    color: rgba(255,255,255,0.92);
    margin-bottom: 24px;
    flex: 1;
  }
  .review-author{
    display:flex;align-items:center;gap:14px;
    padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,0.12);
  }
  .avatar{
    width:42px;height:42px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-family:'Fraunces',serif;
    font-size:16px;color:var(--white);font-weight:500;
    flex-shrink:0;
  }
  .av-1{background: var(--brand-blue)}
  .av-2{background: var(--brand-green-deep)}
  .av-3{background: #D4795C}
  .av-4{background: var(--brand-blue-deep)}
  .av-5{background: var(--brand-green)}
  .av-6{background: #8B5CF6}
  .av-7{background: #E2A838}
  .av-8{background: #0EA5E9}
  .author-name{font-size:15px;font-weight:500;color:var(--white)}
  .author-role{font-size:14px;color:rgba(255,255,255,0.6);margin-top:2px}

  /* ===== CTA BOOKING ===== */
  .cta{
    padding: 140px 0;
    background: var(--cream);
    position:relative;
  }
  .cta-box{
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-blue-deep) 100%);
    color: var(--white);
    border-radius: var(--r-xl);
    padding: 80px 80px;
    display:grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 80px;
    align-items:center;
    position:relative;
    overflow:hidden;
    box-shadow: 0 40px 100px -40px rgba(27,111,166,0.55);
  }
  .cta-box::before{
    content:'';
    position:absolute;
    top:-120px;right:-120px;
    width: 400px;height: 400px;
    border-radius:50%;
    background: var(--brand-green);
    opacity:.18;
  }
  .cta-box::after{
    content:'';
    position:absolute;
    bottom:-80px;left:-80px;
    width: 260px;height: 260px;
    border-radius:50%;
    background: var(--white);
    opacity:.06;
  }
  .cta-box > *{position:relative; z-index: 1;}
  .cta-box .eyebrow{color:#FFF; background:rgba(124,191,62,0.18)}
  .cta-box .eyebrow::before{background:#FFF}
  .cta-box h2{
    font-family:'Fraunces',serif;
    font-weight:400;
    font-size: clamp(36px, 4vw, 52px);
    line-height:1.05;
    letter-spacing:-0.02em;
    margin-bottom: 24px;
    color:var(--white);
  }
  .cta-box h2 em{font-style:italic;font-weight:400;color:var(--brand-green)}
  .cta-box p{
    color: rgba(255,255,255,0.85);
    max-width: 440px;
    margin-bottom: 36px;
    font-size: 16px;
  }
  .cta-box .btn-primary{
    background: var(--brand-green);
    box-shadow: 0 14px 30px -10px rgba(124,191,62,0.55);
  }
  .cta-box .btn-primary:hover{background: var(--brand-green-deep); box-shadow:0 18px 38px -10px rgba(124,191,62,0.8)}
  .cta-phone{
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: var(--r-xl);
    padding: 40px;
    text-align:center;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  .cta-phone .label{
    font-size:16px;letter-spacing:0.22em;text-transform:uppercase;
    color: var(--brand-green);
    margin-bottom: 16px;
  }
  .cta-phone .number{
    font-family:'Fraunces',serif;
    font-weight:400;
    font-size: 42px;
    letter-spacing:-0.02em;
    color: var(--white);
    margin-bottom: 8px;
    display:block;
  }
  .cta-phone .hours{
    font-size:16px;color:rgba(255,255,255,0.75);
    margin-top:12px;line-height:1.6;
  }

  /* ===== VISIT / LOCATION ===== */
  .visit{background:var(--white);padding:120px 0;}
  .visit-grid{
    display:grid;grid-template-columns: 1fr 1fr;gap: 48px;align-items:stretch;
  }
  .visit-info{
    background: var(--cream);
    padding: 56px;
    border-radius: var(--r-xl);
    border: 1px solid var(--line);
    display: flex; flex-direction: column;
  }
  .visit-info h3{
    font-family:'Fraunces',serif;
    font-weight:400;
    font-size: 38px;
    line-height: 1.1;
    margin-bottom: 32px;
    letter-spacing: -0.02em;
  }
  .visit-info h3 em{font-style:italic;font-weight:400;color:var(--brand-blue)}
  .info-row{
    display:flex;gap:20px;
    padding: 22px 0;
    border-bottom: 1px solid var(--line);
    align-items: flex-start;
  }
  .info-row:last-child{border-bottom:none}
  .info-icon{
    width:46px;height:46px;
    border-radius: 14px;
    background: var(--brand-blue-soft);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
  }
  .info-icon svg{width:20px;height:20px;stroke:var(--brand-blue-deep)}
  .info-row:nth-child(3) .info-icon{background: var(--brand-green-soft);}
  .info-row:nth-child(3) .info-icon svg{stroke: var(--brand-green-deep);}
  .info-content .label{
    font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
    color: var(--muted);
    margin-bottom: 4px;
    font-weight:600;
  }
  .info-content .value{
    font-size: 16px;color:var(--ink);
    font-weight:500; line-height:1.4;
  }
  .info-content .value a:hover{color:var(--brand-blue-deep)}

  .map-wrap{
    border-radius: var(--r-xl);
    overflow:hidden;
    min-height: 500px;
    background: var(--brand-blue-dark);
    position:relative;
    box-shadow: 0 30px 60px -30px rgba(15,76,122,0.35);
  }
  .map-wrap iframe{width:100%;height:100%;border:0;display:block;min-height:500px;}

  /* ===== FOOTER ===== */
  footer{
    background: var(--ink);
    color: var(--white);
    padding: 80px 0 32px;
    position:relative;overflow:hidden;
  }
  footer::before{
    content:'';position:absolute;
    top:-100px; left:-100px;
    width:400px;height:400px;
    background: radial-gradient(circle, rgba(43,140,206,0.12) 0%, transparent 70%);
  }
  .foot-grid{
    display:grid;
    grid-template-columns: 1.3fr 1fr 1fr 1fr;
    gap: 60px;
    margin-bottom: 60px;
    padding-bottom: 48px;
    border-bottom: 1px solid rgba(255,255,255,0.12);
    position:relative;z-index:1;
  }
  .foot-col h4{
    font-family:'Outfit',sans-serif;
    font-size:14px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--brand-green);
    font-weight: 500;
    margin-bottom: 24px;
  }
  .foot-col ul{list-style:none}
  .foot-col li{margin-bottom:10px}
  .foot-col a, .foot-col li{
    font-size:15px;color:rgba(255,255,255,0.8);
    transition: color .2s;
  }
  .foot-col a:hover{color:var(--brand-green)}
  .foot-brand p{
    font-size:16px;color:rgba(255,255,255,0.7);line-height:1.6;
    max-width: 320px;margin-top: 20px;
  }
  .foot-bottom{
    display:flex;justify-content:space-between;align-items:center;
    font-size: 16px;
    color: rgba(255,255,255,0.55);
    flex-wrap:wrap;gap:20px;
    position:relative;z-index:1;
  }
  .foot-bottom a{color:rgba(255,255,255,0.7)}
  .foot-bottom a:hover{color:var(--brand-green)}

  /* ===== RESPONSIVE ===== */
  @media (max-width: 960px){
    .nav-links{display:none}
    .hero-grid, .pillar-grid, .about-grid, .visit-grid, .cta-box{
      grid-template-columns: 1fr;gap: 60px;
    }
    .hero{padding:48px 0}
    .section, .pillars, .process, .testimonials, .cta, .visit{padding: 80px 0}
    .section-head{flex-direction:column;align-items:flex-start;gap:24px;margin-bottom:48px}
    .process-list{grid-template-columns: 1fr 1fr}
    .process-wrap::before{display:none}
    .stats{grid-template-columns:1fr;gap:24px}
    .cta-box{padding: 48px 32px}
    .visit-info{padding:36px 28px}
    .service-row{grid-template-columns: 1fr;gap: 16px; padding: 24px}
    .service-cta{justify-self: start}
    .service-tabs{width: 100%; display: flex;}
    .tab{flex: 1; justify-content: center; padding: 14px 16px; font-size: 13px}
    .hero-visual .badge{right:10px;top:20px;width:120px;height:120px;font-size:12px}
    .hero-visual .overlay-card{left:0;bottom:-30px}
    .hero-visual .main-img{border-radius: 160px 160px 18px 18px}
    .container{padding:0 20px}
    .about-visual .quote-box{right:20px;max-width:220px}
    .review-card{width: 320px}
  }
  @media (max-width: 560px){
    .process-list{grid-template-columns:1fr}
    .nav-inner{padding:14px 0}
    .logo-mark{width:38px;height:38px}
    .logo-text{font-size:22px}
    .trust-row{gap:16px}
    .review-card{width: 290px; padding: 26px 22px}
    .service-tabs{flex-wrap: wrap}
  }
