/* ================================================================
   MIND ARCHITECTURE — Design System
   Hypnotherapy Pvt Ltd | Mumbai
================================================================ */

:root{
  --bg:           #FAFAFA;
  --bg-2:         #F2F3F7;
  --ink:          #2A2E35;
  --ink-soft:     #4A4F58;
  --ink-mute:     #7C828C;
  --line:         rgba(42,46,53,0.08);
  --line-strong:  rgba(42,46,53,0.16);
  --indigo:       #5C6AC4;
  --indigo-deep:  #404C9E;
  --indigo-soft:  rgba(92,106,196,0.10);
  --teal:         #7FD1B9;
  --teal-deep:    #4FB39A;
  --teal-soft:    rgba(127,209,185,0.14);
  --gradient-1:   linear-gradient(135deg, rgba(92,106,196,0.10), rgba(127,209,185,0.10));
  --gradient-2:   linear-gradient(160deg, #5C6AC4 0%, #7FD1B9 100%);
  --gradient-3:   radial-gradient(60% 60% at 30% 30%, rgba(92,106,196,0.20), transparent 70%),
                  radial-gradient(50% 50% at 80% 70%, rgba(127,209,185,0.22), transparent 70%);
  --shadow-1:     0 1px 2px rgba(42,46,53,0.04), 0 8px 24px rgba(42,46,53,0.06);
  --shadow-2:     0 12px 40px rgba(42,46,53,0.10);
  --shadow-3:     0 20px 60px rgba(42,46,53,0.14);
  --radius-s:     10px;
  --radius-m:     18px;
  --radius-l:     28px;
  --radius-xl:    40px;
  --maxw:         1240px;
  --ease:         cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Manrope','Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-weight:400;
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

img,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;transition:all .3s var(--ease)}
button{font-family:inherit;cursor:pointer;border:0;background:transparent}

::selection{background:var(--indigo);color:#fff}

/* ----------------- Typography ----------------- */
h1,h2,h3,h4,h5{font-family:'Manrope','Inter',sans-serif;font-weight:600;letter-spacing:-0.02em;line-height:1.12;color:var(--ink)}
h1{font-size:clamp(2.4rem,5.4vw,4.6rem);font-weight:500}
h2{font-size:clamp(1.8rem,3.6vw,2.9rem);font-weight:500}
h3{font-size:clamp(1.25rem,2vw,1.55rem);font-weight:600}
h4{font-size:1.05rem;font-weight:600;letter-spacing:.02em}
p{color:var(--ink-soft);font-size:1rem;line-height:1.75}
.lead{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--ink-soft);line-height:1.7;font-weight:400}

.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--indigo);font-weight:600;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--indigo);opacity:.6}

.section-title{margin-top:.9rem;margin-bottom:1.1rem}
.section-intro{max-width:640px;color:var(--ink-soft)}

/* ----------------- Layout ----------------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(72px,9vw,140px) 0;position:relative}
.section--tight{padding:clamp(56px,7vw,100px) 0}

.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

@media (max-width:980px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .grid-3.keep-2,.grid-4.keep-2{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .grid-3.keep-2,.grid-4.keep-2{grid-template-columns:1fr}
}

/* ----------------- Buttons ----------------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:14px 24px;border-radius:999px;
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  transition:all .35s var(--ease);
  position:relative;white-space:nowrap;
}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--indigo);transform:translateY(-2px);box-shadow:var(--shadow-2)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-light{background:#fff;color:var(--ink);box-shadow:var(--shadow-1)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}
.btn .arrow{display:inline-block;transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ----------------- Navigation ----------------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(250,250,250,0.72);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:all .3s var(--ease);
}
.nav.scrolled{background:rgba(250,250,250,0.92);border-bottom:1px solid var(--line)}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;font-weight:600;letter-spacing:-.01em}
.brand__mark{
  width:38px;height:38px;border-radius:10px;
  background:var(--gradient-2);position:relative;display:grid;place-items:center;
  box-shadow:0 6px 18px rgba(92,106,196,.30);
}
.brand__mark::before,.brand__mark::after{
  content:"";position:absolute;border-radius:6px;background:rgba(255,255,255,.55);
}
.brand__mark::before{width:14px;height:14px;top:6px;left:6px;background:rgba(255,255,255,.32)}
.brand__mark::after{width:10px;height:10px;bottom:6px;right:6px;background:rgba(255,255,255,.55)}
.brand__name{font-size:1.02rem;color:var(--ink)}
.brand__sub{display:block;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);font-weight:500;margin-top:1px}

.nav__menu{display:flex;align-items:center;gap:6px;list-style:none}
.nav__menu a{
  display:inline-block;padding:10px 14px;border-radius:999px;
  font-size:.88rem;font-weight:500;color:var(--ink-soft);
}
.nav__menu a:hover{color:var(--ink);background:var(--bg-2)}
.nav__menu a.active{color:var(--ink);background:var(--bg-2)}

.nav__cta{display:none}
@media (min-width:1180px){.nav__cta{display:inline-flex}}

.nav__toggle{display:none;width:42px;height:42px;border-radius:10px;background:var(--bg-2);align-items:center;justify-content:center}
.nav__toggle span{width:18px;height:2px;background:var(--ink);position:relative;display:block}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink);transition:all .3s var(--ease)}
.nav__toggle span::before{top:-6px}
.nav__toggle span::after{top:6px}

@media (max-width:1080px){
  .nav__menu{
    position:fixed;top:0;right:0;height:100vh;width:min(360px,86vw);
    background:#fff;flex-direction:column;align-items:flex-start;justify-content:flex-start;
    padding:96px 28px 28px;gap:6px;box-shadow:var(--shadow-3);
    transform:translateX(100%);transition:transform .35s var(--ease);
  }
  .nav__menu.open{transform:translateX(0)}
  .nav__menu li{width:100%}
  .nav__menu a{display:block;padding:14px 16px;font-size:1rem;border-radius:12px}
  .nav__toggle{display:flex}
  .nav__toggle.open span{background:transparent}
  .nav__toggle.open span::before{top:0;transform:rotate(45deg)}
  .nav__toggle.open span::after{top:0;transform:rotate(-45deg)}
}

/* ----------------- HERO (Homepage) ----------------- */
.hero{
  position:relative;min-height:100vh;
  padding:160px 0 100px;overflow:hidden;
  background:var(--bg);
}
.hero::before{
  content:"";position:absolute;inset:0;background:var(--gradient-3);opacity:.6;pointer-events:none;
}
.hero__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center;position:relative;z-index:2;
}
@media (max-width:980px){.hero__grid{grid-template-columns:1fr;gap:48px}}

.hero__copy h1{margin:1rem 0 1.4rem}
.hero__copy h1 span{
  background:var(--gradient-2);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-style:italic;font-weight:500;
}
.hero__copy .lead{max-width:520px}
.hero__cta{margin-top:2rem;display:flex;gap:14px;flex-wrap:wrap}

.hero__meta{
  margin-top:3rem;display:flex;gap:36px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:1.6rem;
}
.hero__meta div{display:flex;flex-direction:column;gap:4px}
.hero__meta strong{font-size:1.5rem;font-weight:600;color:var(--ink);letter-spacing:-.02em}
.hero__meta span{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}

/* Layered visual */
.hero__visual{
  position:relative;height:600px;
}
@media (max-width:980px){.hero__visual{height:540px;max-width:520px;margin:0 auto;width:100%}}

.layer-card{
  position:absolute;border-radius:var(--radius-l);overflow:hidden;
  box-shadow:var(--shadow-3);
  background:#fff;
}
.layer-card img{width:100%;height:100%;object-fit:cover;object-position:center}

.lc-1{
  width:62%;height:78%;left:0;top:6%;z-index:3;
  transform:rotate(-3deg);
}
.lc-2{
  width:54%;height:54%;right:0;top:0;z-index:4;
  background:var(--gradient-2);color:#fff;padding:28px;
  transform:rotate(2deg);
  display:flex;flex-direction:column;justify-content:space-between;
}
.lc-2 .num{font-size:3.4rem;font-weight:300;line-height:1;letter-spacing:-.04em}
.lc-2 small{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;opacity:.85}
.lc-2 p{color:rgba(255,255,255,.92);font-size:.92rem;line-height:1.55}

.lc-3{
  width:50%;height:38%;right:6%;bottom:2%;z-index:5;
  padding:22px;background:#fff;
  display:flex;flex-direction:column;justify-content:space-between;gap:8px;
  transform:rotate(-2deg);
}
.lc-3 .dot{width:10px;height:10px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 6px var(--teal-soft)}
.lc-3 strong{font-size:1.05rem;font-weight:600;color:var(--ink);line-height:1.3}
.lc-3 small{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute)}

.lc-blob{
  position:absolute;width:280px;height:280px;border-radius:50%;
  background:var(--gradient-2);filter:blur(70px);opacity:.35;
  top:30%;right:-10%;z-index:1;
}

/* ----------------- Mind Layers Section ----------------- */
.layers{position:relative}
.layers__head{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:60px;align-items:end}
@media (max-width:880px){.layers__head{grid-template-columns:1fr;gap:24px}}

.layer-stack{position:relative;display:flex;flex-direction:column;gap:18px}
.layer-row{
  display:grid;grid-template-columns:64px 1fr 1fr;gap:32px;
  padding:32px;background:#fff;border-radius:var(--radius-l);
  border:1px solid var(--line);
  box-shadow:var(--shadow-1);
  transition:all .4s var(--ease);
}
.layer-row:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.layer-row__num{
  font-size:1.4rem;font-weight:300;color:var(--indigo);
  letter-spacing:-.02em;
  border-right:1px solid var(--line);padding-right:24px;
}
.layer-row__title{font-size:1.25rem;font-weight:600;color:var(--ink);margin-bottom:.4rem}
.layer-row__title small{display:block;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:.5rem;font-weight:600}
.layer-row__body p{font-size:.95rem;line-height:1.7}
@media (max-width:760px){
  .layer-row{grid-template-columns:1fr;gap:14px;padding:24px}
  .layer-row__num{border-right:0;padding-right:0;border-bottom:1px solid var(--line);padding-bottom:14px}
}

/* ----------------- Pattern Cards ----------------- */
.pattern-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:980px){.pattern-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.pattern-grid{grid-template-columns:1fr}}

.pattern-card{
  position:relative;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-m);padding:30px;overflow:hidden;
  transition:all .4s var(--ease);
}
.pattern-card::before{
  content:"";position:absolute;inset:auto -30% -30% auto;width:160px;height:160px;
  background:var(--gradient-1);border-radius:50%;filter:blur(20px);
  transition:all .5s var(--ease);
}
.pattern-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-2);border-color:transparent}
.pattern-card:hover::before{transform:scale(1.4)}
.pattern-card .num{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--indigo);font-weight:600;
}
.pattern-card h3{margin:14px 0 10px;font-size:1.18rem}
.pattern-card p{font-size:.94rem;color:var(--ink-soft);position:relative;z-index:2}
.pattern-card .icon{
  width:46px;height:46px;border-radius:12px;background:var(--indigo-soft);
  display:grid;place-items:center;color:var(--indigo);margin-bottom:18px;
  font-weight:600;font-size:1.1rem;position:relative;z-index:2;
}

/* ----------------- How it works (process timeline) ----------------- */
.process-timeline{position:relative;display:flex;flex-direction:column;gap:0}
.process-timeline::before{
  content:"";position:absolute;left:30px;top:30px;bottom:30px;width:2px;
  background:linear-gradient(180deg,var(--indigo),var(--teal));
  opacity:.25;
}
.process-step{
  display:grid;grid-template-columns:62px 1fr;gap:30px;
  padding:30px 0;border-bottom:1px solid var(--line);
  position:relative;
}
.process-step:last-child{border-bottom:0}
.process-step__num{
  width:62px;height:62px;border-radius:50%;background:#fff;border:2px solid var(--indigo);
  display:grid;place-items:center;color:var(--indigo);font-weight:600;font-size:1.05rem;
  position:relative;z-index:2;
}
.process-step__body h3{margin-bottom:.6rem;font-size:1.25rem}
.process-step__body p{font-size:.96rem}
@media (max-width:600px){
  .process-step{grid-template-columns:1fr;gap:14px}
  .process-step__num{margin:0}
  .process-timeline::before{display:none}
}

/* ----------------- Transformation panel ----------------- */
.transform-panel{
  position:relative;border-radius:var(--radius-xl);overflow:hidden;
  background:var(--ink);color:#fff;padding:clamp(48px,7vw,90px);
}
.transform-panel::before{
  content:"";position:absolute;inset:0;background:
    radial-gradient(60% 60% at 20% 20%, rgba(92,106,196,.32), transparent 60%),
    radial-gradient(50% 50% at 80% 80%, rgba(127,209,185,.28), transparent 60%);
}
.transform-panel__grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media (max-width:880px){.transform-panel__grid{grid-template-columns:1fr;gap:32px}}
.transform-panel h2{color:#fff}
.transform-panel p{color:rgba(255,255,255,.78)}
.transform-panel .eyebrow{color:var(--teal)}
.transform-panel .eyebrow::before{background:var(--teal)}

.transform-list{display:grid;gap:14px}
.transform-list__item{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 22px;background:rgba(255,255,255,.06);border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  transition:all .3s var(--ease);
}
.transform-list__item:hover{background:rgba(255,255,255,.10);transform:translateX(6px)}
.transform-list__item .from{color:rgba(255,255,255,.55);font-size:.92rem;text-decoration:line-through;text-decoration-color:rgba(255,255,255,.3)}
.transform-list__item .to{color:#fff;font-weight:600;font-size:1rem}
.transform-list__item .arrow{color:var(--teal);font-size:.92rem}

/* ----------------- Testimonials ----------------- */
.t-card{
  position:relative;padding:34px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-m);box-shadow:var(--shadow-1);
  display:flex;flex-direction:column;gap:18px;
  transition:all .4s var(--ease);
}
.t-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.t-card .quote{font-size:1.02rem;line-height:1.7;color:var(--ink-soft);font-style:italic}
.t-card .who{display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);padding-top:18px}
.t-card .who .avatar{
  width:42px;height:42px;border-radius:50%;background:var(--gradient-2);color:#fff;
  display:grid;place-items:center;font-weight:600;font-size:.95rem;flex-shrink:0;
}
.t-card .who strong{display:block;font-size:.95rem;color:var(--ink)}
.t-card .who small{display:block;font-size:.78rem;color:var(--ink-mute);letter-spacing:.06em}

/* ----------------- Page Header (inner pages) ----------------- */
.page-header{
  position:relative;padding:170px 0 80px;overflow:hidden;background:var(--bg);
}
.page-header::before{
  content:"";position:absolute;inset:0;background:var(--gradient-3);opacity:.55;pointer-events:none;
}
.page-header__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:end}
@media (max-width:880px){.page-header__inner{grid-template-columns:1fr;gap:30px;align-items:start}}
.page-header h1{margin:1rem 0 1.2rem}
.page-header__crumbs{font-size:.78rem;color:var(--ink-mute);letter-spacing:.06em}
.page-header__crumbs a:hover{color:var(--indigo)}

/* ----------------- About Page ----------------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;align-items:start}
@media (max-width:880px){.about-grid{grid-template-columns:1fr;gap:40px}}

.about-portrait{position:relative}
.about-portrait__img{
  position:relative;border-radius:var(--radius-l);overflow:hidden;height:560px;
  box-shadow:var(--shadow-2);
}
.about-portrait__img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.about-portrait__chip{
  position:absolute;left:-20px;bottom:30px;background:#fff;border-radius:18px;padding:18px 22px;
  box-shadow:var(--shadow-2);display:flex;align-items:center;gap:14px;
}
.about-portrait__chip .ring{width:42px;height:42px;border-radius:50%;background:var(--gradient-2);position:relative}
.about-portrait__chip .ring::after{content:"";position:absolute;inset:6px;border-radius:50%;background:#fff}
.about-portrait__chip strong{display:block;font-size:.95rem;color:var(--ink)}
.about-portrait__chip small{display:block;font-size:.74rem;color:var(--ink-mute);letter-spacing:.08em}

.about-text h2{margin-bottom:1.2rem}
.about-text p{margin-bottom:1.1rem}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:2rem}
@media (max-width:520px){.about-stats{grid-template-columns:repeat(2,1fr)}}
.about-stat{padding:22px;background:var(--bg-2);border-radius:14px}
.about-stat strong{display:block;font-size:1.6rem;font-weight:500;color:var(--ink);letter-spacing:-.02em}
.about-stat small{display:block;font-size:.75rem;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}

/* ----------------- Diagram (How Hypnotherapy Works) ----------------- */
.mind-diagram{
  position:relative;padding:60px;background:#fff;border-radius:var(--radius-xl);
  border:1px solid var(--line);box-shadow:var(--shadow-1);
}
@media (max-width:760px){.mind-diagram{padding:32px}}
.mind-diagram__rings{position:relative;height:380px;margin:0 auto;max-width:540px}
.ring-c{position:absolute;left:50%;top:50%;border-radius:50%;border:1.5px dashed var(--line-strong);transform:translate(-50%,-50%)}
.ring-c-1{width:380px;height:380px;border-color:rgba(92,106,196,.35)}
.ring-c-2{width:260px;height:260px;border-color:rgba(127,209,185,.45)}
.ring-c-3{width:140px;height:140px;border-color:var(--ink);opacity:.45}
.ring-label{position:absolute;background:#fff;padding:8px 14px;border-radius:999px;border:1px solid var(--line);font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--ink);box-shadow:var(--shadow-1)}
.ring-label.l1{top:-8px;left:50%;transform:translateX(-50%);color:var(--indigo)}
.ring-label.l2{top:55px;right:50%;transform:translateX(140px);color:var(--teal-deep)}
.ring-label.l3{bottom:55px;left:50%;transform:translateX(-50%)}
.ring-center{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:120px;height:120px;border-radius:50%;background:var(--gradient-2);
  display:grid;place-items:center;color:#fff;font-weight:600;font-size:.85rem;text-align:center;
  box-shadow:0 14px 40px rgba(92,106,196,.34);
}
@media (max-width:600px){
  .mind-diagram__rings{height:320px}
  .ring-c-1{width:300px;height:300px}
  .ring-c-2{width:210px;height:210px}
  .ring-c-3{width:110px;height:110px}
  .ring-center{width:96px;height:96px;font-size:.78rem}
}

/* ----------------- Areas grid ----------------- */
.area-card{
  position:relative;padding:36px 30px;background:#fff;border-radius:var(--radius-m);
  border:1px solid var(--line);overflow:hidden;
  display:flex;flex-direction:column;gap:14px;
  transition:all .4s var(--ease);min-height:260px;
}
.area-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-2);border-color:transparent}
.area-card .badge{
  align-self:flex-start;padding:6px 12px;border-radius:999px;background:var(--teal-soft);
  color:var(--teal-deep);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
}
.area-card h3{font-size:1.2rem;margin-top:6px}
.area-card p{font-size:.94rem}
.area-card .arrow-link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-weight:600;font-size:.9rem}
.area-card .arrow-link:hover{color:var(--indigo)}

/* ----------------- Insights / Articles ----------------- */
.article-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;
  display:flex;flex-direction:column;transition:all .4s var(--ease);
}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.article-card .img{aspect-ratio:4/5;overflow:hidden;background:var(--bg-2)}
.article-card .img img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .6s var(--ease)}
.article-card:hover .img img{transform:scale(1.06)}
.article-card .body{padding:24px 26px 28px;display:flex;flex-direction:column;gap:10px;flex:1}
.article-card .meta{display:flex;gap:12px;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}
.article-card .meta .tag{color:var(--indigo)}
.article-card h3{font-size:1.12rem;line-height:1.35}
.article-card p{font-size:.92rem;line-height:1.65}
.article-card .link{margin-top:auto;color:var(--ink);font-weight:600;font-size:.86rem;display:inline-flex;align-items:center;gap:8px}

/* ----------------- Media Page ----------------- */
.media-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:160px;gap:18px}
.media-item{position:relative;border-radius:var(--radius-m);overflow:hidden;background:var(--bg-2);box-shadow:var(--shadow-1);cursor:pointer;transition:all .4s var(--ease)}
.media-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.media-item img,.media-item video{width:100%;height:100%;object-fit:cover;object-position:center}
.media-item .overlay{
  position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(42,46,53,.65));
  opacity:0;transition:opacity .35s var(--ease);display:flex;align-items:flex-end;padding:18px;color:#fff;font-size:.85rem;font-weight:600;
}
.media-item:hover .overlay{opacity:1}
.media-item .play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);
  display:grid;place-items:center;color:var(--ink);font-size:1.2rem;
  box-shadow:var(--shadow-2);
}

/* span layouts for layered look */
.m-1{grid-column:span 6;grid-row:span 2}
.m-2{grid-column:span 3;grid-row:span 2}
.m-3{grid-column:span 3;grid-row:span 2}
.m-4{grid-column:span 4;grid-row:span 2}
.m-5{grid-column:span 4;grid-row:span 2}
.m-6{grid-column:span 4;grid-row:span 2}
.m-7{grid-column:span 6;grid-row:span 2}
.m-8{grid-column:span 3;grid-row:span 2}
.m-9{grid-column:span 3;grid-row:span 2}
.m-10{grid-column:span 4;grid-row:span 2}
.m-11{grid-column:span 4;grid-row:span 2}
.m-12{grid-column:span 4;grid-row:span 2}
.m-13{grid-column:span 6;grid-row:span 2}
.m-14{grid-column:span 6;grid-row:span 2}

@media (max-width:980px){
  .media-grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:140px}
  .m-1{grid-column:span 6;grid-row:span 2}
  .m-2,.m-3{grid-column:span 3}
  .m-4,.m-5,.m-6{grid-column:span 3}
  .m-7{grid-column:span 6}
  .m-8,.m-9{grid-column:span 3}
  .m-10,.m-11,.m-12{grid-column:span 3}
  .m-13,.m-14{grid-column:span 6}
}
@media (max-width:560px){
  .media-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .m-1,.m-7,.m-13,.m-14{grid-column:span 2}
  .m-2,.m-3,.m-4,.m-5,.m-6,.m-8,.m-9,.m-10,.m-11,.m-12{grid-column:span 1}
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(20,22,28,.92);backdrop-filter:blur(6px);
  z-index:200;display:none;align-items:center;justify-content:center;padding:30px;
}
.lightbox.open{display:flex}
.lightbox__inner{max-width:1100px;max-height:90vh;width:100%;position:relative}
.lightbox__inner img,.lightbox__inner video{
  max-width:100%;max-height:90vh;border-radius:18px;box-shadow:var(--shadow-3);margin:0 auto;display:block;
}
.lightbox__close{
  position:absolute;top:-50px;right:0;width:40px;height:40px;border-radius:50%;background:#fff;
  display:grid;place-items:center;color:var(--ink);font-size:1.2rem;
}

/* ----------------- Contact Page ----------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:40px}}

.contact-info{display:flex;flex-direction:column;gap:22px}
.contact-info__row{
  padding:24px 26px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-m);box-shadow:var(--shadow-1);
  transition:all .3s var(--ease);
}
.contact-info__row:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.contact-info__row small{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}
.contact-info__row strong{display:block;margin-top:6px;color:var(--ink);font-size:1.05rem;font-weight:500;word-break:break-all}
.contact-info__row strong a:hover{color:var(--indigo)}

.form-card{
  padding:40px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-l);box-shadow:var(--shadow-1);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field label{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}
.form-field input,.form-field select,.form-field textarea{
  padding:14px 16px;border-radius:12px;border:1px solid var(--line-strong);
  background:var(--bg);font-family:inherit;font-size:.95rem;color:var(--ink);
  transition:all .3s var(--ease);
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:none;border-color:var(--indigo);background:#fff;
  box-shadow:0 0 0 4px var(--indigo-soft);
}
.form-field textarea{min-height:130px;resize:vertical}
.form-card .btn{margin-top:8px;width:100%;justify-content:center}

.social-row{display:flex;gap:12px;margin-top:8px}
.social-row a{
  width:42px;height:42px;border-radius:12px;background:var(--bg-2);
  display:grid;place-items:center;color:var(--ink-soft);transition:all .3s var(--ease);
}
.social-row a:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.social-row svg{width:18px;height:18px}

/* ----------------- Footer ----------------- */
.footer{
  background:var(--ink);color:rgba(255,255,255,.74);
  padding:80px 0 30px;position:relative;overflow:hidden;
}
.footer::before{
  content:"";position:absolute;inset:0;background:
    radial-gradient(50% 50% at 10% 0%, rgba(92,106,196,.18), transparent 60%),
    radial-gradient(40% 40% at 90% 80%, rgba(127,209,185,.16), transparent 60%);
}
.footer__grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.4fr .8fr .8fr 1fr;gap:40px;
}
@media (max-width:880px){.footer__grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:560px){.footer__grid{grid-template-columns:1fr}}

.footer h4{color:#fff;margin-bottom:18px;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.footer__brand .brand__name{color:#fff}
.footer__brand .brand__sub{color:rgba(255,255,255,.6)}
.footer__brand p{color:rgba(255,255,255,.62);margin-top:18px;font-size:.92rem;max-width:320px}

.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer ul a{color:rgba(255,255,255,.74);font-size:.92rem}
.footer ul a:hover{color:#fff}

.footer__contact small{display:block;color:rgba(255,255,255,.48);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.footer__contact a{display:block;color:#fff;font-size:.95rem;margin-bottom:4px}
.footer__contact a:hover{color:var(--teal)}

.footer__social{display:flex;gap:10px;margin-top:18px}
.footer__social a{
  width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.08);
  display:grid;place-items:center;color:#fff;
}
.footer__social a:hover{background:var(--indigo)}
.footer__social svg{width:15px;height:15px;display:block}

.footer__bottom{
  margin-top:60px;padding-top:24px;border-top:1px solid rgba(255,255,255,.10);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  font-size:.82rem;color:rgba(255,255,255,.55);position:relative;z-index:2;
}
.footer__bottom a{color:rgba(255,255,255,.78)}
.footer__bottom a:hover{color:var(--teal)}

/* ----------------- Reveal Animations ----------------- */
.reveal{opacity:0;transform:translateY(28px);transition:all .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}
.reveal-d2{transition-delay:.16s}
.reveal-d3{transition-delay:.24s}
.reveal-d4{transition-delay:.32s}

/* ----------------- Misc ----------------- */
.divider{height:1px;background:var(--line);margin:0;border:0}
.center{text-align:center;margin:0 auto}
.mb-0{margin-bottom:0}
.mt-2{margin-top:1rem}
.mt-4{margin-top:2rem}

/* Two column callouts (process page reinforcement) */
.callout-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:760px){.callout-grid{grid-template-columns:1fr}}
.callout{
  padding:32px;background:#fff;border-radius:var(--radius-m);border:1px solid var(--line);
  display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-1);
}
.callout h3{font-size:1.15rem}
.callout p{font-size:.94rem}

/* Outcome rows */
.outcome-row{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;
  padding:26px;border-bottom:1px solid var(--line);align-items:center;
}
.outcome-row:last-child{border-bottom:0}
.outcome-row .label{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}
.outcome-row .before{color:var(--ink-soft);font-size:1rem}
.outcome-row .after{color:var(--ink);font-weight:600;font-size:1.05rem;display:inline-flex;align-items:center;gap:10px}
.outcome-row .after::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--teal)}
@media (max-width:680px){.outcome-row{grid-template-columns:1fr;gap:8px;padding:20px 0}}

/* Page final CTA */
.cta-strip{
  position:relative;border-radius:var(--radius-xl);overflow:hidden;padding:clamp(48px,7vw,80px);
  background:linear-gradient(135deg,#FFFFFF 0%, var(--bg-2) 100%);
  border:1px solid var(--line);
  display:grid;grid-template-columns:1.4fr .8fr;gap:40px;align-items:center;
}
@media (max-width:760px){.cta-strip{grid-template-columns:1fr;gap:24px}}
.cta-strip h2{margin-bottom:.5rem}
.cta-strip p{max-width:520px}
.cta-strip__actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}
@media (max-width:760px){.cta-strip__actions{justify-content:flex-start}}

