*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
    :root{
      --cream:#F6F2EC;
      --cream-soft:#EEE9DF;
      --cream-deep:#E6DFD3;
      --ink:#16161A;
      --ink-soft:#4A4843;

      /* Core blues */
      --blue-deep:#1B3A6B;
      --blue-mid:#2A5FC0;
      --blue-bright:#4C8EF7;
      --blue-pale:#C8DAFF;
      --blue-tint:#EBF1FF;

      /* NEW: Charcoal palette for depth */
      --charcoal:#1E2228;
      --charcoal-deep:#13161B;
      --charcoal-mid:#2C3340;
      --charcoal-soft:#3D4557;
      --charcoal-mist:rgba(30,34,40,0.06);

      /* NEW: Blueâ†’Purple gradient vars */
      --grad-bp: linear-gradient(135deg, #1B3A6B 0%, #2A5FC0 45%, #6B4EBB 100%);
      --grad-bp-bright: linear-gradient(135deg, #2A5FC0 0%, #4C8EF7 50%, #8B6FE8 100%);
      --grad-bp-subtle: linear-gradient(135deg, #EBF1FF 0%, #EDE8FF 100%);
      --grad-charcoal: linear-gradient(160deg, #1E2228 0%, #2C3340 100%);

      --border:rgba(22,22,26,0.10);
      --border-med:rgba(22,22,26,0.18);
      --border-blue:rgba(42,95,192,0.18);
      --off-white:#FAF9F6;
    }
    html,body{height:100%;background:var(--off-white);color:var(--ink);font-family:'Outfit',sans-serif;overflow-x:hidden;}
    /* Add this to style.css to ensure navigation takes priority over the decorative header stripe */
.nav-logo {
  position: relative;
  z-index: 400; /* Must be higher than the 300 used in .site-header::before */
}

    /* â•â• SITE HEADER â•â• */
    .site-header{
      position:sticky;top:0;z-index:200;
      background:var(--off-white);
      box-shadow:
        0 1px 0 rgba(250,249,246,1.0) inset,
        0 8px 0 rgba(27,58,107,0.08),
        0 16px 0 rgba(27,58,107,0.04),
        0 20px 40px rgba(27,58,107,0.18),
        0 40px 80px rgba(27,58,107,0.06);
        
    }
    body{
         padding-top: 140px;
     }
    .site-header{
       position: fixed;
       top: 0;
       left: 0;
       width: 100%;
       z-index: 9999;
    }

    /* â”€â”€ 3D SCENE CANVAS behind the header â”€â”€ */
    #hdrScene{
      position:absolute;inset:0;width:100%;height:100%;
      pointer-events:none;z-index:0;display:block;
    }

    /* â”€â”€ NAV 1 â”€â”€ */
    .nav-logo{
      display:flex;align-items:center;justify-content:space-between;
      padding:14px 36px;
      background:var(--charcoal);
      border-bottom:1px solid var(--border-blue);
      position:relative;z-index:250;
      opacity:0;animation:fdwn .5s ease .05s forwards;
    }

    /* 3D extruded logo */
    .logo-box{
      border:2px solid rgba(76,142,247,0.7);
      border-radius:9px;
      padding:10px 28px;
      font-family:'Playfair Display',serif;
      font-size:20px;font-weight:700;letter-spacing:4px;
      color:var(--blue-deep);
      position:relative;overflow:hidden;cursor:pointer;
      min-width:110px;
      box-shadow:
        4px 4px 0 var(--blue-deep),
        6px 6px 0 rgba(27,58,107,0.25),
        8px 8px 0 rgba(27,58,107,0.10),
        4px 4px 20px rgba(27,58,107,0.20);
      transform:translate(-2px,-2px);
      transition:transform .2s cubic-bezier(.22,1,.36,1), box-shadow .2s, color .2s;
      background:var(--cream);
    }
    .logo-box::after{
      content:'';position:absolute;inset:0;
      background: var(--blue-deep);
      transform:scaleX(0);transform-origin:left;
      transition:transform .35s cubic-bezier(.22,1,.36,1);z-index:-1;
    }
    .logo-box:hover{
      color:var(--cream);
      transform:translate(0,0);
      box-shadow:
        0px 0px 0 var(--blue-deep),
        2px 2px 0 rgba(27,58,107,0.3),
        2px 2px 16px rgba(27,58,107,0.25);
    }
    .logo-box:hover::after{transform:scaleX(1);}

    /* Logo text / image swap */
    .logo-text,.logo-img-wrap{display:block;transition:opacity 0s;}
    .logo-img-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;}
    .logo-img{height:38px;width:auto;display:block;}
    .logo-cover{position:absolute;left:0;right:0;bottom:0;height:0%;background:var(--blue-mid);transition:height 0.38s cubic-bezier(0.77,0,0.18,1);pointer-events:none;z-index:3;}
    .logo-box.wipe-in .logo-cover{height:100%;}
    .logo-box.wipe-out .logo-cover{height:0%;bottom:auto;top:0;transition:height 0.38s cubic-bezier(0.77,0,0.18,1);}
    .logo-box.show-img .logo-img-wrap{opacity:1;}
    .logo-box.show-img .logo-text{opacity:0;}

    /* â”€â”€ HAMBURGER + MEGA NAV PANEL â”€â”€ */
    .hamburger-wrap{position:relative;z-index:500;}
    .hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border-radius:6px;transition:background .2s;}
    .hamburger span{display:block;width:24px;height:1.5px;background:var(--blue-mid);transition:transform .3s, background .2s;}
    .hamburger:hover{background:rgba(42,95,192,0.08);}
    .hamburger:hover span{background:var(--blue-bright);}
    .hamburger:hover span:first-child{transform:translateX(4px);}
    .hamburger:hover span:last-child{transform:translateX(-4px);}

    /* Mega nav dropdown */
    .mega-nav{
      position:fixed;top:60px;right:20px;
      width:780px;
      max-width:calc(100vw - 40px);
      background:var(--charcoal-deep);
      border:1px solid rgba(76,142,247,0.2);
      border-radius:14px;
      overflow-y:auto;
      max-height:calc(100vh - 80px);
      box-shadow:
        0 4px 0 rgba(0,0,0,0.2),
        0 8px 0 rgba(0,0,0,0.12),
        0 24px 60px rgba(0,0,0,0.55),
        0 0 0 1px rgba(255,255,255,0.04) inset;
      opacity:0;visibility:hidden;
      transform:translateY(-10px) scale(0.97);
      transform-origin:top right;
      transition:opacity .28s cubic-bezier(.22,1,.36,1), transform .28s cubic-bezier(.22,1,.36,1), visibility .28s;
      z-index:9999;
    }
    .hamburger-wrap:hover .mega-nav,
    .mega-nav:hover{opacity:1;visibility:visible;transform:translateY(0) scale(1);}
    /* Increase width to hold 3 columns comfortably */

/* Ensure the middle column also has a border to maintain the line pattern */
.mega-nav-col:first-child,
.mega-nav-col:nth-child(2) {
  border-right: 1px solid rgba(255, 255, 255, 0.06);
}

    .mega-nav-header{
      padding:18px 24px 14px;
      border-bottom:1px solid var(--border-blue);
      background:linear-gradient(135deg, rgba(27,58,107,0.5) 0%, rgba(44,51,64,0.8) 100%);
      display:flex;align-items:center;gap:10px;
    }
    .mega-nav-header-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--blue-pale);opacity:.7;}
    .mega-nav-header-dot{width:5px;height:5px;border-radius:50%;background:var(--blue-bright);box-shadow:0 0 8px var(--blue-bright);}

    .mega-nav-grid{display:grid;grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));gap:0;}

    .mega-nav-col{padding:20px 24px;}
    .mega-nav-col:first-child{border-right:1px solid rgba(255,255,255,0.06);}
    .mega-nav-col-title{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--blue-bright);opacity:.8;margin-bottom:12px;font-weight:500;}

    .mega-nav-col a{
      display:flex;align-items:center;gap:10px;
      text-decoration:none;color:rgba(200,218,255,0.65);
      font-size:13px;font-weight:300;letter-spacing:.3px;
      padding:9px 10px;border-radius:7px;
      transition:color .2s, background .2s, transform .15s;
      position:relative;
    }
    .mega-nav-col a::before{
      content:'';width:4px;height:4px;border-radius:50%;
      background:var(--blue-bright);opacity:0;
      transition:opacity .2s, transform .2s;
      flex-shrink:0;
    }
    .mega-nav-col a:hover{color:#fff;background:rgba(76,142,247,0.10);transform:translateX(4px);}
    .mega-nav-col a:hover::before{opacity:1;}

    .mega-nav-footer{
      padding:14px 24px;
      border-top:1px solid rgba(255,255,255,0.06);
      background:linear-gradient(135deg, rgba(30,34,40,0.9) 0%, rgba(19,22,27,0.9) 100%);
      display:flex;align-items:center;justify-content:space-between;
    }
    .mega-nav-cta-text{font-size:12px;color:rgba(200,218,255,0.5);letter-spacing:.3px;}
    .mega-nav-cta-btn{
      background:var(--grad-bp-bright);color:#fff;border:none;
      border-radius:6px;padding:9px 20px;font-family:'Outfit',sans-serif;
      font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
      cursor:pointer;
      box-shadow:2px 2px 0 rgba(0,0,0,0.3), 0 4px 16px rgba(76,142,247,0.25);
      transform:translate(-1px,-1px);transition:transform .15s, box-shadow .15s;
    }
    .mega-nav-cta-btn:hover{transform:translate(0,0);box-shadow:0 0 0 rgba(0,0,0,0.3),0 2px 12px rgba(76,142,247,0.3);}

    /* â”€â”€ NAV 2 â€” categories â”€â”€ */
    .nav-cats{
      display:flex;padding:0 18px;
      background:var(--blue-tint);
      overflow-x:auto;scrollbar-width:none;
      position:relative;z-index:2;
      opacity:0;animation:fdwn .5s ease .12s forwards;
      border-top:1px solid rgba(255,255,255,0.8);
      border-bottom:1px solid rgba(42,95,192,0.2);
      box-shadow:
        0 2px 0 rgba(27,58,107,0.10),
        0 4px 0 rgba(27,58,107,0.06),
        0 6px 0 rgba(27,58,107,0.03);
    }
    .nav-cats::-webkit-scrollbar{display:none;}
    .nav-cats a{
      text-decoration:none;color:var(--blue-deep);
      font-size:10.6px;font-weight:400;letter-spacing:.4px;
      padding:13px 20px;white-space:nowrap;
      border-right:1px solid rgba(255,255,255,0.06);
      transition:color .2s, background .2s, transform .15s, box-shadow .15s;
      position:relative;display:block;
    }
    .nav-cats a:hover{
      color:var(--blue-bright);
      background:rgba(76,142,247,0.08);
      box-shadow:0 3px 0 rgba(42,95,192,0.15) inset;
      transform:translateY(1px);
    }
    .nav-cats a::after{
      content:'';position:absolute;bottom:0;left:20px;right:20px;
      height:2px;background:var(--grad-bp-bright);
      transform:scaleX(0);transition:transform .25s cubic-bezier(.22,1,.36,1);
    }
    .nav-cats a:hover::after,.nav-cats a.active::after{transform:scaleX(1);}
    .nav-cats a.active{color:var(--blue-mid);font-weight:500;}

    /* â”€â”€ NAV 3 â€” products â”€â”€ */
    .nav-products{
      display:flex;padding:0 18px;
      background:var(--charcoal);
      overflow-x:auto;scrollbar-width:none;
      position:relative;z-index:2;
      opacity:0;animation:fdwn .5s ease .22s forwards;
      border-top:1px solid rgba(255,255,255,0.9);
      box-shadow:
        0 3px 0 rgba(27,58,107,0.12),
        0 6px 0 rgba(27,58,107,0.06),
        0 9px 0 rgba(27,58,107,0.03),
        0 12px 30px rgba(27,58,107,0.12);
    }
    .nav-products::-webkit-scrollbar{display:none;}
    .nav-products a{
      text-decoration:none;color:var(--cream-soft);
      font-size:10.6px;font-weight:300;letter-spacing:.5px;
      padding:10px 35px;white-space:nowrap;
      transition:color .2s,background .2s,transform .15s;
      position:relative;
    }
    .nav-products a::before{
      content:'';position:absolute;inset:5px 6px;
      border-radius:5px;background:transparent;
      box-shadow:none;
      transition:background .2s, box-shadow .2s, transform .15s;
    }
    .nav-products a:hover{color:var(--blue-bright);}
    .nav-products a:hover::before{
      background:rgba(76,142,247,0.10);
      box-shadow:
        0 2px 0 rgba(76,142,247,0.2),
        0 4px 8px rgba(76,142,247,0.10);
    }

    /* â•â• HERO â•â• */
    .hero{display:grid;grid-template-columns:minmax(380px,30%) 1fr;}
    .hero-left{
      padding:56px 36px 100px;display:flex;flex-direction:column;
      justify-content:center;position:relative;
      background:linear-gradient(160deg, var(--charcoal-deep) 0%, var(--charcoal) 60%, #1a2030 100%);
      z-index:2;
      /* Subtle noise/grain texture via SVG */
    }
    /* Subtle blue glow in hero left */
    .hero-left::before{
      content:'';position:absolute;inset:0;
      background:radial-gradient(ellipse 80% 60% at 20% 60%, rgba(42,95,192,0.12) 0%, transparent 70%);
      pointer-events:none;
    }
    .hero-left::after{
      content:'';position:absolute;right:0;top:12%;bottom:12%;
      width:1.5px;
      background:linear-gradient(to bottom,transparent 0%,var(--blue-mid) 35%,#8B6FE8 65%,transparent 100%);
      opacity:0;animation:fin 1.2s ease 2s forwards;
    }
    .tagline{
      font-size:11px;font-weight:400;color:rgba(200,218,255,0.65);
      letter-spacing:1.5px;text-transform:uppercase;line-height:1.8;
      max-width:210px;margin-bottom:30px;
      opacity:0;transform:translateY(14px);
      animation:rise .8s cubic-bezier(.22,1,.36,1) .7s forwards;
    }
    .hero-headline{
      font-family:'Playfair Display',serif;
      font-size:clamp(46px,5.2vw,66px);font-weight:700;
      line-height:1.02;letter-spacing:-.5px;color:#fff;
    }
    .word{display:block;overflow:hidden;line-height:1.1;}
    .word span{display:block;opacity:0;transform:translateY(105%);}
    .word:nth-child(1) span{animation:wrd .75s cubic-bezier(.22,1,.36,1) .95s forwards;}
    .word:nth-child(2) span{animation:wrd .75s cubic-bezier(.22,1,.36,1) 1.12s forwards;}
    .word:nth-child(3) span{animation:wrd .75s cubic-bezier(.22,1,.36,1) 1.29s forwards;}
    .word:nth-child(4) span{animation:wrd .75s cubic-bezier(.22,1,.36,1) 1.46s forwards;}
    .word.accent span{
      background:var(--grad-bp-bright);
      -webkit-background-clip:text;-webkit-text-fill-color:transparent;
      background-clip:text;font-style:italic;
    }
    .accent-line{width:0;height:2px;background:var(--grad-bp-bright);margin-top:20px;border-radius:2px;box-shadow:0 0 12px rgba(76,142,247,0.4);animation:gline .9s cubic-bezier(.22,1,.36,1) 1.7s forwards;}
    .hero-sub{margin-top:16px;font-size:11px;font-weight:300;color:rgba(200,218,255,0.55);letter-spacing:1.5px;text-transform:uppercase;opacity:0;animation:rise .8s cubic-bezier(.22,1,.36,1) 1.75s forwards;}

    .hero-visual{position:relative;overflow:hidden;background:var(--charcoal-deep);opacity:0;animation:fin 1s ease .4s forwards;}
    #roomCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;}
    .corner-tl{position:absolute;top:18px;left:18px;z-index:5;pointer-events:none;opacity:0;animation:fin 1s ease 1.5s forwards;}
    .corner-br{position:absolute;bottom:18px;right:18px;z-index:5;pointer-events:none;opacity:0;animation:fin 1s ease 1.6s forwards;}
    .stage-label{
      position:absolute;bottom:24px;left:24px;z-index:10;
      background:rgba(19,22,27,0.88);border:1px solid rgba(76,142,247,0.25);
      border-radius:3px;padding:5px 14px;font-size:10px;font-weight:500;
      color:var(--blue-pale);letter-spacing:2px;text-transform:uppercase;
      backdrop-filter:blur(10px);transition:opacity .5s;
    }

    /* â•â• CONTACT STRIP â•â• */
    .contact-strip{
      position:sticky;bottom:0;display:flex;align-items:center;
      justify-content:space-between;padding:17px 36px;
      background:var(--blue-tint);
      border-top:1px solid var(--border-blue);
      box-shadow:0 -1px 0 rgba(42,95,192,0.15), 0 -8px 20px rgba(27,58,107,0.10);
      z-index:100;opacity:0;animation:fup .7s cubic-bezier(.22,1,.36,1) 2s forwards;
    }
    .contact-text{font-family:'Playfair Display',serif;font-size:18px;font-weight:400;font-style:italic;color:var(--blue-deep);}
    .contact-text strong{font-style:normal;font-weight:700;color:var(--blue-deep);}
    .contact-btn{
      position:relative;
      background:var(--grad-bp-bright);
      border:none;color:#fff;
      border-radius:6px;padding:12px 30px;
      font-family:'Outfit',sans-serif;font-size:12px;font-weight:500;
      letter-spacing:1.8px;text-transform:uppercase;cursor:pointer;overflow:hidden;
      box-shadow:
        4px 4px 0 rgba(0,0,0,0.4),
        6px 6px 12px rgba(76,142,247,0.2),
        0 0 0 1px rgba(255,255,255,0.08) inset;
      transform:translate(-2px,-2px);
      transition:transform .15s,box-shadow .15s;
    }
    .contact-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#6B4EBB,#4C8EF7);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.22,1,.36,1);}
    .contact-btn span{position:relative;z-index:1;}
    .contact-btn:hover::before{transform:scaleX(1);}
    .contact-btn:hover{transform:translate(0,0);box-shadow:0px 0px 0 rgba(0,0,0,0.4),2px 2px 12px rgba(76,142,247,0.3);}
    .contact-btn:active{transform:translate(2px,2px);box-shadow:none;}

    /* â•â• HOW IT WORKS â•â• */
    .hiw-section{
      padding:80px 44px 100px;
      background:linear-gradient(160deg, #F6F2EC 0%, #F0EBE2 50%, #EBE5DC 100%);
      display:flex;gap:40px;align-items:stretch;min-height:640px;overflow:hidden;
      position:relative;
    }
    /* Charcoal top stripe on hiw-section for contrast */
    .hiw-section::before{
      content:'';position:absolute;top:0;left:0;right:0;height:4px;
      background:var(--grad-bp-bright);
    }
    .hiw-left{flex:0 0 380px;display:flex;flex-direction:column;align-self:stretch;position:relative;}
    .hiw-pill{
      display:flex;flex-direction:column;overflow:hidden;position:relative;
      background:var(--cream);
      border:1.5px solid var(--border-blue);
      border-top:none;
      border-radius:16px;
      /* 3D charcoal shadow for depth */
      box-shadow:
        0 8px 0 rgba(30,34,40,0.12),
        0 16px 0 rgba(30,34,40,0.06),
        0 8px 32px rgba(27,58,107,.12),
        0 2px 8px rgba(27,58,107,.06);
      min-height:480px;
    }
    /* Gradient top border on pill */
    .hiw-pill::before{
      content:'';position:absolute;top:0;left:0;right:0;height:3px;
      background:var(--grad-bp-bright);border-radius:16px 16px 0 0;z-index:2;
    }
    .hiw-pill-inner{overflow:hidden;background:var(--blue-tint);display:flex;align-items:center;justify-content:center;flex:1;}
    .hiw-pill-inner img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;}
    .hiw-pill-label{padding:16px 20px 12px;font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--blue-mid);background:var(--cream);border-bottom:1px solid var(--border-blue);}
    .hiw-right{flex:1;display:flex;flex-direction:column;gap:20px;overflow:hidden;position:relative;}
    .hiw-carousel-viewport{flex:1;overflow:hidden;position:relative;}
    .hiw-carousel-track{display:flex;width:100%;height:100%;transition:transform .72s cubic-bezier(.77,0,.175,1);will-change:transform;}
    .hiw-slide{flex:0 0 100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr;gap:20px;align-content:start;padding-right:2px;}
    .hiw-text-block{grid-column:1;grid-row:1;padding:10px 4px 0;display:flex;flex-direction:column;gap:12px;}
    .hiw-step-tag{font-size:10px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;color:var(--blue-bright);opacity:.9;}
    .hiw-slide-title{font-family:'Playfair Display',serif;font-size:clamp(22px,2.8vw,34px);font-weight:700;color:var(--charcoal);line-height:1.12;}
    .hiw-slide-body{font-size:13px;font-weight:300;color:var(--ink-soft);line-height:1.75;max-width:300px;}
    .hiw-card-top{grid-column:2;grid-row:1;border-radius:22px;overflow:hidden;background:var(--blue-pale);min-height:200px;position:relative;box-shadow:0 4px 0 rgba(30,34,40,0.12),0 8px 0 rgba(30,34,40,0.06),0 4px 28px rgba(42,95,192,.10);}
    .hiw-card-bottom{grid-column:1/-1;grid-row:2;border-radius:22px;overflow:hidden;background:var(--blue-pale);min-height:220px;position:relative;box-shadow:0 4px 0 rgba(30,34,40,0.12),0 8px 0 rgba(30,34,40,0.06),0 4px 28px rgba(42,95,192,.10);}
    .hiw-card-top img,.hiw-card-bottom img{width:100%;height:100%;object-fit:fill;position:absolute;inset:0;}
    .hiw-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--blue-mid);letter-spacing:1.2px;text-transform:uppercase;opacity:.45;font-weight:300;}
    .hiw-dots{display:flex;align-items:center;gap:8px;padding:0 4px;flex-shrink:0;}
    .hiw-dot{width:6px;height:6px;border-radius:50%;background:var(--blue-pale);cursor:pointer;transition:background .3s,width .3s;border:none;padding:0;outline:none;}
    .hiw-dot.active{width:24px;border-radius:4px;background:var(--grad-bp-bright);}
    .hiw-nav{display:flex;gap:10px;margin-left:auto;}
    .hiw-nav-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--charcoal-soft);background:var(--charcoal);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s;box-shadow:0 2px 0 rgba(0,0,0,0.25);}
    .hiw-nav-btn:hover{background:var(--blue-deep);border-color:var(--blue-mid);}
    .hiw-nav-btn:hover svg path{stroke:#fff;}
    .hiw-nav-btn svg path{stroke:rgba(200,218,255,0.7);transition:stroke .2s;}
    .hiw-controls{display:flex;align-items:center;padding:0 4px;flex-shrink:0;}

    /* â•â• ABOUT US â•â• */
    .about-section{
      padding:90px 44px 100px;
      background:var(--off-white);
      display:flex;
      flex-direction:column;
      align-items:center;
      gap:64px;
      position:relative;
    }
    /* Charcoal top accent */
    .about-section::before{
      content:'';position:absolute;top:0;left:0;right:0;height:4px;
      background:linear-gradient(90deg, var(--charcoal) 0%, var(--charcoal-mid) 100%);
    }

    .about-eyebrow{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;}
    .about-eyebrow-tag{
      font-size:10px;font-weight:500;letter-spacing:3px;
      text-transform:uppercase;color:var(--charcoal-soft);
      display:flex;align-items:center;gap:10px;
    }
    .about-eyebrow-tag::before,.about-eyebrow-tag::after{
      content:'';display:block;width:32px;height:1px;background:var(--charcoal-soft);opacity:.4;
    }
    .about-title{
      font-family:'Playfair Display',serif;
      font-size:clamp(30px,3.5vw,46px);font-weight:700;
      color:var(--charcoal);line-height:1.1;letter-spacing:-.3px;
      max-width:640px;
    }
    .about-title em{
      background:var(--grad-bp-bright);
      -webkit-background-clip:text;-webkit-text-fill-color:transparent;
      background-clip:text;font-style:italic;
    }
    .about-subtitle{font-size:14px;font-weight:300;color:var(--ink-soft);line-height:1.75;max-width:560px;text-align:center;}

    .about-body{display:grid;grid-template-columns:1fr 1fr;gap:28px;width:100%;}

    /* LEFT dark card â€” now full charcoal with gradient */
    .about-card-dark{
      background:var(--grad-charcoal);
      border-radius:20px;
      padding:48px 44px 48px;
      display:flex;flex-direction:column;
      justify-content:space-between;
      gap:32px;
      position:relative;overflow:hidden;
      box-shadow:
        6px 6px 0 rgba(0,0,0,0.4),
        8px 8px 0 rgba(0,0,0,0.18),
        0 24px 60px rgba(0,0,0,0.28),
        0 0 0 1px rgba(255,255,255,0.04) inset;
      border:1px solid rgba(76,142,247,0.12);
    }
    /* Blue-purple gradient accent top bar */
    .about-card-dark::after{
      content:'';position:absolute;top:0;left:0;right:0;height:3px;
      background:var(--grad-bp-bright);border-radius:20px 20px 0 0;
    }
    /* Grid pattern */
    .about-card-dark::before{
      content:'';position:absolute;inset:0;
      background-image:
        linear-gradient(rgba(76,142,247,0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(76,142,247,0.05) 1px, transparent 1px);
      background-size:40px 40px;pointer-events:none;
    }
    .about-card-dark-top{position:relative;z-index:1;}
    .about-card-tag{font-size:10px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--blue-pale);opacity:.6;margin-bottom:18px;display:block;}
    .about-card-body{font-size:13px;font-weight:300;color:rgba(200,218,255,0.65);line-height:1.8;margin-bottom:24px;}
    .about-card-headline{
      font-family:'Playfair Display',serif;
      font-size:clamp(32px,3.8vw,52px);font-weight:700;
      color:#fff;line-height:1.05;letter-spacing:-.5px;
    }
    .about-card-headline em{
      background:var(--grad-bp-bright);
      -webkit-background-clip:text;-webkit-text-fill-color:transparent;
      background-clip:text;font-style:italic;
    }
    .about-card-quote{
      position:relative;z-index:1;
      border-left:2px solid var(--blue-bright);
      padding-left:16px;
      font-size:13px;font-weight:300;
      color:rgba(200,218,255,0.55);
      line-height:1.7;font-style:italic;
    }

    /* RIGHT form card */
    .about-card-form{
      background:var(--cream);
      border:1.5px solid var(--border-blue);
      border-top:none;
      border-radius:20px;overflow:hidden;
      display:flex;flex-direction:column;
      box-shadow:
        0 6px 0 rgba(30,34,40,0.10),
        0 12px 0 rgba(30,34,40,0.05),
        0 8px 32px rgba(27,58,107,.10);
      position:relative;
    }
    .about-card-form::before{
      content:'';position:absolute;top:0;left:0;right:0;height:3px;
      background:var(--grad-bp-bright);z-index:2;border-radius:20px 20px 0 0;
    }
    .about-form-header{
      background:var(--charcoal-deep);
      padding:18px 28px;display:flex;flex-direction:column;gap:4px;
      border-bottom:1px solid rgba(255,255,255,0.06);
    }
    .about-form-header-tag{font-size:10px;font-weight:400;letter-spacing:2px;text-transform:uppercase;color:var(--blue-pale);opacity:.6;}
    .about-form-header-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:#fff;}
    .about-form-body{padding:28px;}
    .about-form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
    .about-form-row label{font-size:10px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--charcoal-soft);}
    .about-form-row input,.about-form-row select,.about-form-row textarea{
      background:var(--blue-tint);
      border:1px solid var(--border-blue);
      border-radius:7px;padding:11px 14px;
      font-family:'Outfit',sans-serif;font-size:13px;font-weight:300;color:var(--ink);
      outline:none;transition:border-color .2s, box-shadow .2s, background .2s;width:100%;
    }
    .about-form-row input:focus,.about-form-row select:focus,.about-form-row textarea:focus{
      border-color:var(--blue-mid);background:#fff;
      box-shadow:0 0 0 3px rgba(42,95,192,0.10);
    }
    .about-form-row input::placeholder,.about-form-row textarea::placeholder{color:var(--blue-mid);opacity:.4;}
    .about-form-row select{appearance:none;cursor:pointer;}
    .about-form-row textarea{resize:none;height:80px;}
    .about-form-row-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
    .about-form-submit{
      width:100%;
      background:var(--grad-charcoal);
      color:#fff;border:none;border-radius:8px;padding:14px;
      font-family:'Outfit',sans-serif;font-size:12px;font-weight:500;letter-spacing:2px;
      text-transform:uppercase;cursor:pointer;margin-top:4px;
      position:relative;overflow:hidden;
      box-shadow:
        3px 3px 0 rgba(0,0,0,0.4),
        0 8px 20px rgba(0,0,0,.2),
        0 0 0 1px rgba(255,255,255,0.04) inset;
      transform:translate(-1px,-1px);transition:transform .15s, box-shadow .15s;
    }
    .about-form-submit::before{
      content:'';position:absolute;inset:0;
      background:var(--grad-bp-bright);
      transform:scaleX(0);transform-origin:left;
      transition:transform .35s cubic-bezier(.22,1,.36,1);
    }
    .about-form-submit span{position:relative;z-index:1;}
    .about-form-submit:hover::before{transform:scaleX(1);}
    .about-form-submit:hover{transform:translate(0,0);box-shadow:0 0 0 rgba(0,0,0,0.4),2px 2px 12px rgba(76,142,247,.25);}
    .about-form-submit:active{transform:translate(2px,2px);box-shadow:none;}

    /* STATS STRIP */
    .about-stats{
      width:100%;display:grid;grid-template-columns:repeat(4,1fr);gap:0;
      border:1.5px solid var(--border-blue);border-radius:16px;overflow:hidden;
      box-shadow:
        0 6px 0 rgba(30,34,40,0.12),
        0 12px 0 rgba(30,34,40,0.06),
        0 4px 24px rgba(27,58,107,.10);
    }
    .about-stat{
      padding:32px 28px;background:var(--blue-tint);
      border-right:1px solid var(--border-blue);
      display:flex;flex-direction:column;gap:8px;position:relative;transition:background .2s;
    }
    .about-stat:last-child{border-right:none;}
    .about-stat:hover{background:rgba(200,218,255,0.55);}
    .about-stat::before{
      content:'';position:absolute;top:0;left:0;right:0;height:3px;
      background:var(--grad-bp-bright);opacity:0;transition:opacity .2s;
    }
    .about-stat:hover::before{opacity:1;}
    .about-stat-num{
      font-family:'Playfair Display',serif;
      font-size:clamp(32px,3vw,44px);font-weight:700;
      color:var(--charcoal);line-height:1;
      display:flex;align-items:flex-start;gap:4px;
    }
    .about-stat-num sup{
      font-size:.45em;font-weight:700;
      background:var(--grad-bp-bright);
      -webkit-background-clip:text;-webkit-text-fill-color:transparent;
      background-clip:text;margin-top:6px;
    }
    .about-stat-label{font-size:11px;font-weight:400;letter-spacing:.6px;color:var(--ink-soft);line-height:1.5;}


    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       ENHANCED HEADER â€” MORE POP
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .site-header{
      background:linear-gradient(180deg,rgba(250,249,246,0.97) 0%,rgba(235,241,255,0.96) 100%);
      backdrop-filter:blur(16px);
      border-bottom:1px solid rgba(42,95,192,0.15);
      box-shadow:
        0 1px 0 rgba(255,255,255,0.9) inset,
        0 6px 0 rgba(42,95,192,0.06),
        0 12px 0 rgba(42,95,192,0.04),
        0 20px 50px rgba(27,58,107,0.22),
        0 40px 100px rgba(27,58,107,0.10);
    }
    /* Gradient accent stripe at very top of header */
    .site-header::before{
      content:'';position:absolute;top:0;left:0;right:0;height:3px;
      background:linear-gradient(90deg,#1B3A6B 0%,#2A5FC0 30%,#4C8EF7 55%,#8B6FE8 80%,#1B3A6B 100%);
      background-size:200% 100%;
      animation:headerStripe 6s linear infinite;
      z-index:300;
    }
    @keyframes headerStripe{
      0%{background-position:0% 0%;}
      100%{background-position:200% 0%;}
    }
    /* Logo box â€” more presence */
    .logo-box{
      box-shadow:
        5px 5px 0 var(--blue-deep),
        7px 7px 0 rgba(27,58,107,0.22),
        9px 9px 0 rgba(27,58,107,0.10),
        5px 5px 24px rgba(27,58,107,0.25),
        0 0 0 1px rgba(76,142,247,0.15) inset;
    }
    /* Nav cats â€” stronger visual */
    .nav-cats{
      background:linear-gradient(180deg,rgba(235,241,255,0.95) 0%,rgba(200,218,255,0.30) 100%);
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       WORK IN ACTION SECTION
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .wia-section{
      padding:100px 44px 110px;
      background:var(--cream);
      position:relative;
      overflow:hidden;
    }
    .wia-section::before{
      content:'';position:absolute;top:0;left:0;right:0;height:4px;
      background:var(--grad-bp-bright);
    }
    /* Subtle grid background */
    .wia-section::after{
      content:'';position:absolute;inset:0;
      background-image:
        linear-gradient(rgba(42,95,192,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(42,95,192,0.03) 1px, transparent 1px);
      background-size:60px 60px;pointer-events:none;
    }
    .wia-eyebrow{
      display:flex;align-items:center;gap:14px;margin-bottom:20px;
      position:relative;z-index:1;
    }
    .wia-label{
      font-size:10px;font-weight:600;letter-spacing:4px;
      text-transform:uppercase;color:var(--blue-mid);
      display:flex;align-items:center;gap:12px;
    }
    .wia-label::before,.wia-label::after{
      content:'';display:block;width:36px;height:1.5px;
      background:var(--grad-bp-bright);border-radius:1px;
    }
    .wia-headline-row{
      display:grid;grid-template-columns:1fr 1fr;gap:40px;
      align-items:end;margin-bottom:48px;
      position:relative;z-index:1;
    }
    .wia-headline{
      font-family:'Playfair Display',serif;
      font-size:clamp(32px,4vw,54px);font-weight:700;
      color:var(--charcoal);line-height:1.06;letter-spacing:-.5px;
    }
    .wia-headline sup{
      font-size:.45em;font-weight:700;
      background:var(--grad-bp-bright);
      -webkit-background-clip:text;-webkit-text-fill-color:transparent;
      background-clip:text;vertical-align:super;
    }
    .wia-sub{
      font-size:14px;font-weight:300;color:var(--ink-soft);
      line-height:1.75;max-width:520px;align-self:end;
    }

    /* FILTER TABS */
    .wia-tabs{
      display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px;
      position:relative;z-index:1;
    }
    .wia-tab{
      padding:9px 20px;border-radius:100px;
      font-family:'Outfit',sans-serif;font-size:12px;font-weight:400;
      letter-spacing:.5px;cursor:pointer;
      background:transparent;
      border:1.5px solid var(--border-blue);
      color:var(--blue-deep);
      transition:all .22s cubic-bezier(.22,1,.36,1);
    }
    .wia-tab:hover{
      background:var(--blue-tint);border-color:var(--blue-mid);
      color:var(--blue-mid);transform:translateY(-1px);
      box-shadow:0 4px 12px rgba(42,95,192,0.12);
    }
    .wia-tab.active{
      background:var(--grad-bp-bright);border-color:transparent;
      color:#fff;font-weight:500;
      box-shadow:3px 3px 0 rgba(0,0,0,0.2),0 8px 20px rgba(42,95,192,0.25);
      transform:translate(-1px,-1px);
    }

    /* PROJECTS GRID */
    .wia-grid{
      display:grid;
      grid-template-columns:1fr 1fr 1fr;
      grid-template-rows:auto auto;
      gap:20px;
      position:relative;z-index:1;
      margin-bottom:56px;
    }
    /* Featured card spans 2 rows on first col */
    .wia-card--featured{
      grid-row:span 2;
    }
    .wia-card{
      background:var(--off-white);
      border:1.5px solid var(--border-blue);
      border-radius:18px;overflow:hidden;
      display:flex;flex-direction:column;
      transition:transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s, opacity .3s;
      box-shadow:
        0 4px 0 rgba(30,34,40,0.08),
        0 8px 0 rgba(30,34,40,0.04),
        0 6px 24px rgba(27,58,107,0.08);
      position:relative;
    }
    .wia-card::before{
      content:'';position:absolute;top:0;left:0;right:0;height:2.5px;
      background:var(--grad-bp-bright);opacity:0;
      transition:opacity .25s;border-radius:18px 18px 0 0;
    }
    .wia-card:hover{
      transform:translateY(-6px) scale(1.01);
      box-shadow:
        0 0 0 rgba(30,34,40,0.08),
        0 20px 60px rgba(27,58,107,0.16),
        0 0 0 1.5px rgba(76,142,247,0.3);
    }
    .wia-card:hover::before{opacity:1;}
    .wia-card-img{
      width:100%;
      flex:1;min-height:200px;
      display:flex;align-items:center;justify-content:center;
      position:relative;overflow:hidden;
    }
    .wia-card--featured .wia-card-img{min-height:340px;}
    .wia-card-img-placeholder{
      display:flex;flex-direction:column;align-items:center;justify-content:center;
      gap:14px;text-align:center;
    }
    .wia-card-img-placeholder span{
      font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
      color:rgba(200,218,255,0.5);font-weight:300;
    }
    .wia-card-body{padding:22px 22px 24px;}
    .wia-card-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px;}
    .wia-card-tag{
      font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
      color:#fff;background:var(--grad-bp-bright);
      padding:4px 12px;border-radius:100px;
      box-shadow:2px 2px 0 rgba(0,0,0,0.2);
    }
    .wia-card-area{
      font-size:11px;font-weight:500;color:var(--blue-mid);
      letter-spacing:.5px;opacity:.75;
    }
    .wia-card-title{
      font-family:'Playfair Display',serif;
      font-size:clamp(17px,1.6vw,22px);font-weight:700;
      color:var(--charcoal);line-height:1.2;margin-bottom:8px;
    }
    .wia-card-desc{
      font-size:13px;font-weight:300;color:var(--ink-soft);line-height:1.7;
    }
    /* CTA row */
    .wia-cta-row{
      display:flex;align-items:center;justify-content:center;
      gap:28px;position:relative;z-index:1;
    }
    .wia-cta-text{
      font-family:'Playfair Display',serif;
      font-size:18px;font-weight:400;font-style:italic;
      color:var(--blue-deep);
    }
    .wia-cta-btn{
      position:relative;background:var(--grad-charcoal);
      border:none;color:#fff;border-radius:7px;
      padding:13px 32px;font-family:'Outfit',sans-serif;
      font-size:12px;font-weight:500;letter-spacing:1.8px;
      text-transform:uppercase;cursor:pointer;overflow:hidden;
      box-shadow:
        4px 4px 0 rgba(0,0,0,0.4),
        6px 6px 14px rgba(27,58,107,0.2),
        0 0 0 1px rgba(255,255,255,0.05) inset;
      transform:translate(-2px,-2px);
      transition:transform .15s, box-shadow .15s;
    }
    .wia-cta-btn::before{
      content:'';position:absolute;inset:0;
      background:var(--grad-bp-bright);
      transform:scaleX(0);transform-origin:left;
      transition:transform .35s cubic-bezier(.22,1,.36,1);
    }
    .wia-cta-btn span{position:relative;z-index:1;}
    .wia-cta-btn:hover::before{transform:scaleX(1);}
    .wia-cta-btn:hover{transform:translate(0,0);box-shadow:0 2px 12px rgba(76,142,247,0.3);}
    .wia-cta-btn:active{transform:translate(2px,2px);box-shadow:none;}

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       SITE FOOTER
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .site-footer-main{
      background:var(--charcoal-deep);
      position:relative;overflow:hidden;
      padding:0;
      border-top:1px solid rgba(76,142,247,0.15);
    }
    /* Gradient top accent on footer */
    .site-footer-main::before{
      content:'';position:absolute;top:0;left:0;right:0;height:3px;
      background:var(--grad-bp-bright);z-index:2;
    }
    .footer-top{
      display:grid;grid-template-columns:1fr 2fr;
      gap:60px;padding:72px 60px 56px;
      position:relative;z-index:1;
    }
    .footer-brand{display:flex;flex-direction:column;gap:20px;}
    .footer-logo{
      font-family:'Playfair Display',serif;
      font-size:32px;font-weight:700;letter-spacing:5px;
      color:#fff;
      background:var(--grad-bp-bright);
      -webkit-background-clip:text;-webkit-text-fill-color:transparent;
      background-clip:text;
    }
    .footer-tagline{
      font-size:13px;font-weight:300;
      color:rgba(200,218,255,0.55);
      line-height:1.75;max-width:280px;
    }
    .footer-socials{display:flex;gap:10px;}
    .footer-contact-list{
      display:flex;flex-direction:column;gap:6px;
      margin-top:4px;
    }
    .footer-contact-link{
      color:rgba(200,218,255,0.75);
      text-decoration:none;
      font-size:13px;
      line-height:1.5;
      transition:color .2s;
    }
    .footer-contact-link:hover{color:#fff;}
    .footer-company-info{
      display:flex;flex-direction:column;gap:4px;
      margin-top:8px;
      color:rgba(200,218,255,0.72);
      font-size:13px;
      line-height:1.5;
    }
    .footer-social{
      width:36px;height:36px;border-radius:8px;
      border:1px solid rgba(76,142,247,0.2);
      background:rgba(76,142,247,0.08);
      color:rgba(200,218,255,0.6);
      display:flex;align-items:center;justify-content:center;
      text-decoration:none;
      transition:color .2s, background .2s, border-color .2s, transform .15s;
    }
    .footer-social:hover{
      color:#fff;background:rgba(76,142,247,0.22);
      border-color:rgba(76,142,247,0.5);
      transform:translateY(-2px);
    }
    .footer-links-grid{
      display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
    }
    .footer-col{display:flex;flex-direction:column;gap:11px;}
    .footer-col-title{
      font-size:10px;font-weight:600;letter-spacing:2.5px;
      text-transform:uppercase;color:var(--blue-bright);opacity:.85;
      margin-bottom:4px;
    }
    .footer-col a{
      text-decoration:none;color:rgba(200,218,255,0.55);
      font-size:13px;font-weight:300;letter-spacing:.2px;
      transition:color .2s, transform .15s;
      display:inline-block;
    }
    .footer-col a:hover{color:#fff;transform:translateX(4px);}

    .footer-divider{
      height:1px;background:rgba(76,142,247,0.10);
      margin:0 60px;position:relative;z-index:1;
    }

    .footer-contact-bar{
      display:flex;align-items:center;gap:32px;
      padding:24px 60px;
      position:relative;z-index:1;
      flex-wrap:wrap;
    }
    .footer-contact-item{
      display:flex;align-items:center;gap:8px;
      font-size:13px;font-weight:300;
      color:rgba(200,218,255,0.60);
    }
    .footer-contact-item svg{color:var(--blue-bright);flex-shrink:0;opacity:.8;}
    .footer-cta-btn{
      margin-left:auto;
      position:relative;background:var(--grad-bp-bright);
      border:none;color:#fff;border-radius:7px;
      padding:12px 28px;font-family:'Outfit',sans-serif;
      font-size:11px;font-weight:500;letter-spacing:1.8px;
      text-transform:uppercase;cursor:pointer;overflow:hidden;
      box-shadow:3px 3px 0 rgba(0,0,0,0.3),0 8px 20px rgba(76,142,247,0.2);
      transform:translate(-1px,-1px);
      transition:transform .15s, box-shadow .15s;
    }
    .footer-cta-btn span{position:relative;z-index:1;}
    .footer-cta-btn:hover{transform:translate(0,0);box-shadow:0 4px 16px rgba(76,142,247,0.35);}
    .footer-cta-btn:active{transform:translate(2px,2px);box-shadow:none;}

    .footer-bottom{
      display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;
      gap:12px;padding:18px 60px 28px;
      border-top:1px solid rgba(76,142,247,0.08);
      position:relative;z-index:1;
    }
    .footer-copy{
      font-size:11.5px;color:rgba(200,218,255,0.35);letter-spacing:.3px;
    }
    .footer-legal{display:flex;align-items:center;gap:10px;}
    .footer-legal a{
      font-size:11.5px;color:rgba(200,218,255,0.35);
      text-decoration:none;transition:color .2s;letter-spacing:.3px;
    }
    .footer-legal a:hover{color:rgba(200,218,255,0.7);}
    .footer-legal span{color:rgba(200,218,255,0.2);}
    .footer-made{
      font-size:11px;color:rgba(200,218,255,0.25);
      letter-spacing:.5px;
    }

    @media (max-width: 1100px){
      .footer-top{grid-template-columns:1fr;gap:36px;}
      .footer-links-grid{grid-template-columns:repeat(2,1fr);}
    }

    @media (max-width: 640px){
      .footer-top{padding:48px 18px 32px;}
      .footer-links-grid{grid-template-columns:1fr;gap:24px;}
      .footer-divider{margin:0 18px;}
      .footer-bottom{padding:16px 18px 26px;}
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       WIA â€” IMAGE CYCLING LAYERS
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .wia-card{cursor:pointer;}
    .wia-card-img{position:relative;}

    /* Two gradient layers for crossfade cycling */
    .wia-img-layer{
      position:absolute;inset:0;width:100%;height:100%;
      pointer-events:none;
    }
    .wia-img-layer--a{z-index:1;}
    .wia-img-layer--b{z-index:2;opacity:0;}

    /* Placeholder sits above the layers */
    .wia-card-img-placeholder{
      position:relative;z-index:3;
    }

    /* Expand hint icon shown on hover */
    .wia-expand-hint{
      position:absolute;top:12px;right:12px;z-index:4;
      width:34px;height:34px;border-radius:8px;
      background:rgba(76,142,247,0.18);
      border:1px solid rgba(76,142,247,0.35);
      color:rgba(200,218,255,0.85);
      display:flex;align-items:center;justify-content:center;
      opacity:0;
      transform:scale(0.8) translateY(-4px);
      transition:opacity .25s ease, transform .25s cubic-bezier(.22,1,.36,1);
      pointer-events:none;
      backdrop-filter:blur(4px);
    }
    .wia-card:hover .wia-expand-hint{
      opacity:1;transform:scale(1) translateY(0);
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       WIA â€” FULLSCREEN OVERLAY
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    /* Backdrop dimmer */
    #wiaOverlay{
      position:fixed;inset:0;z-index:8000;
      display:flex;align-items:center;justify-content:center;
      padding:24px;
      background:rgba(13,16,21,0);
      opacity:0;pointer-events:none;
      transition:opacity .35s cubic-bezier(.22,1,.36,1),
                  background .35s cubic-bezier(.22,1,.36,1);
    }
    #wiaOverlay.open{
      opacity:1;pointer-events:all;
      background:rgba(13,16,21,0.72);
    }
    body.ov-lock{overflow:hidden;}

    /* The actual modal card */
    #wiaOverlay .wia-ov-card{
      position:relative;
      width:100%;max-width:860px;
      height:min(560px,80vh);
      border-radius:18px;overflow:hidden;
      box-shadow:
        0 0 0 1.5px rgba(76,142,247,0.25),
        0 32px 80px rgba(0,0,0,0.6),
        0 8px 0 rgba(0,0,0,0.2);
      transform:scale(0.94) translateY(10px);
      transition:transform .38s cubic-bezier(.22,1,.36,1);
    }
    #wiaOverlay.open .wia-ov-card{
      transform:scale(1) translateY(0);
    }

    /* Background gradient layers â€” scoped inside card */
    .wia-ov-bg{
      position:absolute;inset:0;width:100%;height:100%;
      transition:none;border-radius:inherit;
    }
    .wia-ov-bg--top{
      z-index:1;opacity:0;
      transition:opacity .9s ease;
    }

    /* Dark scrim over gradient */
    #wiaOverlay .wia-ov-card::after{
      content:'';
      position:absolute;inset:0;z-index:2;border-radius:inherit;
      background:linear-gradient(
        to top,
        rgba(13,16,21,0.94) 0%,
        rgba(13,16,21,0.45) 48%,
        rgba(13,16,21,0.10) 100%
      );
      pointer-events:none;
    }

    /* Close button */
    .wia-ov-close{
      position:absolute;top:16px;right:16px;z-index:10;
      width:38px;height:38px;border-radius:50%;
      background:rgba(255,255,255,0.1);
      border:1.5px solid rgba(255,255,255,0.2);
      color:rgba(255,255,255,0.85);
      display:flex;align-items:center;justify-content:center;
      cursor:pointer;
      backdrop-filter:blur(6px);
      transition:background .2s, color .2s, transform .2s cubic-bezier(.22,1,.36,1), border-color .2s;
    }
    .wia-ov-close:hover{
      background:rgba(255,255,255,0.2);
      color:#fff;border-color:rgba(255,255,255,0.5);
      transform:scale(1.1);
    }

    /* Content block â€” bottom of modal card */
    .wia-ov-content{
      position:absolute;bottom:0;left:0;right:0;z-index:5;
      padding:28px 32px 30px;
    }
    .wia-ov-header{
      display:flex;align-items:center;gap:12px;
      margin-bottom:10px;
    }
    .wia-ov-tag{
      font-size:10px;font-weight:600;letter-spacing:2.5px;
      text-transform:uppercase;color:#fff;
      background:var(--grad-bp-bright);
      padding:4px 12px;border-radius:100px;
      box-shadow:2px 2px 0 rgba(0,0,0,0.3);
    }
    .wia-ov-area{
      font-size:11px;font-weight:400;letter-spacing:.5px;
      color:rgba(200,218,255,0.6);
    }
    .wia-ov-title{
      font-family:'Playfair Display',serif;
      font-size:clamp(22px,3vw,36px);
      font-weight:700;color:#fff;
      line-height:1.15;margin-bottom:8px;
      text-shadow:0 2px 16px rgba(0,0,0,0.5);
    }
    .wia-ov-desc{
      font-size:13px;font-weight:300;
      color:rgba(200,218,255,0.7);
      line-height:1.65;max-width:480px;
      margin-bottom:18px;
    }
    .wia-ov-shot-label{
      font-size:10px;letter-spacing:3px;text-transform:uppercase;
      color:rgba(76,142,247,0.85);font-weight:500;
      margin-bottom:10px;
    }
    .wia-ov-dots{
      display:flex;gap:7px;align-items:center;
    }
    .wia-ov-dot{
      width:24px;height:3px;border-radius:2px;
      background:rgba(255,255,255,0.22);border:none;cursor:pointer;
      transition:background .25s, width .25s cubic-bezier(.22,1,.36,1);
      padding:0;
    }
    .wia-ov-dot.active{
      background:var(--blue-bright);width:38px;
    }
    .wia-ov-dot:hover:not(.active){background:rgba(255,255,255,0.45);}

    /* Corner accents on modal */
    .wia-ov-corner-tl{position:absolute;top:16px;left:16px;z-index:6;opacity:.45;}
    .wia-ov-corner-br{position:absolute;bottom:16px;right:16px;z-index:6;opacity:.45;}

    @keyframes fdwn{to{opacity:1;transform:none;}}
    @keyframes fup{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
    @keyframes fin{to{opacity:1;}}
    @keyframes rise{to{opacity:1;transform:translateY(0);}}
    @keyframes wrd{to{opacity:1;transform:translateY(0);}}
    @keyframes gline{to{width:44px;}}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PORTFOLIO / SERVICE CATALOG â€” ASYMMETRIC MATRIX
   Asymmetric Matrix Grid Â· Editorial Minimalist
   Cream/beige atmosphere Â· Warm undertones
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.pcat-section {
  background: var(--cream);
  padding: 90px 48px 80px;
  position: relative;
  overflow: hidden;
}

/* Subtle grain texture overlay */
.pcat-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse 80% 50% at 15% 20%, rgba(42,95,192,0.04) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* â”€â”€ Section Header â”€â”€ */
.pcat-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 52px;
  position: relative;
  z-index: 1;
}

.pcat-header-left {
  flex: 0 0 auto;
}

.pcat-eyebrow {
  display: block;
  font-family: 'Outfit', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--blue-mid);
  margin-bottom: 10px;
  opacity: 0.75;
}

.pcat-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(34px, 4.5vw, 58px);
  font-weight: 700;
  color: var(--ink);
  line-height: 1.08;
  letter-spacing: -0.02em;
}

.pcat-title em {
  font-style: italic;
  color: var(--blue-mid);
}

.pcat-header-desc {
  max-width: 320px;
  font-family: 'Outfit', sans-serif;
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink-soft);
  padding-bottom: 6px;
}

/* â”€â”€ Row layout: 80% items | 20% anchor â”€â”€ */
.pcat-row {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin-bottom: 18px;
  position: relative;
  z-index: 1;
}

/* The 80% grid container */
.pcat-items {
  flex: 0 0 80%;
  display: grid;
  gap: 14px;
  padding-right: 14px;
}

.pcat-items--4 {
  grid-template-columns: repeat(4, 1fr);
}

.pcat-items--3 {
  grid-template-columns: repeat(3, 1fr);
}

/* â”€â”€ Individual card â”€â”€ */
.pcat-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  gap: 10px;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.pcat-card:hover {
  transform: translateY(-4px);
}

/* â”€â”€ Thumbnail image block â”€â”€ */
.pcat-thumb {
  width: 100%;
  aspect-ratio: 4/3;
  position: relative;
  overflow: hidden;
  border-radius: 4px; /* default â€” sharp */
}

/* Top-left corner radically rounded, others sharp */
.pcat-thumb--tl-round {
  border-radius: 38px 4px 4px 4px;
  transition: border-radius 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.pcat-card:hover .pcat-thumb--tl-round {
  border-radius: 16px 4px 4px 4px;
}

/* Inner centered SVG placeholder */
.pcat-thumb-inner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Sheen overlay on hover */
.pcat-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.08) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.3s;
}

.pcat-card:hover .pcat-thumb::after {
  opacity: 1;
}

/* â”€â”€ Card label â€” bottom-aligned, caps, tracking â”€â”€ */
.pcat-label {
  font-family: 'Outfit', sans-serif;
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0.7;
  line-height: 1;
  transition: opacity 0.2s, color 0.2s;
  padding-left: 2px;
}

.pcat-card:hover .pcat-label {
  opacity: 1;
  color: var(--blue-mid);
}

/* â”€â”€ Right column 20%: category anchor â”€â”€ */
.pcat-category-anchor {
  flex: 0 0 20%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  font-family: 'Playfair Display', serif;
  font-size: clamp(22px, 2.8vw, 38px);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.02em;
  text-decoration: none;
  line-height: 1;
  text-align: right;
  padding-bottom: 14px; /* align with label baseline */
  border-bottom: 1.5px solid rgba(22,22,26,0.12);
  margin-bottom: 0;
  transition: color 0.2s;
  position: relative;
}

.pcat-category-anchor::after {
  content: 'â†—';
  display: inline-block;
  margin-left: 8px;
  font-size: 0.55em;
  vertical-align: super;
  opacity: 0;
  transition: opacity 0.2s, transform 0.2s;
  transform: translate(-4px, 4px);
}

.pcat-category-anchor:hover {
  color: var(--blue-mid);
}

.pcat-category-anchor:hover::after {
  opacity: 1;
  transform: translate(0, 0);
}

/* Draw a horizontal separator below each row's items */
.pcat-items {
  border-bottom: 1.5px solid rgba(22,22,26,0.10);
  padding-bottom: 18px;
  margin-bottom: 0;
}

/* â”€â”€ Last row: stacked right column â”€â”€ */
.pcat-row--last {
  align-items: flex-end;
}

.pcat-last-col {
  flex: 0 0 20%;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-between;
  padding-bottom: 18px;
  border-bottom: 1.5px solid rgba(22,22,26,0.12);
  gap: 24px;
}

/* Category anchor inside last-col â€” no flex override needed */
.pcat-last-col .pcat-category-anchor {
  flex: none;
  width: 100%;
  border-bottom: none;
  padding-bottom: 0;
}

/* â”€â”€ CTA button â€” locked to lower-right â”€â”€ */
.pcat-consult-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-decoration: none;
  font-family: 'Outfit', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  line-height: 1.35;
  color: var(--off-white);
  background: var(--ink);
  padding: 18px 22px;
  border-radius: 6px 6px 6px 38px; /* asymmetric: bottom-left radically rounded */
  transition: background 0.25s, transform 0.25s cubic-bezier(0.22,1,0.36,1), box-shadow 0.25s;
  box-shadow: 0 4px 24px rgba(22,22,26,0.15);
  cursor: pointer;
  width: 100%;
}

.pcat-consult-cta:hover {
  background: var(--blue-deep);
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(27,58,107,0.28);
}

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 1024px) {
  .pcat-items--4 {
    grid-template-columns: repeat(2, 1fr);
  }
  .pcat-items--3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .pcat-thumb--tl-round {
    border-radius: 28px 4px 4px 4px;
  }
}

@media (max-width: 768px) {
  .pcat-section {
    padding: 60px 20px 60px;
  }
  .pcat-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .pcat-header-desc {
    max-width: 100%;
  }
  .pcat-row {
    flex-direction: column;
    gap: 12px;
  }
  .pcat-items {
    flex: none;
    width: 100%;
    padding-right: 0;
    grid-template-columns: repeat(2, 1fr);
  }
  .pcat-items--4 {
    grid-template-columns: repeat(2, 1fr);
  }
  .pcat-category-anchor,
  .pcat-last-col {
    flex: none;
    width: 100%;
    justify-content: flex-start;
    text-align: left;
    border-bottom: none;
    border-top: 1.5px solid rgba(22,22,26,0.12);
    padding-top: 12px;
  }
  .pcat-category-anchor {
    justify-content: flex-start;
    padding-bottom: 0;
  }
  .pcat-consult-cta {
    width: auto;
    align-self: flex-start;
  }
}
.wia-card-img {
  position: relative;
  overflow: hidden;
  /* Keep your existing gradient as a fallback */
}

.wia-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Ensures the image fills the area without stretching */
  transition: transform 0.5s ease;
}

.wia-card:hover .wia-card-img img {
  transform: scale(1.05); /* Adds a subtle zoom effect on hover */
}
/* â”€â”€ RESET + ROOT â”€â”€ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --cream:#F6F2EC;
  --cream-soft:#EEE9DF;
  --ink:#16161A;
  --ink-soft:#4A4843;
  --blue-deep:#1B3A6B;
  --blue-mid:#2A5FC0;
  --blue-bright:#4C8EF7;
  --blue-pale:#C8DAFF;
  --off-white:#FAF9F6;
  --grid-line:rgba(42,95,192,0.10);
  --card-radius:36px 5px 5px 5px;
  --card-radius-hover:18px 5px 5px 5px;
}
html,body{font-family:'Outfit',sans-serif;background:var(--off-white);color:var(--ink);}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SECTION WRAPPER
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.tdb-section{
  position:relative;
  background:var(--cream);
  padding:80px 52px 0;
  overflow:hidden;
}

/* â”€â”€ BACKGROUND: off-white with diagonal blue grid â”€â”€ */
.tdb-section::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    repeating-linear-gradient(
      -32deg,
      transparent,
      transparent 38px,
      var(--grid-line) 38px,
      var(--grid-line) 39px
    ),
    repeating-linear-gradient(
      58deg,
      transparent,
      transparent 38px,
      var(--grid-line) 38px,
      var(--grid-line) 39px
    );
  pointer-events:none;
  z-index:0;
   content:'';position:absolute;top:0;left:0;right:0;height:4px;
      background:var(--grad-bp-bright);
}

/* â”€â”€ SECTION HEADER â”€â”€ */
.tdb-header{
  position:relative;
  z-index:1;
  text-align:left;
  margin-bottom:48px;
}

.tdb-headline{
  font-family:'Playfair Display',serif;
  font-size:clamp(36px,5vw,62px);
  font-weight:700;
  color:var(--ink);
  letter-spacing:-0.02em;
  line-height:1.05;
  margin-bottom:14px;
}

.tdb-headline em{
  font-style:italic;
  color:var(--blue-mid);
}

.tdb-subhead{
  font-family:'Outfit',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--blue-mid);
  opacity:0.75;
  margin-bottom:0;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MAIN GRID BODY
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.tdb-body{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:0;
}

/* â”€â”€ EACH ROW â”€â”€ */
.tdb-row{
  display:flex;
  align-items:stretch;
  gap:0;
  margin-bottom:0;
}

/* â”€â”€ CARD GRID (left side) â”€â”€ */
.tdb-cards{
  flex:1 1 0;
  display:grid;
  gap:14px;
  padding-right:0;
  padding-bottom:22px;
  border-bottom:1.5px solid rgba(22,22,26,0.09);
}

.tdb-cards--4{ grid-template-columns:repeat(4,1fr); }
.tdb-cards--3{ grid-template-columns:repeat(3,1fr); }

/* â”€â”€ CATEGORY LABEL COLUMN â”€â”€ */
.tdb-cat{
  flex:0 0 148px;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding-left:22px;
  padding-bottom:28px;
  border-bottom:1.5px solid rgba(22,22,26,0.09);
}

.tdb-cat-name{
  font-family:'Playfair Display',serif;
  font-size:clamp(22px,2.6vw,34px);
  font-weight:700;
  color:var(--ink);
  letter-spacing:-0.02em;
  line-height:1;
  transition:color 0.2s;
  cursor:default;
}

.tdb-row:hover .tdb-cat-name{
  color:var(--blue-mid);
}

/* â”€â”€ INDIVIDUAL CARD â”€â”€ */
.tdb-card{
  display:flex;
  flex-direction:column;
  gap:10px;
  text-decoration:none;
  cursor:pointer;
  transition:transform 0.35s cubic-bezier(0.22,1,0.36,1);
}

.tdb-card:hover{
  transform:translateY(-5px);
}

/* â”€â”€ THUMBNAIL â”€â”€ */
.tdb-thumb{
  width:100%;
  aspect-ratio:4/3;
  position:relative;
  overflow:hidden;
  border-radius:var(--card-radius);
  transition:border-radius 0.35s cubic-bezier(0.22,1,0.36,1);
}

.tdb-card:hover .tdb-thumb{
  border-radius:var(--card-radius-hover);
}

/* Interior renders â€” using real architectural gradients as placeholders */
.tdb-thumb-inner{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

/* Sheen on hover */
.tdb-thumb::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.12) 0%,transparent 55%);
  opacity:0;
  transition:opacity 0.3s;
  pointer-events:none;
}

.tdb-card:hover .tdb-thumb::after{ opacity:1; }

/* â”€â”€ CAPTION â”€â”€ */
.tdb-caption{
  font-family:'Outfit',sans-serif;
  font-size:10.5px;
  font-weight:600;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink);
  opacity:0.65;
  padding-left:2px;
  line-height:1;
  transition:opacity 0.2s, color 0.2s;
}

.tdb-card:hover .tdb-caption{
  opacity:1;
  color:var(--blue-mid);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   ROOM ILLUSTRATION SVGS (placeholder renders)
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.room-svg{ width:100%;height:100%;display:block; }

/* â”€â”€ Last row / CTA row â”€â”€ */
.tdb-cta-belt{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:32px 0 60px;
  gap:24px;
  flex-wrap:wrap;
}

.tdb-cta-main{
  font-family:'Playfair Display',serif;
  font-size:clamp(18px,2.2vw,26px);
  font-weight:600;
  color:var(--ink);
  line-height:1.2;
  letter-spacing:-0.01em;
}

.tdb-cta-brand{
  display:block;
  font-family:'Outfit',sans-serif;
  font-size:13px;
  font-weight:400;
  color:var(--ink-soft);
  letter-spacing:0.04em;
  margin-top:6px;
}

.tdb-cta-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:16px 30px;
  background:var(--blue-deep);
  color:#fff;
  font-family:'Outfit',sans-serif;
  font-size:12px;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  border:none;
  border-radius:50px;
  cursor:pointer;
  transition:background 0.25s,transform 0.25s cubic-bezier(0.22,1,0.36,1),box-shadow 0.25s;
  white-space:nowrap;
  box-shadow:0 6px 28px rgba(27,58,107,0.25);
}

.tdb-cta-btn:hover{
  background:var(--blue-mid);
  transform:translateY(-2px);
  box-shadow:0 10px 36px rgba(27,58,107,0.35);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   ARCHITECTURAL ROOM ILLUSTRATIONS
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Thumbnail BGs â”€â”€ */
.bg-exec    { background:linear-gradient(145deg,#2a1f14 0%,#4a3828 40%,#7a6050 70%,#9a8070 100%); }
.bg-openplan{ background:linear-gradient(145deg,#1a2a3a 0%,#2a4060 40%,#405878 70%,#c8d4e0 100%); }
.bg-conf    { background:linear-gradient(145deg,#0e1a24 0%,#1c303e 40%,#2c4a58 60%,#bccad2 100%); }
.bg-recep   { background:linear-gradient(145deg,#1e2018 0%,#3a3e2c 40%,#8a8a72 70%,#d0cebe 100%); }
.bg-class   { background:linear-gradient(145deg,#141e2a 0%,#1e3040 40%,#e8e4d8 80%,#f2f0e8 100%); }
.bg-medical { background:linear-gradient(145deg,#0a1820 0%,#1a2e3a 40%,#90b8c8 70%,#d8ecf2 100%); }
.bg-comm    { background:linear-gradient(145deg,#161e12 0%,#2a3422 40%,#8aaa80 70%,#c0d4b8 100%); }
.bg-1bhk    { background:linear-gradient(145deg,#1c1810 0%,#3a3020 40%,#7a6840 70%,#d8c8a8 100%); }
.bg-2bhk    { background:linear-gradient(145deg,#1a1410 0%,#382c24 40%,#6a5848 70%,#c8b8a0 100%); }
.bg-living  { background:linear-gradient(145deg,#0e1820 0%,#1c2c3a 40%,#5a7888 70%,#d0dce4 100%); }
.bg-modkit  { background:linear-gradient(145deg,#181618 0%,#2c2a2c 40%,#585058 70%,#c0bcc0 100%); }
.bg-custom  { background:linear-gradient(145deg,#201a10 0%,#3c3018 40%,#786040 70%,#d0c090 100%); }
.bg-chefs   { background:linear-gradient(145deg,#181614 0%,#302c28 40%,#786858 70%,#c8b8a8 100%); }

/* â”€â”€ Interior scene SVG overlays â”€â”€ */
.room-scene{ position:absolute;inset:0;display:flex;align-items:flex-end;padding:8px; }

/* â”€â”€ RESPONSIVE â”€â”€ */
@media(max-width:1100px){
  .tdb-cards--4{ grid-template-columns:repeat(2,1fr); }
  .tdb-cat{ flex:0 0 110px; }
}
@media(max-width:760px){
  .tdb-section{ padding:56px 20px 0; }
  .tdb-cards--4,.tdb-cards--3{ grid-template-columns:repeat(2,1fr); }
  .tdb-row{ flex-wrap:wrap; }
  .tdb-cat{
    flex:0 0 100%;
    padding-left:0;padding-top:10px;padding-bottom:14px;
    border-bottom:none;
    border-top:1.5px solid rgba(22,22,26,0.09);
  }
  .tdb-cards{ border-bottom:none; padding-bottom:14px; }
  .tdb-cta-belt{ flex-direction:column;align-items:flex-start; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MEET OUR ARCHITECTS
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.moa-section {
  position: relative;
  display: flex;
  align-items: stretch;
  min-height: 750px;
  background: var(--off-white);
  overflow: hidden;
  
}
.moa-section::before{
      content:'';position:absolute;top:0;left:0;right:0;height:4px;
      background:var(--grad-bp-bright);
    }

/* â”€â”€ Left panel â”€â”€ */
.moa-left {
  flex: 0 0 300px;
  background: var(--ink);
  color: var(--cream);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 48px 60px 52px;
  position: relative;
  z-index: 2;
  overflow: hidden;
}

.moa-eyebrow {
  font-family: 'Outfit', sans-serif;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--blue-bright);
  opacity: 0.8;
  margin-bottom: 20px;
}

.moa-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(36px, 4vw, 54px);
  font-weight: 700;
  color: var(--cream);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0;
}

.moa-title em {
  font-style: italic;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(76,142,247,0.7);
}

.moa-title-deco {
  margin-top: 28px;
  width: 52px;
  opacity: 0.7;
}

/* Pendant lights SVGs */
.moa-left-pendant {
  position: absolute;
  top: 0;
  right: 28px;
  width: 40px;
  opacity: 0.8;
}
.moa-left-pendant--2 {
  right: 60px;
  top: -10px;
  opacity: 0.6;
}

/* â”€â”€ Diagonal divider â”€â”€ */
.moa-divider {
  flex: 0 0 60px;
  position: relative;
  z-index: 3;
  margin-left: -1px;
}
.moa-divider svg {
  width: 60px;
  height: 100%;
  display: block;
}

/* â”€â”€ Right panel â”€â”€ */
.moa-right {
  flex: 1 1 0;
  padding: 52px 52px 52px 28px;
  display: flex;
  align-items: center;
}

/* â”€â”€ Card grid â”€â”€ */
.moa-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 30px;
  width: 100%;
}

/* Kenji's card spans 2 rows */
.moa-card--side {
  grid-row: 1 / 3;
  grid-column: 2 / 3;
}

/* â”€â”€ Each architect card â”€â”€ */
.moa-card {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: 14px;
  display: flex;
  gap: 14px;
  padding: 16px;
  box-shadow: 0 2px 12px rgba(22,22,26,0.07), 0 6px 24px rgba(22,22,26,0.04);
  transition: transform 0.35s cubic-bezier(0.22,1,0.36,1), box-shadow 0.35s;
  position: relative;
  overflow: hidden;
}
.moa-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(22,22,26,0.12), 0 2px 8px rgba(22,22,26,0.06);
}

/* Side card is taller â€” flex column */
.moa-card--side {
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

/* â”€â”€ Photo block â”€â”€ */
.moa-card-photo {
  flex: 0 0 110px;
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background: var(--charcoal);
  min-height: 130px;
}
.moa-card-photo--tall {
  flex: 0 0 180px;
  border-radius: 0;
  min-height: 200px;
  width: 100%;
}

.moa-photo-placeholder {
  width: 100%;
  height: 100%;
  min-height: inherit;
}

/* Colour tints per architect */
.moa-photo--sarah  { background: linear-gradient(160deg, #2a3545 0%, #5a6880 50%, #c8bba8 100%); }
.moa-photo--kenji  { background: linear-gradient(160deg, #1a2030 0%, #3a4a60 50%, #9aacba 100%); }
.moa-photo--aisha  { background: linear-gradient(160deg, #3a2820 0%, #7a5848 50%, #c8a890 100%); }

/* Project thumbnail inset */
.moa-card-project-thumb {
  position: absolute;
  bottom: 8px;
  right: 8px;
  width: 56px;
  height: 42px;
  border-radius: 7px;
  overflow: hidden;
  border: 1.5px solid rgba(255,255,255,0.25);
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.moa-card-project-thumb--kenji {
  bottom: auto;
  top: 8px;
  right: 8px;
  width: 64px;
  height: 48px;
}
.moa-proj-thumb-inner {
  width: 100%;
  height: 100%;
}

/* â”€â”€ Card body â”€â”€ */
.moa-card-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 2px 0;
}
.moa-card--side .moa-card-body {
  padding: 18px 20px 20px;
}

.moa-card-name {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin: 0;
  line-height: 1.2;
}

.moa-card-spec {
  font-family: 'Outfit', sans-serif;
  font-size: 11px;
  font-weight: 500;
  color: var(--blue-mid);
  line-height: 1.4;
  margin: 2px 0 4px;
}

.moa-card-bio {
  font-family: 'Outfit', sans-serif;
  font-size: 11.5px;
  font-weight: 300;
  color: var(--ink-soft);
  line-height: 1.55;
  margin: 0;
  flex: 1;
}

/* â”€â”€ Badges â”€â”€ */
.moa-card-badges {
  display: flex;
  gap: 6px;
  margin-top: 6px;
  flex-wrap: wrap;
}

.moa-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: 'Outfit', sans-serif;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 50px;
  padding: 4px 10px;
  line-height: 1;
}

.moa-badge--leed {
  background: rgba(76,142,247,0.12);
  color: var(--blue-mid);
  border: 1px solid rgba(76,142,247,0.25);
}

.moa-badge--cert {
  background: rgba(22,22,26,0.06);
  color: var(--ink-soft);
  border: 1px solid rgba(22,22,26,0.12);
}

/* â”€â”€ Portfolio button â”€â”€ */
.moa-portfolio-btn {
  margin-top: 10px;
  align-self: flex-start;
  background: var(--grad-bp);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 9px 18px;
  font-family: 'Outfit', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.2s cubic-bezier(0.22,1,0.36,1), box-shadow 0.2s;
  box-shadow: 0 3px 14px rgba(27,58,107,0.22);
}
.moa-portfolio-btn:hover {
  opacity: 0.92;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(27,58,107,0.3);
}

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 1100px) {
  .moa-left { flex: 0 0 220px; padding: 48px 36px 48px 36px; }
  .moa-right { padding: 40px 36px 40px 20px; }
}

@media (max-width: 820px) {
  .moa-section { flex-direction: column; }
  .moa-left { flex: none; padding: 48px 32px; flex-direction: row; flex-wrap: wrap; align-items: flex-end; gap: 20px; }
  .moa-divider { display: none; }
  .moa-right { padding: 32px 24px 48px; }
  .moa-grid { grid-template-columns: 1fr; }
  .moa-card--side { grid-row: auto; grid-column: auto; }
}

/* â”€â”€ Architect photo img â”€â”€ */
.moa-photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.moa-photo-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: linear-gradient(160deg, #2a3545 0%, #4a5870 100%);
  color: rgba(255,255,255,0.5);
  font-family: 'Outfit', sans-serif;
  font-size: 11px;
  letter-spacing: 0.05em;
}
/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SERVICES SECTION
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.services-section{
  position:relative;
  padding:72px 20px;
  background:
    linear-gradient(
      180deg,
      #0f1726 0%,
      #111827 42%,
      #f8f8f8 42%,
      #f8f8f8 100%
    );
  overflow:hidden;
  
}

.services-container{
  width:min(1280px,100%);
  margin-inline:auto;
}

.services-header{
  margin-bottom:42px;
}

.services-eyebrow{
  display:inline-flex;
  align-items:center;
  margin-bottom:14px;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.72);
}

.services-title{
  margin:0 0 12px;
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,5vw,4rem);
  line-height:1.05;
  font-weight:700;
  color:#fff;
}

.services-subtitle{
  max-width:760px;
  font-size:1rem;
  line-height:1.7;
  color:--charcoal;
}

/* GRID */

.services-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
}

/* CARD */

.service-card{
  position:relative;
  border-radius:26px;
  overflow:hidden;
  background:linear-gradient(
    180deg,
    #1c3f78 0%,
    #2a5fc0 100%
  );

  box-shadow:
    0 10px 30px rgba(0,0,0,.18);

  transform:translateY(40px);
  opacity:0;

  transition:
    transform .7s cubic-bezier(.22,1,.36,1),
    opacity .7s ease,
    box-shadow .35s ease;
}

/* GPU accelerated hover */

.service-card:hover{
  transform:translateY(-6px);
  box-shadow:
    0 18px 42px rgba(0,0,0,.22);
}

/* IntersectionObserver active state */

.service-card.is-visible{
  opacity:1;
  transform:translateY(0);
}

/* IMAGE WRAPPER */

.service-media{
  position:relative;
  width:100%;
  aspect-ratio:380 / 550;
  overflow:hidden;
}

/* CLS prevention */

.service-media img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;

  transform:scale(1);
  transition:transform .7s ease;

  will-change:transform;
}

.service-card:hover img{
  transform:scale(1.04);
}

/* CONTENT */

.service-content{
  position:absolute;
  inset:0;
  z-index:2;

  display:flex;
  flex-direction:column;
  justify-content:flex-start;

  padding:28px 24px;

  background:
    linear-gradient(
      180deg,
      rgba(0,0,0,.28) 0%,
      rgba(0,0,0,.05) 38%,
      rgba(0,0,0,.10) 100%
    );
}

.service-heading{
  margin:0 0 14px;

  font-family:'Playfair Display',serif;
  font-size:clamp(1.7rem,3vw,2.6rem);
  line-height:1.08;
  font-weight:700;
  color:#fff;

}

.service-description{
  max-width:90%;
  margin:0;

  font-size:.96rem;
  line-height:1.65;
  font-weight:400;

  color:rgba(255,255,255,.92);
}

/* CTA */

.services-cta-wrap{
  display:flex;
  justify-content:center;
  margin-top:36px;
}

.services-cta{
  border:none;
  border-radius:12px;

  padding:16px 34px;

  background:
    linear-gradient(
      180deg,
      #4c8ef7 0%,
      #2a5fc0 100%
    );

  color:#fff;

  font-size:.82rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;

  cursor:pointer;

  transition:
    transform .25s ease,
    box-shadow .25s ease;

  box-shadow:
    0 10px 20px rgba(42,95,192,.24);
}

.services-cta:hover{
  transform:translateY(-2px);
  box-shadow:
    0 14px 28px rgba(42,95,192,.34);
}

/* TABLET */

@media (min-width:768px){

  .services-section{
    padding:92px 36px;
  }

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

/* DESKTOP */

@media (min-width:1200px){

  .services-grid{
    grid-template-columns:repeat(3,1fr);
    gap:28px;
  }

  .service-content{
    padding:34px 28px;
  }
}

/* ACCESSIBILITY */

@media (prefers-reduced-motion:reduce){

  .service-card,
  .service-media img,
  .services-cta{
    transition:none !important;
    animation:none !important;
  }

}



/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   EVIZ SOLUTIONS SECTION
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â•â• SECTION â•â• */
.eviz-section{
  min-height:100vh;
  display:grid;
  grid-template-columns:360px 1fr;
  position:relative;
  overflow:hidden;
  background:var(--charcoal-deep);
}

/* â•â• LEFT PANEL â€” 360px wide â•â• */
.eviz-left{
  width:360px;
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  justify-content:space-between;
  padding:52px 32px 52px 48px;
  border-right:1px solid rgba(76,142,247,0.10);
  background:linear-gradient(180deg,rgba(19,22,27,0.55) 0%,rgba(30,34,40,0.25) 100%);
}
.eviz-left::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad-bp-bright);
}

.eviz-brand-block{display:flex;flex-direction:column;gap:0;}

.eviz-eyebrow{
  font-size:10px;font-weight:500;letter-spacing:4px;
  text-transform:uppercase;color:rgba(200,218,255,0.38);
  margin-bottom:14px;
}

.eviz-wordmark{
  font-family:'Playfair Display',serif;
  font-size:clamp(40px,4.5vw,62px);
  font-weight:700;line-height:0.92;
  color:#fff;letter-spacing:-1px;
}
.eviz-wordmark .line{display:block;}
.eviz-wordmark .line span{
  display:block;
  opacity:0;transform:translateY(110%);
}
.eviz-wordmark .line--accent span{
  background:var(--grad-bp-bright);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;font-style:italic;
}

.eviz-underline{
  width:0;height:2px;
  background:var(--grad-bp-bright);
  border-radius:2px;margin-top:18px;
  box-shadow:0 0 10px rgba(76,142,247,0.35);
}

.presents-tag{
  margin-top:16px;
  font-size:11px;font-weight:300;letter-spacing:5px;
  text-transform:uppercase;color:rgba(200,218,255,0.35);
  opacity:0;
}

/* â”€â”€ Services list â”€â”€ */
.eviz-services-col{display:flex;flex-direction:column;gap:0;}
.eviz-service-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 0;
  border-bottom:1px solid rgba(76,142,247,0.07);
  font-size:13px;font-weight:300;
  color:rgba(200,218,255,0.45);
  letter-spacing:0.04em;
  cursor:default;
  transition:color .25s,padding-left .22s;
  position:relative;
}
.eviz-service-item::before{
  content:'';width:4px;height:4px;border-radius:50%;
  background:rgba(76,142,247,0.45);flex-shrink:0;
  transition:background .25s,transform .25s;
}
.eviz-service-item:hover{color:rgba(200,218,255,0.88);padding-left:8px;}
.eviz-service-item:hover::before{background:var(--blue-bright);transform:scale(1.6);}

/* â”€â”€ Progress â”€â”€ */
.eviz-progress-block{opacity:0;transition:opacity .5s;}
.eviz-progress-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;}
.eviz-progress-track{
  flex:1;height:1.5px;background:rgba(76,142,247,0.10);border-radius:2px;overflow:hidden;
}
.eviz-progress-fill{
  height:100%;width:0%;border-radius:2px;
  background:var(--grad-bp-bright);
  transition:width .4s cubic-bezier(0.645,0.045,0.355,1);
}
.eviz-progress-label{
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(200,218,255,0.28);
}

/* â•â• RIGHT STAGE â€” CREAM â•â• */
.eviz-stage{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  padding:52px 48px 52px 44px;
  overflow:hidden;min-width:0;
  background:linear-gradient(160deg,var(--cream) 0%,var(--cream-soft) 60%,var(--cream-deep) 100%);
}
.eviz-stage::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(42,95,192,0.055) 1px,transparent 1px),
    linear-gradient(90deg,rgba(42,95,192,0.055) 1px,transparent 1px);
  background-size:52px 52px;
  pointer-events:none;z-index:0;
  animation:gridShift 22s linear infinite;
}
@keyframes gridShift{0%{background-position:0 0;}100%{background-position:52px 52px;}}

.eviz-stage::after{
  content:'';
  position:absolute;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(42,95,192,0.06) 0%,transparent 70%);
  bottom:-100px;right:-80px;
  pointer-events:none;z-index:0;
}

.eviz-stage-accent{
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad-bp-bright);z-index:1;
}

.eviz-stage-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:36px;flex-shrink:0;
  position:relative;z-index:2;
}
.eviz-stage-meta{display:flex;flex-direction:column;gap:6px;}
.eviz-stage-tag{
  font-size:10px;font-weight:500;letter-spacing:3px;
  text-transform:uppercase;color:var(--blue-mid);opacity:0.7;
}
.eviz-stage-headline{
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,3vw,42px);font-weight:700;
  color:var(--ink);letter-spacing:-0.5px;line-height:1;
}
.eviz-stage-headline em{
  background:var(--grad-bp-bright);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;font-style:italic;
}

.eviz-arrows{display:flex;gap:8px;align-items:center;}
.eviz-arrow{
  width:42px;height:42px;border-radius:10px;
  border:1px solid rgba(22,22,26,0.12);
  background:rgba(255,255,255,0.6);
  color:var(--ink-soft);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  box-shadow:0 2px 0 rgba(22,22,26,0.08),0 4px 12px rgba(22,22,26,0.06);
  transition:background .2s,border-color .2s,color .2s,transform .18s,box-shadow .2s;
}
.eviz-arrow:hover{
  background:var(--blue-deep);
  border-color:var(--blue-deep);
  color:#fff;transform:translateY(-2px);
  box-shadow:0 4px 0 rgba(27,58,107,0.25),0 8px 20px rgba(27,58,107,0.15);
}
.eviz-arrow:active{transform:scale(0.92);}

/* â”€â”€ CARD GRID â”€â”€ */
.eviz-grid-wrapper{
  flex:1;overflow:hidden;position:relative;min-width:0;
  z-index:2;
  mask-image:linear-gradient(90deg,transparent 0%,#000 3%,#000 94%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 3%,#000 94%,transparent 100%);
}
.eviz-grid{
  display:flex;gap:18px;
  overflow-x:auto;scroll-behavior:smooth;
  scrollbar-width:none;
  padding:4px 4px 20px;
  scroll-snap-type:x mandatory;
  height:100%;
}
.eviz-grid::-webkit-scrollbar{display:none;}

/* â•â• CARD â€” FULL IMAGE FILL â•â• */
.eviz-card{
  flex-shrink:0;
  width:300px;
  height:520px;
  border-radius:20px;
  overflow:hidden;
  position:relative;
  background:var(--charcoal-deep);
  border:1.5px solid rgba(22,22,26,0.14);
  box-shadow:
    0 4px 0 rgba(22,22,26,0.08),
    0 8px 0 rgba(22,22,26,0.04),
    0 8px 32px rgba(22,22,26,0.14);
  scroll-snap-align:start;
  cursor:pointer;
  opacity:0;transform:translateY(28px) scale(0.97);
  transition:
    opacity .65s cubic-bezier(0.645,0.045,0.355,1),
    transform .65s cubic-bezier(0.645,0.045,0.355,1),
    box-shadow .3s,
    border-color .3s;
}
.eviz-card.visible{opacity:1;transform:translateY(0) scale(1);}
.eviz-card:hover{
  border-color:rgba(76,142,247,0.35);
  box-shadow:
    0 0 0 rgba(22,22,26,0.08),
    0 28px 60px rgba(22,22,26,0.28),
    0 0 0 1.5px rgba(76,142,247,0.25);
  transform:translateY(-10px) scale(1.025);
}

/* Blue gradient top edge on hover */
.eviz-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad-bp-bright);
  border-radius:20px 20px 0 0;
  z-index:6;
  opacity:0;
  transition:opacity .3s;
}
.eviz-card:hover::before{opacity:1;}

/* â”€â”€ IMAGE: fills entire card â”€â”€ */
.eviz-card-img-wrap{
  position:absolute;
  inset:0;
  overflow:hidden;
  border-radius:18px;
}
.eviz-card-img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform .7s cubic-bezier(0.645,0.045,0.355,1);
}
.eviz-card:hover .eviz-card-img{transform:scale(1.08);}

/* â”€â”€ CARD BODY â€” hover overlay sliding up from bottom â”€â”€ */
.eviz-card-body{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:48px 18px 22px;
  display:flex;
  flex-direction:column;
  gap:10px;
  background:linear-gradient(
    to top,
    rgba(10,13,18,0.96) 0%,
    rgba(10,13,18,0.80) 45%,
    rgba(10,13,18,0.40) 75%,
    transparent 100%
  );
  border-radius:0 0 18px 18px;
  opacity:0;
  transform:translateY(10px);
  transition:opacity .35s ease, transform .35s ease;
  z-index:4;
}
.eviz-card:hover .eviz-card-body{
  opacity:1;
  transform:translateY(0);
}

/* Number badge â€” always visible */
.eviz-card-num{
  position:absolute;
  top:14px;right:14px;z-index:5;
  width:28px;height:28px;border-radius:7px;
  background:rgba(10,13,18,0.60);
  border:1px solid rgba(76,142,247,0.28);
  backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:500;
  color:rgba(200,218,255,0.80);letter-spacing:0.5px;
}

/* Label text inside overlay */
.eviz-card-label{
  font-size:9px;font-weight:600;letter-spacing:2.8px;
  text-transform:uppercase;
  color:rgba(200,218,255,0.70);
  display:block;
  margin-bottom:2px;
}

/* Pill inside overlay */
.eviz-card-pill{
  align-self:flex-start;
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(76,142,247,0.16);
  border:1px solid rgba(76,142,247,0.38);
  border-radius:50px;padding:5px 13px;
  font-size:11px;font-weight:400;
  color:rgba(200,218,255,0.92);letter-spacing:0.2px;
  transition:background .2s,border-color .2s;
  backdrop-filter:blur(4px);
}
.eviz-card:hover .eviz-card-pill{
  background:rgba(76,142,247,0.28);
  border-color:rgba(76,142,247,0.55);
}
.eviz-card-pill::before{
  content:'';display:block;width:5px;height:5px;border-radius:50%;
  background:var(--blue-bright);
  box-shadow:0 0 6px rgba(76,142,247,0.7);
}

/* â”€â”€ STATUS BAR â”€â”€ */
.eviz-status-bar{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:22px;padding-top:16px;
  border-top:1px solid rgba(22,22,26,0.10);
  flex-shrink:0;position:relative;z-index:2;
}
.eviz-dots{display:flex;gap:6px;align-items:center;}
.eviz-dot{
  width:20px;height:2.5px;border-radius:2px;
  background:rgba(22,22,26,0.12);border:none;cursor:pointer;
  transition:background .25s,width .25s cubic-bezier(0.645,0.045,0.355,1);padding:0;
}
.eviz-dot.active{width:34px;background:var(--blue-mid);}
.eviz-dot:hover:not(.active){background:rgba(42,95,192,0.3);}
.eviz-hint{
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;
  color:rgba(22,22,26,0.28);
}

/* â”€â”€ ANIMATIONS â”€â”€ */
@keyframes slideUp{to{opacity:1;transform:translateY(0);}}
@keyframes expandLine{to{width:52px;}}
@keyframes fadeUp{to{opacity:1;}}
/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   WHY US SECTION â€” EVIZ PREMIUM VERSION
   Palette:
   Cream â€¢ Charcoal â€¢ Slate â€¢ Electric Blue â€¢ Violet
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.whyus-section{
  position:relative;
  padding:120px 48px;

  background:
    linear-gradient(
      180deg,
      #F7F4EE 0%,
      #F1F3F8 100%
    );

  overflow:hidden;
}

/* TOP GLOW LINE */

.whyus-section::before{
  content:'';

  position:absolute;
  top:0;
  left:0;
  right:0;
  height:2px;

  background:
    linear-gradient(
      90deg,
      #1B3A6B,
      #4C8EF7,
      #7B61FF,
      #4C8EF7,
      #1B3A6B
    );
}

/* SOFT BACKGROUND BLOBS */

.whyus-section::after{
  content:'';

  position:absolute;
  width:700px;
  height:700px;

  right:-220px;
  top:120px;

  background:
    radial-gradient(
      circle,
      rgba(123,97,255,0.08),
      transparent 70%
    );

  pointer-events:none;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   HEADER
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.whyus-header{
  text-align:center;
  margin-bottom:70px;
  position:relative;
  z-index:2;
}

.whyus-tag{
  display:block;

  margin-bottom:18px;

  font-size:12px;
  letter-spacing:5px;
  text-transform:uppercase;

  color:#6B7280;
}

.whyus-title{
  font-family:'Playfair Display', serif;

  font-size:clamp(52px,7vw,100px);
  line-height:.95;
  letter-spacing:-4px;

  color:#141922;

  margin:0;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   GRID
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.whyus-grid{
  position:relative;
  z-index:2;

  display:grid;

  grid-template-columns:
    1fr
    1fr
    1fr
    1fr;

  grid-template-rows:
    290px
    250px;

  gap:26px;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BASE CARD
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.why-card{
  position:relative;

  border-radius:30px;

  overflow:hidden;

  padding:34px;

  transition:
    transform .5s cubic-bezier(.22,1,.36,1),
    box-shadow .5s ease,
    border-color .4s ease;

  isolation:isolate;

  backdrop-filter:blur(500px);
}

.why-card:hover{
  transform:translateY(-10px);
}

/* GLASS HIGHLIGHT */

.why-card::after{
  content:'';

  position:absolute;
  inset:0;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,.18),
      transparent 42%
    );

  pointer-events:none;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   LIGHT CARD
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.why-card.light{
  background:
    linear-gradient(
      145deg,
      #F5F7FC 0%,
      #E8EDF7 100%
    );

  border:1px solid rgba(76,142,247,0.08);

  box-shadow:
    0 18px 35px rgba(15, 23, 42, 0.636);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   DARK CHARCOAL CARD
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.why-card.dark{
  background:
    linear-gradient(
      145deg,
      #141922 0%,
      #1E2633 55%,
      #252F3F 100%
    );

  border:1px solid rgba(255,255,255,0.05);

  box-shadow:
    0 25px 55px rgba(0, 0, 0.6, 0.758);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BLUE / PURPLE FEATURE CARD
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.why-card.accent{
  background:
    linear-gradient(
      145deg,
      #1B3A6B 0%,
      #315ECF 45%,
      #5B8FF9 70%,
      #7B61FF 100%
    );

  box-shadow:
    0 25px 60px rgba(49,94,207,0.35);

  display:flex;
  align-items:flex-end;
}

.why-card.accent::before{
  content:'';

  position:absolute;
  inset:0;

  background:
    radial-gradient(
      circle at top left,
      rgba(255,255,255,.22),
      transparent 40%
    );

  pointer-events:none;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   IMAGE CARDS
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.image-card{
  padding:0;
  background:#464e63;
}

.image-card img{
  width:100%;
  height:100%;

  object-fit:cover;
  display:block;

  transition:
    transform .8s ease,
    filter .5s ease;
}

.image-card:hover img{
  transform:scale(1.06);
  filter:contrast(1.05);
}

/* CENTER IMAGE */

.tall{
  grid-row:span 2;
  min-height:566px;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TYPOGRAPHY
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.why-card h3{
  margin:0 0 14px;

  font-size:clamp(44px,4vw,74px);
  line-height:.88;
  letter-spacing:-3px;
  font-weight:700;
}

.why-card p{
  margin:0;

  font-size:20px;
  line-height:1.12;

  max-width:90%;
}

/* LIGHT CARD TEXT */

.why-card.light h3{
  color:#111827;
}

.why-card.light p{
  color:#374151;
}

/* DARK CARD TEXT */

.why-card.dark h3{
  color:#FFFFFF;
}

.why-card.dark p{
  color:rgba(255,255,255,.9);
}

/* FEATURE CARD TEXT */

.why-card.accent p{
  color:white;

  font-size:42px;
  line-height:.95;
  letter-spacing:-2px;
  font-weight:600;

  max-width:280px;
}

/* BLUE TYPOGRAPHY CARD */

.accent-text h3,
.accent-text p{
  color:#315ECF !important;
}

.why-small-text{
  position:absolute;

  bottom:34px;
  left:34px;

  max-width:240px;

  font-size:15px;
  line-height:1.45;

  color:#5B8FF9;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SPECIAL DEPTH EFFECTS
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.why-card.light:hover{
  box-shadow:
    0 25px 50px rgba(49,94,207,0.10);
}

.why-card.dark:hover{
  box-shadow:
    0 30px 65px rgba(0,0,0,0.34);
}

.why-card.accent:hover{
  box-shadow:
    0 35px 70px rgba(91,143,249,0.35);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   RESPONSIVE
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

@media (max-width:1200px){

  .whyus-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
  }

  .tall{
    min-height:420px;
  }

}

@media (max-width:768px){

  .whyus-section{
    padding:90px 20px;
  }

  .whyus-grid{
    grid-template-columns:1fr;
    gap:20px;
  }

  .why-card{
    min-height:240px;
    padding:28px;
  }

  .why-card h3{
    font-size:54px;
  }

  .why-card p{
    font-size:18px;
  }

  .why-card.accent p{
    font-size:32px;
  }

  .tall{
    min-height:340px;
  }

  .why-small-text{
    position:relative;
    bottom:auto;
    left:auto;
    margin-top:30px;
  }

}
.tdb-thumb{
    position: relative;
    width: 100%;
    height: 220px;
    overflow: hidden;
    border-radius: 18px;
}

.tdb-thumb img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .5s ease;
}

.tdb-card:hover img{
    transform: scale(1.08);
}
.pillar-section-intro{
padding:120px 0;
background:#fafafa;
}
.pillar-section-intro::before{
      content:'';position:absolute;top:0;left:0;right:0;height:4px;
      background:var(--grad-bp-bright);
 }  ss
.pillar-intro-inner{
max-width:1280px;
margin:auto;
padding:0 40px;
}

.pillar-heading{
text-align:center;
max-width:850px;
margin:auto;
}

.pillar-heading h2{
font-family:'Playfair Display',serif;
font-size:clamp(2.6rem,5vw,4rem);
margin:20px 0;
color:#111;
}

.pillar-heading em{
background:linear-gradient(135deg,#4c8ef7,#9a63ff);
background-clip:text;
-webkit-text-fill-color:transparent;
}

.pillar-heading p{
font-size:1.1rem;
color:#666;
line-height:1.8;
}

.ecosystem-banner{
position:relative;
height:450px;
margin:70px 0;
overflow:hidden;
border-radius:24px;
}

.ecosystem-banner img{
width:100%;
height:100%;
object-fit:cover;
}

.ecosystem-overlay{
position:absolute;
inset:0;
display:flex;
flex-direction:column;
justify-content:center;
padding:60px;
background:
linear-gradient(
90deg,
rgba(10,15,30,.92),
rgba(10,15,30,.30)
);
}

.ecosystem-overlay span{
color:#5e93e7;
letter-spacing:3px;
text-transform:uppercase;
margin-bottom:15px;
}

.ecosystem-overlay h3{
max-width:650px;
color:rgb(12, 9, 9);
font-family:'Playfair Display',serif;
font-size:3.2rem;
line-height:1.1;
}

.feature-grid{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:28px;
}

.feature-card{
background:white;
border-radius:20px;
overflow:hidden;
box-shadow:
0 15px 50px rgba(0,0,0,.05);
transition:.35s ease;
}

.feature-card:hover{
transform:translateY(-8px);
}

.feature-image{
height:240px;
}

.feature-image img{
width:100%;
height:100%;
object-fit:cover;
}

.feature-content{
padding:32px;
}

.feature-index{
color:#010814;
font-size:.85rem;
letter-spacing:2px;
font-weight:600;
}

.feature-content h3{
margin:15px 0;
font-size:1.7rem;
}

.feature-content p{
color:#666;
line-height:1.7;
}

.feature-content a{
display:inline-block;
margin-top:20px;
text-decoration:none;
font-weight:600;
color:#1b3a6b;
}


/* â”€â”€ Section wrapper â”€â”€ */
.ecosystems-section {
  padding: 140px 72px 100px;
  position: relative;
  background: #121b3a; /* Defined explicit deep background */
  overflow: hidden;
}

/* Subtle top separator */
.ecosystems-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 72px;
  right: 72px;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(76,142,247,0.45) 30%,
    rgba(76,142,247,0.45) 70%,
    transparent
  );
}

/* â”€â”€ Section header â”€â”€ */
.eco-header {
  max-width: 1380px;
  margin: 0 auto 80px;
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  grid-template-rows: auto auto auto;
  column-gap: 80px;
  row-gap: 0;
  align-items: start;
}

.eco-eyebrow {
  grid-column: 1 / -1;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 18px;
  border-radius: 50px;
  background: rgba(76,142,247,0.15); /* Darkened label capsule background */
  border: 1px solid rgba(76,142,247,0.35);
  font-size: 10px;
  letter-spacing: 3px;
  color: rgba(220,235,255,0.9); /* Sharper text contrast */
  font-weight: 600;
  text-transform: uppercase;
  width: fit-content;
  margin-bottom: 40px;
}

.eco-eyebrow-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #4C8EF7;
  box-shadow: 0 0 8px #4C8EF7, 0 0 16px rgba(76,142,247,0.6);
  flex-shrink: 0;
  animation: ecoDotPulse 2.4s ease-in-out infinite;
}

@keyframes ecoDotPulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 8px #4C8EF7, 0 0 16px rgba(76,142,247,0.6); }
  50%       { opacity: .55; box-shadow: 0 0 4px #4C8EF7; }
}

.eco-headline {
  grid-column: 1 / 2;
  font-family: 'Playfair Display', serif;
  font-size: clamp(44px, 4.5vw, 68px);
  line-height: 1.04;
  color: #ffffff;
  letter-spacing: -1.5px;
  margin: 0;
}

.eco-headline em {
  font-style: italic;
  color: #A3C7FF;
}

.eco-subline {
  grid-column: 2 / 3;
  grid-row: 2 / 4;
  color: rgba(215, 230, 255, 0.75); /* Fixed ultra-transparent contrast */
  font-size: 16px;
  line-height: 2;
  font-weight: 300;
  padding-top: 8px;
  max-width: 640px;
}

.eco-divider {
  grid-column: 1 / -1;
  height: 1px;
  background: linear-gradient(90deg, rgba(76,142,247,0.35), transparent 60%);
  margin-top: 48px;
}

/* â”€â”€ Grid â”€â”€ */
.eco-grid {
  max-width: 1380px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}

/* â”€â”€ Individual card â”€â”€ */
.eco-card {
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(160deg, rgba(10,14,28,0.85) 0%, rgba(6,9,18,0.95) 100%); /* Deep rich solid structure instead of light frost */
  border: 1px solid rgba(255,255,255,0.09);
  backdrop-filter: blur(16px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.06),
    0 24px 64px rgba(0,0,0,0.65); /* Deeper back-drop shading */
  transition: transform 0.4s cubic-bezier(.22,1,.36,1), border-color 0.3s, box-shadow 0.4s;
  position: relative;
}

.eco-card:hover {
  transform: translateY(-10px);
  border-color: rgba(76,142,247,0.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.1),
    0 40px 90px rgba(0,0,0,0.8),
    0 0 0 1px rgba(76,142,247,0.2);
}

/* Per-card accent borders on hover */
.eco-card--security:hover  { border-color: rgba(214,80,255,0.5); }
.eco-card--smart:hover     { border-color: rgba(0,210,160,0.5); }
.eco-card--collab:hover    { border-color: rgba(76,142,247,0.55); }
.eco-card--interiors:hover { border-color: rgba(200,164,74,0.5); }

.eco-card-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}

/* â”€â”€ Card image â”€â”€ */
.eco-card-media {
  position: relative;
  height: 240px;
  overflow: hidden;
  flex-shrink: 0;
}

.eco-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s cubic-bezier(.22,1,.36,1);
  display: block;
}

.eco-card:hover .eco-card-media img {
  transform: scale(1.08);
}

.eco-card-media-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 15%,
    rgba(6,9,19,0.5) 60%,
    rgba(6,9,19,1) 100__ /* Solidified black blend toward text block */
  );
  z-index: 1;
}

.eco-card-index {
  position: absolute;
  bottom: 16px;
  right: 20px;
  z-index: 2;
  font-size: 11px;
  letter-spacing: 2px;
  color: rgba(200,218,255,0.6); /* Boosted contrast */
  font-weight: 600;
}

/* â”€â”€ Card body â”€â”€ */
.eco-card-body {
  padding: 28px 28px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
  background: #060913; /* Ensured background remains dark under content areas */
}

.eco-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.eco-card-tag {
  font-size: 10px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 50px;
  background: rgba(76,142,247,0.18);
  border: 1px solid rgba(76,142,247,0.3);
  color: rgba(215,230,255,0.9);
  font-weight: 600;
}

.eco-card--security  .eco-card-tag { background: rgba(214,80,255,0.15); border-color: rgba(214,80,255,0.35); color: rgba(240,210,255,0.9); }
.eco-card--smart     .eco-card-tag { background: rgba(0,210,160,0.15);   border-color: rgba(0,210,160,0.35);   color: rgba(160,255,230,0.95); }
.eco-card--collab    .eco-card-tag { background: rgba(76,142,247,0.18);  border-color: rgba(76,142,247,0.35);  color: rgba(215,230,255,0.9); }
.eco-card--interiors .eco-card-tag { background: rgba(200,164,74,0.15);  border-color: rgba(200,164,74,0.35);  color: rgba(245,220,160,0.95); }

.eco-card-arrow {
  color: rgba(200,218,255,0.5);
  transition: color 0.3s, transform 0.3s;
  display: flex;
  align-items: center;
}

.eco-card:hover .eco-card-arrow {
  color: rgba(255,255,255,1);
  transform: translate(3px, -3px);
}

.eco-card-title {
  font-family: 'Playfair Display', serif;
  font-size: 26px;
  line-height: 1.15;
  color: #ffffff;
  letter-spacing: -0.3px;
  margin: 0;
}

.eco-card-desc {
  font-size: 13.5px;
  line-height: 1.85;
  color: rgba(210, 225, 255, 0.7); /* Deep gray-blue readable contrast */
  font-weight: 300;
  margin: 0;
  flex: 1;
}

/* â”€â”€ Feature list â”€â”€ */
.eco-card-features {
  list-style: none;
  padding: 0;
  margin: 4px 0 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.eco-card-features li {
  font-size: 12px;
  color: rgba(200, 218, 255, 0.65); /* Boosted list text visibility */
  display: flex;
  align-items: center;
  gap: 8px;
  letter-spacing: 0.3px;
}

.eco-card-features li::before {
  content: '';
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(76,142,247,0.8);
  flex-shrink: 0;
}

.eco-card--security  .eco-card-features li::before { background: rgba(214,80,255,0.8); }
.eco-card--smart     .eco-card-features li::before { background: rgba(0,210,160,0.8); }
.eco-card--collab    .eco-card-features li::before { background: rgba(76,142,247,0.9); }
.eco-card--interiors .eco-card-features li::before { background: rgba(200,164,74,0.85); }

/* â”€â”€ CTA â”€â”€ */
.eco-card-cta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(200, 218, 255, 0.65); /* Enhanced CTA bottom tier baseline */
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.12);
  margin-top: auto;
  transition: color 0.3s;
}

.eco-card:hover .eco-card-cta { color: rgba(255,255,255,1); }

.eco-card--security:hover  .eco-card-cta { color: rgba(240,210,255,1); }
.eco-card--smart:hover     .eco-card-cta { color: rgba(160,255,230,1); }
.eco-card--collab:hover    .eco-card-cta { color: rgba(200,225,255,1); }
.eco-card--interiors:hover .eco-card-cta { color: rgba(255,230,180,1); }

/* â”€â”€ Integration proof bar â”€â”€ */
.eco-proof-bar {
  max-width: 1380px;
  margin: 60px auto 0;
  border-radius: 20px;
  background: linear-gradient(160deg, rgba(12,17,32,0.9) 0%, rgba(6,9,18,0.98) 100%);
  border: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: blur(16px);
}

.eco-proof-inner {
  display: flex;
  align-items: stretch;
  padding: 36px 48px;
  gap: 0;
}

.eco-proof-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 0 32px;
}

.eco-proof-item:first-child { padding-left: 0; }
.eco-proof-item:last-child  { padding-right: 0; }

.eco-proof-divider {
  width: 1px;
  background: rgba(255,255,255,0.12);
  flex-shrink: 0;
}

.eco-proof-num {
  font-size: 36px;
  font-weight: 600;
  color: #A3C7FF;
  letter-spacing: -1px;
  line-height: 1;
}

.eco-proof-num sup {
  font-size: 0.5em;
  vertical-align: super;
}

.eco-proof-label {
  font-size: 12px;
  color: rgba(210, 225, 255, 0.65);
  letter-spacing: 0.5px;
  line-height: 1.5;
}

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 1200px) {
  .ecosystems-section { padding: 100px 40px 80px; }
  .ecosystems-section::before { left: 40px; right: 40px; }
  .eco-grid { grid-template-columns: repeat(2, 1fr); }
  .eco-header { grid-template-columns: 1fr; }
  .eco-subline { grid-column: 1; grid-row: auto; padding-top: 0; max-width: 100%; }
  .eco-proof-inner { padding: 28px 32px; }
}

@media (max-width: 768px) {
  .ecosystems-section { padding: 80px 20px 60px; }
  .eco-grid { grid-template-columns: 1fr; gap: 16px; }
  .eco-proof-inner {
    flex-direction: column;
    gap: 28px;
    padding: 28px 24px;
  }

  .eco-proof-divider { display: none; }
  .eco-proof-item { padding: 0; }
}
.eviz-form-error.visible {
  display: block;       
  opacity: 1;
  color: #ff3333;       
  margin-top: 8px;
  transition: opacity 0.2s ease-in-out;
}
clients-section { padding: 4rem 0; overflow: hidden; position: relative; }

/* Top glow divider before Why Us */
.client-section{
  background:#121b3a
}

.clients-label { text-align: center; font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: #aaa; margin: 0 0 2.5rem; }
.clients-track-wrapper {
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}
.clients-track { display: flex; align-items: center; gap: 4rem; width: max-content; }
.client-slide { flex-shrink: 0; width: 250px; height: 150px; display: flex; align-items: center; justify-content: center; }
.client-slide img { max-width: 100%; max-height: 100%; object-fit: contain; filter: none; transition: transform 0.3s ease, opacity 0.4s; opacity: 0; }
.client-slide img.loaded { opacity: 1; }
.client-slide img:hover { transform: scale(1.08); }
@media (prefers-reduced-motion: reduce) { .clients-track { animation: none !important; flex-wrap: wrap; width: 100%; justify-content: center; } }

clients-section, clients-section::before,clients-section::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
.dividerindex {
    width: 100%;
    height: 2px;
    background: linear-gradient(
        90deg,
        #1B3A6B,
        #4C8EF7,
        #7B61FF,
        #4C8EF7,
        #1B3A6B
    );
    background-size: 200% 100%;
    animation: gradientFlow 6s linear infinite;
}

@keyframes gradientFlow {
    from {
        background-position: 0% 50%;
    }
    to {
        background-position: 200% 50%;
    }
}


.clients-section {
    position: relative;
}

.clients-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px; /* border thickness */

    background: linear-gradient(
        90deg,
        #1B3A6B,
        #4C8EF7,
        #7B61FF,
        #4C8EF7,
        #1B3A6B
    );
}
.ticker-band{
    width: 100%;
    background: #244b8c;
    background: linear-gradient(90deg,rgba(36, 75, 140, 0.93) 0%, rgba(59, 28, 120, 0.85) 47%, rgba(32, 138, 138, 1) 96%);
    overflow: hidden;
    padding: 14px 0;
    position: relative;
}

.ticker-track{
    display:flex;
    align-items:center;
    width:max-content;
    animation:tickerMove 30s linear infinite;
}

.ticker-track span{
    color:#fff;
    font-size:14px;
    font-weight:600;
    letter-spacing:1.5px;
    white-space:nowrap;
    margin-right:100px; /* controls spacing */
    text-transform:uppercase;
}

@keyframes tickerMove{
    from{
        transform:translateX(0);
    }
    to{
        transform:translateX(-50%);
    }
}
.ecosystem-groups{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:80px;
    margin-bottom:40px;
}

.eco-group{
    position:relative;
    padding-bottom:24px;
}

.eco-group::after{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    width:100%;
    height:2px;

    background:linear-gradient(
        90deg,
        rgba(126,167,255,.8),
        rgba(126,167,255,.15)
    );
}

.eco-kicker{
    display:block;
    color:#7ea7ff;
    text-transform:uppercase;
    letter-spacing:2px;
    font-size:12px;
    margin-bottom:8px;
}

.eco-group h3{
    color:#fff;
    font-size:32px;
    margin:0 0 10px;
}

.eco-group p{
    color:rgba(255,255,255,.7);
    line-height:1.6;
    max-width:500px;
}
.eco-group-title{
    grid-row:1;
    margin-bottom:10px;
    position:relative;
}

.eco-group-title--security{
    grid-column:1 / span 2;
}

.eco-group-title--space{
    grid-column:3 / span 2;
}

.eco-group-title span{
    display:inline-block;

    font-family:'Playfair Display',serif;
    font-size:1.6rem;
    font-weight:600;
    color:#fff;

    padding-bottom:14px;
}

.eco-group-title::after{
    content:'';
    position:absolute;
    left:0;
    right:0;
    bottom:0;

    height:1px;

    background:linear-gradient(
        90deg,
        rgba(163,199,255,.9),
        rgba(163,199,255,.15)
    );
}
.eco-group-box{
    border:1px solid rgba(163,199,255,.45);
    border-radius:24px;
    padding:30px;
    background:rgba(163,199,255,.03);
    margin-bottom:40px;
}

.eco-group-heading{
    margin-bottom:24px;
}

.eco-group-heading h3{
    color:#A3C7FF;
    margin:0;
    font-size:2rem;
    font-weight:600;
}

.eco-group-cards{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:20px;
}
/* Container Panel Management */
.wia-tab-panel {
  display: none;
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.wia-tab-panel.active {
  display: block;
  opacity: 1;
}

/* Ensure global space-tab elements look uniform here */
.spaces-tabs {
  display: flex;
  border-bottom: 2px solid #eaeaea;
}

.space-tab {
  padding: 12px 24px;
  border: none;
  background: none;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  color: #777;
  border-bottom: 3px solid transparent;
  transition: all 0.3s ease;
}

.space-tab.active {
  color: #000;
  border-bottom-color: #000;
}
/* ── WIA TAB PANELS ── */
.wia-tab-panel {
  display: none;
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.wia-tab-panel.active {
  display: block;
  opacity: 1;
  animation: wiaFadeIn 0.45s ease;
}

@keyframes wiaFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── ENHANCED TAB BUTTONS ── */
.wia-tabs {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-bottom: 48px;
  flex-wrap: wrap;
}

.wia-tab {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 28px;
  border: 2px solid rgba(27, 58, 107, 0.15);
  border-radius: 100px;
  background: transparent;
  font-family: 'Outfit', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-soft, #4A4843);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.wia-tab .wia-tab-icon {
  font-size: 18px;
  line-height: 1;
}

.wia-tab:hover {
  background: rgba(42, 95, 192, 0.06);
  border-color: rgba(42, 95, 192, 0.3);
  transform: translateY(-2px);
}

.wia-tab.active {
  background: var(--charcoal-deep, #13161B);
  border-color: var(--charcoal-deep, #13161B);
  color: #fff;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}
