/* Single Gotham Font */
@font-face {
font-display: swap;
font-family: 'Gotham';
font-weight: 100;
font-style: normal;
src: url("fonts/Gotham-Thin.woff2") format("woff2"),
url("fonts/Gotham-Thin.woff") format("woff"),
url("fonts/Gotham-Thin.ttf") format("truetype");
}
@font-face {
font-display: swap;
font-family: 'Gotham';
font-weight: 300;
font-style: normal;
src: url("fonts/Gotham-Light.woff2") format("woff2"),
url("fonts/Gotham-Light.woff") format("woff"),
url("fonts/Gotham-Light.ttf") format("truetype");
}
@font-face {
font-display: swap;
font-family: 'Gotham';
font-weight: 400;
font-style: normal;
src: url("fonts/Gotham-Book.woff2") format("woff2"),
url("fonts/Gotham-Book.woff") format("woff"),
url("fonts/Gotham-Book.ttf") format("truetype");
}
@font-face {
font-display: swap;
font-family: 'Gotham';
font-weight: 600;
font-style: normal;
src: url("fonts/Gotham-Medium.woff2") format("woff2"),
url("fonts/Gotham-Medium.woff") format("woff"),
url("fonts/Gotham-Medium.ttf") format("truetype");
}
@font-face {
font-display: swap;
font-family: 'Gotham-Book';
font-weight: 400;
font-style: normal;
src: url("fonts/Gotham-Medium.woff2") format("woff2"),
url("fonts/Gotham-Medium.woff") format("woff"),
url("fonts/Gotham-Medium.ttf") format("truetype");
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
 --bg: #ffffff;
--text: #0d1117;
--muted: #5d6875;
--line: #a6e9e7;
--teal: #009d9a;
--teal-bright: #3cc3c2;
--teal-soft: #bff0ef;
--black: #010608;
--shadow: 0 24px 50px rgba(12, 31, 46, 0.14);
--radius: 20px;

/* Material You — Google Blue seed */
--primary:                  #1a73e8;
--on-primary:               #ffffff;
--primary-container:        #d3e3fd;
--on-primary-container:     #041e49;
--secondary:                #5f6368;
--on-secondary:             #ffffff;
--secondary-container:      #e8eaed;
--on-secondary-container:   #1f1f1f;
--tertiary:                 #1e8e3e;
--tertiary-container:       #ceead6;
--on-tertiary-container:    #0d652d;
--error:                    #d93025;
--error-container:          #fce8e6;
--surface:                  #ffffff;
--surface-dim:              #f8f9fa;
--surface-container-lowest: #ffffff;
--surface-container-low:    #f1f3f4;
--surface-container:        #e8eaed;
--surface-container-high:   #dadce0;
--surface-container-highest:#c4c7c5;
--on-surface:               #1f1f1f;
--on-surface-variant:       #5f6368;
--outline:                  #dadce0;
--outline-variant:          #e8eaed;
--inverse-surface:          #303134;
--inverse-on-surface:       #e8eaed;

/* Google accent colours */
--google-blue:   #3cc3c2;
--google-red:    #ea4335;
--google-yellow: #fbbc04;
--google-green:  #267e7d;

/* Material elevation shadows */
--elevation-1: 0 1px 2px rgba(60,64,67,.3), 0 1px 3px 1px rgba(60,64,67,.15);
--elevation-2: 0 1px 2px rgba(60,64,67,.3), 0 2px 6px 2px rgba(60,64,67,.15);
--elevation-3: 0 4px 8px 3px rgba(60,64,67,.15), 0 1px 3px rgba(60,64,67,.3);

--radius-xs:   8px;
--radius-sm:   12px;
--radius-md:   16px;
--radius-lg:   28px;
--radius-full: 9999px;

--tc-blue:#3D86C6; /* Tata blue (from internal brand guidelines) */
  --ink:#0b1220;
  --muted:#5d6b85;
  --bg:#0a1020;
  --surface:#ffffff;
  --surface2:#f6f8fc;
  --line:#e6eaf2;
  --shadow:0 12px 28px rgba(11,18,32,.10);
  --shadow2:0 18px 44px rgba(11,18,32,.14);
  --radius:18px;
  --radius2:26px;
  --ok:#17b26a;
  --warn:#f79009;
  --bad:#f04438;
  --crit:#b42318;
  --info:#2e90fa;
  --focus:0 0 0 4px rgba(61,134,198,.18);

--nav-height: 64px;
--font:         'Gotham', sans-serif;
--font-display: 'Gotham Book', sans-serif;
--font-mono:    'Gotham', sans-serif;
}

html { scroll-behavior: smooth; }

body {
background: var(--surface);
color: var(--on-surface) !important;
font-family: var(--font) !important;
line-height: 1.6;
-webkit-font-smoothing: antialiased;
font-size: 14px;
overflow-x: hidden;
}

::selection { background: var(--primary-container); color: var(--on-primary-container); }

/* ─── SECTIONS ─── */
section { padding: 96px 24px; }
.wrap { 
max-width: 1292px;
margin: 0 auto;
}
.s-eyebrow {
font-size: 18px; 
color: var(--google-blue);
letter-spacing: 0.08em;
margin-bottom: 8px;
margin-bottom: 20px;
font-weight: 700;
line-height: 1.75;
}
.s-headline {
font-family: var(--font-display); 
color: var(--on-surface);
font-size: 40px;
font-weight: 400;
line-height: 1.4;
margin-bottom: 0.8rem;
}
.s-body {
font-size: 16px; color: var(--on-surface-variant);
max-width: 520px; line-height: 1.75; margin-bottom: 48px;
}

/* ════════════════════════════════════════
NAV — BASE
════════════════════════════════════════ */
nav#topnav {
position: fixed; top: 0; left: 0; right: 0; z-index: 200;
/*background: rgba(255,255,255,0.90);*/
backdrop-filter: blur(16px);
-webkit-backdrop-filter: blur(16px);
transition: box-shadow 0.2s;
background: rgba(0, 0, 0, 0.8);
}
nav#topnav.scrolled { box-shadow: var(--elevation-1);border-bottom: 2px solid rgba(238, 238, 238, 0.2); }

/* Row that contains logo, desktop links, burger */
.nav-top-row {
display: flex;
align-items: center;
height: var(--nav-height);
padding: 0 24px;
margin: 0 auto;
border-bottom: 2px solid rgba(238, 238, 238, 0.2);
}
nav#topnav.scrolled .nav-top-row {
    border: none;
}

/* Logo */
.nav-logo {
margin-right: auto;
display: flex;
align-items: center;
gap: 20px;
}
.nav-logo a {
display: flex;
align-items: center;
gap: 12px;
text-decoration: none;
}
.nav-logo-img {
display: block;
max-height: 32px;
width: auto;
}
.nav-logo-izo {
display: block;
width: 150px;
}

nav#topnav.scrolled .nav-logo {
    width: 0;
    height: 0;
    opacity: 0;
    display: none;
}
nav#topnav.scrolled .nav-links {
    margin: 0 auto;
}
nav#topnav.scrolled .nav-links li.active {
       position: relative;
}
nav#topnav.scrolled .nav-links li.active:after {
           position: absolute;
    content: '';
    width: 100%;
    height: 2px;
    left: 0;
    bottom: -22px;
    background: #009D9A;
}
nav#topnav.scrolled .nav-links li.active a {
    font-weight: 600;
}

nav#topnav.scrolled .nav-links li:last-child a {
    display: none;
}
nav#topnav.scrolled .nav-links li:last-child {
    margin-left: 0;
}

/* Desktop nav links */
.nav-links {
list-style: none;
display: flex;
gap: 4px;
align-items: center;
}
.nav-links a {
text-decoration: none;
color: #fff;
font-size: 14px; 
font-weight: 300;
padding: 8px 16px;
transition: background 0.2s, color 0.2s;
}
.nav-links li:last-child {
margin-left: 40px;
}
.nav-links li:last-child a{
padding: 0;
}
.mobiles {
display: none;
}

/* ════════════════════════════════════════
BURGER BUTTON
════════════════════════════════════════ */
.burger {
display: none;
flex-direction: column;
justify-content: center;
align-items: center;
gap: 5px;
width: 40px; 
height: 40px;
background: transparent;
border: 1.5px solid var(--outline);
border-radius: var(--radius-xs);
cursor: pointer;
padding: 8px;
transition: background 0.2s, border-color 0.2s;
flex-shrink: 0;
margin-left: 12px;
}
.burger:hover {
background: transparent;
}
.burger span {
display: block;
width: 18px; height: 2px;
background: var(--on-surface-variant);
border-radius: 2px;
transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
transform-origin: center;
}

/* Burger → X when open */
.burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; width: 0; }
.burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ════════════════════════════════════════
MOBILE SLIDE-DOWN MENU
════════════════════════════════════════ */
.mobile-menu {
display: none; /* activated by media query */
overflow: hidden;
max-height: 0;
opacity: 0;
background: rgba(13,15,20,0.98);
border-top: 1px solid var(--on-surface-variant);
transition: max-height 0.35s cubic-bezier(0.4,0,0.2,1),
        opacity 0.25s ease;
}
.mobile-menu.open {
max-height: 400px;
opacity: 1;
}
.mobile-menu ul { list-style: none; padding: 6px 0 12px; }
.mobile-menu li { border-bottom: 1px solid var(--on-surface-variant); }
.mobile-menu li:last-child { border-bottom: none; }
.mobile-link {
display: block;
padding: 14px 24px;
font-size: 14px; font-weight: 500;
color: #fff;
text-decoration: none;
transition: background 0.2s, color 0.2s, padding-left 0.2s;
}
.mobile-link:hover {
background: var(--surface-container-low);
color: var(--primary);
padding-left: 32px;
}

/* ════════════════════════════════════════
OVERLAY — dims content behind open menu
════════════════════════════════════════ */
.nav-overlay {
display: none;
position: fixed; inset: 0;
z-index: 150;
background: rgba(0,0,0,0.32);
opacity: 0;
transition: opacity 0.3s ease;
cursor: pointer;
}
.nav-overlay.active {
display: block;
opacity: 1;
}
.hero {
position: relative;
overflow: hidden;
min-height: 600px;
background-color: #000;
background-image: url(../images/hero-bg.png);
width: 100%;
background-size: 100%;
background-repeat: no-repeat;
height: 100%;
background-position: bottom center;
padding: 300px 24px 200px;
}


.hero-grid {
position: relative;
z-index: 1;
max-width: var(--max-width);
margin: 0 auto;
display: flex;
gap: 40px;
align-items: center;
 justify-content: space-between;
}

.hero-copy {
    max-width: 810px;
    overflow: hidden;
    padding-left: 28px;
    position: relative;
}
.hero-copy .tagline {
    color: #fff;
    font-family: Gotham;
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    letter-spacing: -.02em;
    line-height: 51px;
        font-weight: 700;
    margin-bottom: 20px;
    text-transform: capitalize;
        line-height: 1.275;
}
.hero-copy:before {
    border: 1px solid;
    border-image-slice: 1;
    border-image-source: linear-gradient(180deg, hsla(0, 0%, 100%, 0), hsla(0, 0%, 100%, .5) .01%, hsla(0, 0%, 100%, .5) 50%, hsla(0, 0%, 100%, 0));
    bottom: 0;
    box-sizing: border-box;
    content: "";
    height: calc(100% - 6px);
    left: 0;
    position: absolute;
    width: 0;
    z-index: 1;
}
.eyebrow {
margin: 0 0 12px;
color: rgba(255, 255, 255, 0.62);
font-size: 0.78rem;
letter-spacing: 0.18em;
text-transform: uppercase;
}

h1,
h2{
    font-size: 40px;
    font-weight: 400;
    letter-spacing: -.02em;
    line-height: 1.25;
    margin-bottom: 1.5rem;
    color: #fff;
}

h6{
    font-size: 16px;
    font-weight: 700;
    line-height: 22px;
    margin-bottom: 8px;
}

.hero h1 {
  font-size: 40px;
font-weight: 400;
letter-spacing: -.02em;
line-height: 1.25;
margin-bottom: 1.5rem;
    color: #fff;
}

.hero h1 span {
color: var(--teal-bright);
}
h2 span{    background: linear-gradient(91deg, #3cc3c2 50%, #267e7d 94.42%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;}

.hero-text {
  font-size: 16px;
line-height: 1.65;
font-weight: 400;
  color: #fff;
}

.hero-actions,
.classify-actions {
display: flex;
gap: 12px;
flex-wrap: wrap;
margin-top: 30px;
  align-items: center;
}
.button{
    color: #fff;
display: inline-block;
overflow: hidden;
padding: 4px;
position: relative;
z-index: 0;
}
.button button {
    cursor: pointer;
color: #fff;
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 42px;
padding: 0 18px;
border-radius: 999px;
border: 1px solid transparent;
font-size: 0.92rem;
font-weight: 400;
  text-decoration: none;
      text-transform: capitalize;
transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.button-primary button{
color: #fff;
  background: linear-gradient(0deg, #3cc3c2, #3cc3c2), radial-gradient(100% 100% at 50% 0%, #ffffff4d 0%, rgba(255, 255, 255, 0) 100%);
}

.button-secondary {
display: inline-flex;
align-items: center;
justify-content: center;
    border-radius: 100px;
border: 1.5px solid;
padding: 11px 30px;
font-weight: 400;
font-size: 14px;
line-height: 20px;
height: 42px;
text-transform: capitalize;
transition: all .3s ease;
backdrop-filter: blur(42px);
border: 1.5px solid;
 text-decoration: none;
backdrop-filter: blur(42px);
background: linear-gradient(181deg, #3cc2c080 -246.15%, rgba(0, 175, 253, 0) 135.95%);
border: 1px solid #3cc2c0;
}
.button-secondary:hover {
color: #fff;
background: #3cc3c2;
border: 1px solid #3cc3c2;
}

.button i {
border-radius: 40px;
content: "";
inset: 0;
-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
-webkit-mask-composite: xor;
mask-composite: exclude;
padding: 2px;
position: absolute;
z-index: -1;
}

.button i:before{
    position: absolute;
animation: animationButton 2s ease-in-out infinite;
content: "";
height: 400px;
left: 50%;
top: 50%;
transform: translate(-50%, -50%) rotate(0);
width: 400px;
    background: linear-gradient(45deg, #3cc3c2, #3cc3c2, #0000001a, #0000001a);
}

@keyframes animationButton {
0% {
 transform: translate(-50%,-50%) rotate(0deg)
}

25% {
 transform: translate(-50%,-50%) rotate(90deg)
}

50% {
 transform: translate(-50%,-50%) rotate(180deg)
}

to {
 transform: translate(-50%,-50%) rotate(1turn)
}
}


.button-dark {
background: rgba(0, 0, 0, 0.35);
}
.hero-right {
position: relative;
}
.hero-panel {
    position: relative;
padding: 50px;
border-radius: 22px;
background: linear-gradient(180deg, rgba(4, 19, 26, 0.72), rgba(2, 10, 16, 0.86));
border: 1px solid rgba(135, 221, 219, 0.32);
box-shadow: var(--shadow);
width: 566px;
box-sizing: border-box;
padding: 49px 54px 49px 53px;
justify-content: center;
align-items: center;
align-self: stretch;
border-radius: 16px;
border: 1px solid #009D9A;
background: var(--tata-greys-greys-r-0-g-0-b-0, #000);
}

.hero-metrics {
display: flex;
gap: 70px;
}

.metric-card {
border-left: 1px solid #D9D9D9;
width: 30%;
padding-left: 15px;
color: #009D9A;
font-size: 28px;
font-style: normal;
font-weight: 350;
line-height: normal;
}

.metric-card strong {
display: block;
color: var(--teal-bright);
font-size: 2rem;
line-height: 1;
font-size: 28px;
font-style: normal;
line-height: normal;
}

.metric-card span {
display: block;
margin-top: 8px;
color: rgba(255, 255, 255, 0.74);
font-size: 0.9rem;
color: #FFF;
font-size: 16px;
font-style: normal;
line-height: 100.655%;
}
.metric-caption {
margin: 18px 0 0;
color: rgba(255, 255, 255, 0.76);
font-size: 0.84rem;
text-align: center;
display: flex;
padding: 10px 16px;
justify-content: center;
align-items: center;
position: absolute;
right: -20px;
bottom: -13px;
border-radius: 20px;
color: var(--tata-greys-greys-r-255-g-255-b-255, #FFF);
font-size: 16px;
font-style: normal;
font-weight: 325;
line-height: normal;
border: 1px solid var(--tataiz-oteal-iz-oteal-r-0-g-157-b-154, #009D9A);
background: var(--tata-greys-greys-r-0-g-0-b-0, #000);
}
.icons-left {
position: absolute;
left: 0;
top: -110px;
}
.icons-right {
position: absolute;
right: 0;
top: -85px;
}
.icons-bottom {
position: relative;
left: 30%;
top: 50px;
}
.icons-left,
.icons-right,
.icons-bottom {
display: flex;
align-items: center;
}

.floating-cta {
    position: fixed;
    right: 24px;
    bottom: 28px;
    z-index: 2;
    border: 0;
    border-radius: 10px;
    padding: 12px 18px;
    background: rgba(0, 0, 0, 0.9);
    color: #fff;
    font-weight: 700;
    cursor: pointer;
    border: 1px solid #fff;
    border-radius: 50px;
    display: flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    transition: 0.3s;
}
.floating-cta:hover {
    background: #3cc3c2;
    border: 1px solid #3cc3c2;
}
button.floating-cta svg {
    width: 14px;
}
a.floating-cta.hide {
    opacity: 0;
        pointer-events: none;
}

.section {
padding: 120px 24px 0;
}

.section-heading p{
    font-size: 16px;
max-width: 700px;
margin: 0 auto;
}

.section-heading.centered {
margin: 0 auto;
text-align: center;
}
.section-heading h2{
    color: #1f1f1f;
}
.content {
 max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
    margin-top: 12px;
}

.problem-item.is-active .content {
  display: block;
}
.problem-body p {
        font-size: 14px;
    line-height: 24px;
    font-weight: 400;
    color:  #1f1f1f;
}
{
    font-size: 16px;
    line-height: 1.65;
    font-weight: 400;
    color:  #1f1f1f;
}
p.source-line {
    font-size: 13px;
    font-style: normal;
    font-weight: 325;
    line-height: normal;
    border-top: 1px solid #000;
    margin-top: 15px;
    padding-top: 15px;
}
.problem-section,
.classify-section,
.dimensions-section,
.evidence-section {
position: relative;
max-width: calc(var(--max-width) + 48px);
margin: 0 auto;
}
.problem-section {
    background-image: url(../images/Ellipse-bg.png);
    width: 100%;
    background-size: 100%;
    background-repeat: no-repeat;
    height: 100%;
    background-position: top right;
}

/*.problem-section::before,
.dimensions-section::before,
.evidence-section::before {
content: "";
position: absolute;
pointer-events: none;
width: 520px;
height: 520px;
border-radius: 50%;
background: radial-gradient(circle, rgba(0, 157, 154, 0.28), transparent 62%);
}*/

.problem-section::before {
top: -140px;
left: -240px;
}

.dimensions-section::before {
top: -120px;
right: -220px;
}

.evidence-section::before {
top: -120px;
left: -200px;
}

.evidence-section.section {
    padding: 120px 0 120px;
    background: linear-gradient(90deg, var(--tata-greys-greys-r-255-g-255-b-255, #FFF) 0%, #BFEFEE 100%);
}

.evidence-section .section-heading {
    margin-bottom: 30px;
}

.evidence-section h2{
    color: #1f1f1f;
}
.evidence-section .section-heading p {
    margin: 0 auto 0 0;
}

.problem-layout {
    position: relative;
    display: flex;
    gap: 60px;
    align-items: start;
    max-width: var(--max-width);
    margin: 56px auto 0;
    justify-content: center;
}
.problem-photo-card {
    overflow: hidden;
    border-radius: 22px;
    box-shadow: var(--shadow);
    height: 430px;
    width: 50%;
    max-width: 460px;
}

.problem-photo-card img {
width: 100%;
height: 100%;
object-fit: cover;
}

.problem-list {
    display: flex;
    flex-direction: column;
    gap: 28px;
    width:50%;
}

.problem-item {
display: flex;
align-items: flex-start;
gap: 16px;
}
.problem-item h6{
    margin-top: 13px;
    color: #009D9A;
    cursor: pointer;
}

.problem-icon img {
width: 40px;
height: 40px;
object-fit: contain;
}



.problem-rule {
    width: 210px;
    height: 2px;
    margin-top: 12px;
    background: #000;
    margin-bottom: 20px;
}

.source-line {
font-size: 0.92rem;
color: #a1a8b0;
}

.source-line span {
color: var(--teal);
font-weight: 800;
}

.classify-section {
overflow: hidden;
}

.classify-section::after {
content: "";
position: absolute;
left: -4%;
bottom: -130px;
width: 720px;
height: 320px;
background:
radial-gradient(circle at center, rgba(148, 233, 245, 0.18), transparent 58%),
repeating-radial-gradient(circle at center, rgba(148, 233, 245, 0.14) 0 2px, transparent 2px 18px);
transform: perspective(900px) rotateX(75deg);
}


.approach-section {
    padding: 180px 24px 80px;
    background-image: url(../images/approach-bg.png);
    width: 100%;
    background-size: 100%;
    background-repeat: no-repeat;
    height: 100%;
    background-position: -150px 105%;
}
.approach-inner h2 {
    color: #1f1f1f;
} 
.approach-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 60px;
}

/* LEFT SIDE */
.left-content {
  flex: 1;
}

.left-content h1 {
  font-size: 48px;
  line-height: 1.2;
  margin-bottom: 20px;
  color: #111;
}

.subtitle {
  font-size: 16px;
  color: #1f1f1f;
  max-width: 420px;
  margin-bottom: 30px;
}

.approach-inner .button-secondary {
    color: #009D9A;
}
.approach-inner .button-secondary:hover {
    color: #fff;
}

/* RIGHT SIDE */
.right-content {
    flex: 1.2;
    display: flex;
    gap: 60px;
    position: relative;
    flex-wrap: wrap;
    justify-content: center;
}

/* CARDS */
.right-content .card {
        width: 43%;
    padding: 30px;
    position: relative;
    min-height: 260px;
    max-width: 320px;
    border-radius: 12px;
border: 1px solid var(--tata-greys-greys-r-255-g-255-b-255, #FFF);
background: linear-gradient(302deg, rgba(60, 194, 192, 0.30) 1.22%, rgba(255, 255, 255, 0.20) 99.1%);
}

.right-content .card h3 {
  color: #1f1f1f;
font-size: 24px;
font-style: normal;
font-weight: 400;
line-height: normal;
margin-bottom: 30px;
}

.right-content .card p {
  color: #1f1f1f    ;
font-size: 14px;
font-style: normal;
font-weight: 400;
line-height: normal;
}

/* STEP CIRCLE */
.right-content .step {
    position: absolute;
    top: -40px;
    left: -30px;
    width: 70px;
    height: 70px;
    border: 4px solid #009D9A;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    background: #fff;
    font-size: 20px;
}

.cta-band {
    position: relative;
    min-height: 520px;
    background: url(../images/cta-banner.jpg) center / cover no-repeat;
}

/* RESPONSIVE */
@media (max-width: 1024px) {
  .container {
    flex-direction: column;
    gap: 50px;
  }
  .approach-section {
        padding: 0 24px 80px;
    background-position: center bottom;
}
.approach-inner {
    gap: 100px;
    flex-wrap: wrap;
}
.approach-inner h2 br{ display:none; }
.subtitle {
    max-width: 100%;
}
  .right-content {
    grid-template-columns: 1fr;
  }
  .left-content {
     flex: 100%; 
    width: 100%;
}

  .right-content .card-3 {
    grid-column: auto;
  }
}

@media (max-width: 980px) {


}

@media (max-width: 767px) {
    h1, h2 {
    font-size: 30px;
}
  .left-content h1 {
    font-size: 34px;
  }

  .btn-group {
    flex-direction: column;
    align-items: flex-start;
  }

  .right-content .step {
    width: 50px;
    height: 50px;
    font-size: 16px;
  }
  .right-content .card {
    width: 100%;
}
.cta-band {
    min-height: 300px;
}
.right-content .step {
    left: -10px;
    width: 60px;
    height: 60px;
}
}


.dimensions-section {
        padding-bottom: 120px;
            background-image: url(../images/Ellipse-bg.png);
    width: 100%;
    background-size: 100%;
    background-repeat: no-repeat;
    height: 100%;
    background-position: top right;
}

.dimension-grid {
max-width: var(--max-width);
margin: 50px auto 0;
display: grid;
grid-template-columns: repeat(6, minmax(0, 1fr));
gap: 14px;
}

.dimension-card {
background: rgba(255, 255, 255, 0.75);
border: 1px solid var(--line);
border-radius: 12px;
padding: 20px;
min-height: 182px;
}


.dimension-card h3 {
color: #1f1f1f;
font-size: 20px;
font-style: normal;
font-weight: 400;
line-height: normal;
    margin-bottom: 10px;
}

.dimension-card sub {
font-size: 0.9rem;
}
.dimension-card p{
color: #1f1f1f;
font-size: 14px;
font-style: normal;
font-weight: 400;
line-height: normal;
margin-bottom: 20px;

}
p.dimension-code {
color: #009D9A;
font-size: 24px;
font-style: normal;
font-weight: 400;
line-height: normal;
    margin-bottom: 20px;
}

.dimension-card span {
color: #666;
font-size: 12px;
font-style: normal;
line-height: normal;
}


.evidence-track::-webkit-scrollbar {
display: none;
}

.evidence-card.swiper-slide {
    height: auto;
}

.evidence-card .card-inner{
display: flex;
height: 100%;
padding: 26.919px;
flex-direction: column;
align-items: flex-start;
gap: 13.74px;
border-radius: 8px;
    justify-content: space-between;
background: linear-gradient(110deg, rgba(191, 239, 238, 0.20) 0.03%, rgba(0, 157, 154, 0.15) 100.03%);
}

.evidence-card strong {
color: #009D9A;
font-size: 40.379px;
font-style: normal;
font-weight: 800;
line-height: 44.865px; /* 111.111% */
}

.evidence-card span {
display: block;
width: 100%;
margin-top: 24px;
padding-top: 16px;
border-top: 1px solid #F1F5F9;
color: #1f1f1f;
font-size: 12px;
font-weight: 600;
letter-spacing: 0.56px;
text-transform: uppercase;
}
.swiper-pagination-bullet-active {
    width: 20px !important;
    border-radius: 20px;
}

.slider-dots {
display: flex;
justify-content: center;
gap: 12px;
margin-top: 22px;
}

.top_content_icons.post_icons {
        align-items: center;
    display: flex;
    gap: 10px;
    justify-content: end;
    justify-content: center;
    margin-top: 40px;
    width: 100%;
}
.swiper-next svg, .swiper-prev svg {
    cursor: pointer;
    height: 16px;
    width: 16px;
}
.swiper-next svg path, .swiper-prev svg path {
    fill: #1f1f1f;
}
.swiper-paginations-pst.swiper-pagination-horizontal {
    width: auto;
    align-items: center;
    border: .5px solid #1f1f1f;
    border-radius: 26px;
    display: inline-flex;
    padding: 6px;
    transform: none !important;
    width: max-content !important;
}
.swiper-pagination-bullet {
    background: #1f1f1f;
    color: #1f1f1f;
    height: 4px;
    left: 1px !important;
    opacity: 1;
    position: relative;
    transform: scale(1);
    width: 4px;
}

.swiper-prev,
.swiper-next {
    display: flex;
}


/*.cta-overlay {
position: absolute;
inset: 0;
background: linear-gradient(180deg, rgba(0, 0, 0, 0.14), rgba(0, 0, 0, 0.38));
}
*/
.cta-content {
position: relative;
z-index: 1;
color: #fff;
text-align: left;
}

.cta-content p {
max-width: 640px;
color: rgba(255, 255, 255, 0.78);
}

.footer {
background:
radial-gradient(circle at left top, rgba(78, 205, 196, 0.15), transparent 18%),
#020406;
color: #fff;
}

.footer-inner {
max-width: var(--max-width);
margin: 0 auto;
padding: 74px 24px 28px;
}

.footer-heading h2 {
    color: #fff;
    margin-bottom: 30px;
}

.footer-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 32px;
}

.footer-column {
padding-left: 24px;
border-left: 2px solid rgba(255, 255, 255, 0.8);
}
.footer-column h3 {
    font-size: 24px;
    line-height: 1.2;
    color: #FFFFFF;
        font-weight: 400;
    margin-bottom: 12px;
}
.footer-column p {
color: #97a1ab;
}

.footer-column a {
display: inline-block;
margin-top: 22px;
color: #3cc3c2;
font-weight: 600;
text-decoration: none;
}
.subscribe_btn span.button_icon {
    position: relative;
    display: inline-flex;
    overflow: hidden;
    border: 0px;
}
.subscribe_btn .hr_2 {
    position: absolute;
    left: -20px;
    top: 20px;
        transition: 1s;
}
.footer-column a svg path{
    fill: #3cc3c2;
}
.subscribe_btn .card_btn:hover .hr_1 {
    position: relative;
    top: -12px;
    right: -12px;
}
.subscribe_btn .card_btn:hover .hr_2 {
    top: 0;
    left: 0;
}
.copyright {
margin: 56px 0 0;
text-align: center;
color: #8d959d;
font-size: 11px;
}

@media (max-width: 1024px) {
.hero-grid,
.problem-layout {
            flex-wrap: wrap;
grid-template-columns: 1fr;
}

.problem-photo-card {
    height: auto;
    width: 100%;
    max-width: 100%;
}
.problem-list {
    width: 100%;
}
.classify-intro,
.footer-grid {
display: flex;
flex-direction: column;
}
.hero-copy {
    max-width: 100%;
    width: 100%;
}

.hero-panel {
            width: 100%;
justify-self: stretch;
}
.metric-caption {
    right: auto;
    bottom: -20px;
    left: 0;
}

.dimension-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
}

.evidence-track {
grid-auto-columns: calc((100% - 18px) / 2);
}
}



/* ════════════════════════════════════════
RESPONSIVE BREAKPOINTS
════════════════════════════════════════ */

/* Tablet ≤ 768px: show burger, hide desktop links */
@media (max-width: 1024px) {
.mobiles {
display: block;
}
.desktop {
display: none;
}
.nav-links { display: none; }
.burger     { display: flex; }
.mobile-menu { display: block; }
.nav-links li:last-child {
margin-left: 0;
}

.s-headline {
font-size: 24px;
}
.hero h1 {
font-size: 30px;
}

.hero { padding: 120px 20px; }
.hero-right {
    width: 100%;
}
.icons-left, .icons-right, .icons-bottom {
    display: none;
}
.hero-metrics { 
 gap: 20px; }
.hero-formula  { font-size: 12px; }
.hero-formula-pill { padding: 10px 16px; }

.prob-grid   { grid-template-columns: 1fr; }
.prob-card.geo-feat { grid-column: span 1; }
.approach-row { grid-template-columns: 1fr; }

.calc-grid  { grid-template-columns: 1fr; }
.result-card { position: static; box-shadow: var(--elevation-1); }

.ev-grid { grid-template-columns: repeat(2, 1fr); }

.cta { padding: 72px 20px; }
.btn-tonal { margin-left: 0; margin-top: 12px; }
.cta .btn-filled,
.cta .btn-tonal { display: block; width: fit-content; margin: 6px auto; }
.result-num {
font-size: 40px;
}
.ev-n {
font-size: 24px;
}

.section { padding: 72px 20px; }
}

@media (max-width: 767px) {
.nav-shell,
.brand-lockup,
.top-nav,
.hero-actions,
.classify-actions {
flex-wrap: wrap;
}

.nav-shell,
.brand-lockup {
gap: 14px;
}

.top-nav {
gap: 14px 18px;
}

.hero {
padding-top: 100px;
}

.overview-footer .floating-cta {
position: static;
margin: 28px 24px 0;
}

.section,
.evidence-section.section {
padding: 50px 20px;
}

.steps-grid,
.dimension-grid,
.footer-grid {
grid-template-columns: 1fr;
}

.step-card:last-child {
grid-column: auto;
max-width: none;
}

.evidence-track {
grid-auto-columns: 88%;
}

.hero-metrics {
grid-template-columns: 1fr;
}
}

/* Small mobile ≤ 480px */
@media (max-width: 580px) {
:root { --nav-height: 56px; }
.nav-top-row {
padding: 0 10px;
}
.nav-logo-img {     width: 180px; }
.nav-logo-izo {    width: 120px; }
.mobiles {
display: none;
}

.ev-grid { grid-template-columns: 1fr; }
.dim-grid { grid-template-columns: repeat(2, 1fr); }
.prob-card .ic {
width: 50px;
height: 50px;
}
.prob-card h3 {
font-size: 20px;
}
.hero-sub { font-size: 15px; }

.formula-block { padding: 20px 16px; }
.fl { font-size: 11px; }
.approach-card h3 {
font-size: 22px;
}

.section { padding: 56px 16px; }
}
@media (max-width: 480px) {
.nav-logo-img {
  width: 150px;
}
.nav-logo-izo {
  width: 100px;
}
.burger {
width: 30px;
height: 30px;
margin-left: 5px;
}
}

@media screen and (min-width: 1024px) {
    .wrap {
        max-width: 1160px;
        padding: 0 24px
    }
}
@media screen and (min-width: 1160px) {
    .wrap {
        max-width: 1160px;
    }
}
@media screen and (min-width: 1280px) {
    .wrap {
        max-width: 1160px;
    }
}
@media screen and (min-width: 1380px) {
    .wrap {
        max-width: 1292px;
    }
}
@media (min-width: 1480px) {
    .nav-top-row {
        max-width: 2400px;
        width: calc(100% - 160px);
    }
}