
    *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    :root{
      --cobalt:#1B3FBF;--peri:#8BA7D4;--cream:#F5F0E8;
      --gold:#FFD000;--orange:#F66725;--pink:#FF8DAC;
      --cell:155px;--gap:8px;
      --ease:cubic-bezier(.4,0,.2,1);
    }
    html{scroll-behavior:smooth}
    body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--cobalt);overflow-x:hidden;margin:0;padding:0}

    /* ── NAV ── */
    nav{background:var(--cobalt);display:flex;align-items:center;justify-content:space-between;padding:0 48px;height:68px;position:sticky;top:0;z-index:200}
    .nav-links{display:flex;gap:40px;list-style:none}
    .nav-links a{color:var(--cream);text-decoration:none;font-size:15px;font-weight:600;opacity:.88;transition:opacity .2s}
    .nav-links a:hover{opacity:1}
    .nav-logo{height:44px;width:auto;display:block}

    /* Hamburger */
    .hb{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;background:none;border:none;padding:4px;z-index:300}
    .hb span{display:block;width:24px;height:2.5px;background:var(--cream);border-radius:2px;transition:transform .3s,opacity .3s;transform-origin:center}
    .hb.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
    .hb.open span:nth-child(2){opacity:0;transform:scaleX(0)}
    .hb.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

    /* Side menu */
    .sidemenu{position:fixed;top:0;left:-100%;width:min(250px,72vw);height:100vh;height:100svh;background:var(--cobalt);z-index:250;transition:left .35s var(--ease);display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:52px;padding:80px 24px 40px}
    .sidemenu.open{left:0}
    .sidemenu a{color:var(--cream);text-decoration:none;font-size:22px;font-weight:700;padding:10px 0;text-align:center;border-bottom:1px solid rgba(245,240,232,.15)}
    .overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:240}
    .overlay.open{display:block}

    /* ── HERO ── */
    .hero{min-height:calc(100vh - 68px);display:flex;align-items:center;justify-content:center;padding:48px 56px;gap:56px;background:var(--cream)}

    /* Puzzle grid */
    .puzzle-area{flex:0 0 auto;position:relative}
    .puzzle-grid{position:relative;width:calc(var(--cell)*3 + var(--gap)*2);height:calc(var(--cell)*3 + var(--gap)*2)}
    .cell{position:absolute;width:var(--cell);height:var(--cell);will-change:top,left}
    .cell.moving{transition:top 1.4s cubic-bezier(0.22,0.61,0.36,1),left 1.4s cubic-bezier(0.22,0.61,0.36,1)}
    .shape-img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none}

    /* Blobs */
    .bwrap{position:relative;width:100%;height:100%}
    .bbody{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}
    .beyes{position:absolute;pointer-events:none;transform:translateX(0);transition:transform .3s ease-out}
    .ce{left:31.051%;top:44.314%;width:37.430%;height:9.036%}
    .pe{left:35.770%;top:43.685%;width:28.460%;height:9.956%}

    /* Heart tile */
    .heart-tile{position:absolute;width:var(--cell);height:var(--cell);pointer-events:none;z-index:5;opacity:0;transform:scale(0.9);transition:opacity .45s ease,transform .45s cubic-bezier(.34,1.3,.64,1)}
    .heart-tile.show{opacity:1;transform:scale(1)}
    .heart-tile img{width:100%;height:100%;object-fit:fill;display:block}

    /* Float shapes */
    .fshape{position:absolute;width:var(--cell);height:var(--cell);object-fit:contain;pointer-events:none;will-change:transform;transform-origin:center}
    #fAsterisk{top:0;left:0}
    #fBurst{bottom:0;right:0}

    /* Hero text */
    .hero-text{display:flex;flex-direction:column;align-items:center;gap:18px;max-width:540px}
    .headline{display:flex;flex-direction:column;width:100%;line-height:.78}
    .hl1{font-family:'DM Sans',sans-serif;font-weight:800;font-size:clamp(64px,6.8vw,96px);color:var(--cobalt);letter-spacing:-.025em;align-self:flex-start;padding-right:52px}
    .hl2{display:flex;align-items:baseline;gap:1px;align-self:flex-end;padding-left:52px}
    .wfound{font-family:'DM Sans',sans-serif;font-weight:800;font-size:clamp(64px,6.8vw,96px);color:var(--peri);letter-spacing:-.025em}
    .wus{font-family:'Playfair Display',serif;font-style:italic;font-weight:700;font-size:clamp(74px,7.8vw,110px);color:var(--cobalt)}
    .wex{font-family:'Dancing Script',cursive;font-weight:700;font-size:clamp(74px,7.8vw,110px);color:var(--cobalt);line-height:1}
    .subtext{font-size:20px;line-height:1.7;color:var(--cobalt);text-align:center;margin-top:4px}
    .subtext strong{font-weight:700}
    .cta{display:inline-block;background:var(--cobalt);color:#fff;font-family:'DM Sans',sans-serif;font-weight:600;font-size:20px;padding:19px 56px;border-radius:50px;text-decoration:none;border:none;cursor:pointer;transition:background .2s,transform .15s}
    .cta:hover{background:#142e99;transform:translateY(-2px)}
    .cta:active{transform:translateY(0)}

    /* ── SCROLL TRANSITION ── */
    .svc-section{
      background:var(--cobalt);
      padding:80px 0 120px;
      box-shadow:0 -48px 80px -8px rgba(27,63,191,0.22),0 48px 70px -8px rgba(27,63,191,0.15);
    }

    /* ── SERVICES SECTION ── */
    .sec-inner{max-width:1100px;margin:0 auto;padding:0 48px}
    .sec-lbl{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--peri);margin-bottom:10px}
    .sec-ttl{font-size:clamp(30px,4vw,52px);font-weight:800;color:var(--cream);line-height:1.1;margin-bottom:56px;letter-spacing:-.02em}
    .sec-ttl em{font-family:'Playfair Display',serif;font-style:italic;font-weight:500;color:var(--peri);letter-spacing:0}

    /* Grid */
    .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}

    /* Card */
    .card{background:#1e46d4;border:1px solid rgba(255,255,255,.13);padding:32px 28px 28px;cursor:pointer;display:flex;flex-direction:column;transition:border-color .25s,background .25s;min-height:210px}
    .card:hover,.card.open{border-color:rgba(255,255,255,.32);background:#2149e0}
    .card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}
    .card-num{font-size:13px;font-weight:700;color:rgba(245,240,232,.35);letter-spacing:.04em;padding-top:4px}

    /* Icon box */
    .ib{width:72px;height:72px;position:relative;flex-shrink:0;overflow:hidden}
    .ib img{display:block}

    /* 01 Asterisk */
    .s-ast{position:absolute;width:74%;height:74%;top:13%;left:13%;object-fit:contain;transition:transform .55s var(--ease);transform-origin:center}
    .card-web:hover .s-ast,.card-web.open .s-ast{transform:rotate(30deg)}

    /* 02 Star */
    .s-sb,.s-sf{position:absolute;width:72%;height:72%;top:14%;left:14%;object-fit:contain;transition:transform .55s var(--ease);transform-origin:center}
    .s-sb{z-index:1}.s-sf{z-index:2}
    .card-brand:hover .s-sb,.card-brand.open .s-sb{transform:rotate(45deg)}

    /* 03 Spinners */
    .s-lg,.s-sm{position:absolute;transition:transform .65s var(--ease);transform-origin:center}
    .s-lg{position:absolute;width:82%;height:82%;top:9%;left:9%;object-fit:contain}
    .s-sm{width:60%;height:60%;top:20%;left:20%;opacity:.5;object-fit:contain}
    .card-ai:hover .s-lg,.card-ai.open .s-lg{transform:rotate(-120deg)}
    .card-ai:hover .s-sm,.card-ai.open .s-sm{transform:rotate(120deg)}

    /* 04 Halfcircle */
    .hc-wrap{position:absolute;left:50%;transform:translateX(-50%);width:58px;height:58px;bottom:7px}
    .hc-dome-front,.hc-dome-back{position:absolute;left:0;width:58px;height:29px;background:#F66725}
    .hc-dome-front{border-radius:29px 29px 0 0;bottom:0}
    .hc-dome-back{border-radius:29px 29px 0 0;bottom:29px;transform:translateY(100%);transition:transform .55s var(--ease)}
    .card-mkt:hover .hc-dome-back,.card-mkt.open .hc-dome-back{transform:translateY(0)}

    /* 05 Bars */
    .bars-wrap{position:absolute;inset:0;width:100%;height:100%}
    .s-by,.s-bb{position:absolute;width:65%;height:65%;top:17.5%;left:17.5%;object-fit:contain;display:block}
    .s-by{z-index:1;transition:transform .55s var(--ease);transform-origin:bottom center}
    .s-bb{z-index:2}
    .card-data:hover .s-by,.card-data.open .s-by{transform:translateY(-30%)}

    /* 06 Flower */
    .s-fl{position:absolute;width:80%;height:80%;top:10%;left:10%;object-fit:contain;transition:transform .55s var(--ease);transform-origin:center}
    .card-plan:hover .s-fl,.card-plan.open .s-fl{transform:rotate(40deg)}

    /* Service name */
    .card-name{display:flex;align-items:baseline;gap:10px}
    .w1{font-family:'DM Sans',sans-serif;font-weight:800;font-size:clamp(22px,2.6vw,34px);color:var(--cream);letter-spacing:-.025em;line-height:1;white-space:nowrap}
    .w2{font-family:'Playfair Display',serif;font-style:italic;font-weight:500;font-size:clamp(22px,2.6vw,34px);color:var(--cream);line-height:1;white-space:nowrap}

    /* Panel */
    .panel{max-height:0;overflow:hidden;opacity:0;transition:max-height .45s var(--ease),opacity .3s ease}
    .panel-inner{padding:16px 0 4px}
    .panel-inner p{font-size:clamp(13px,1.2vw,15px);line-height:1.68;font-weight:400;color:var(--cream)}
    .panel-inner p b{font-weight:700;color:var(--cream)}
    .card:hover .panel,.card.open .panel{opacity:1}

    /* ── ABOUT SECTION ── */
    .about-section{
      background:var(--cream);
      padding:140px 0 110px;
      position:relative;
      z-index:3;
    }

    /* ── INTERSTITIAL QUOTES ── */
    .quotes-section{
      position:relative;
      width:100%;
      padding:0;
      margin:0;
      z-index:2;
      overflow:hidden;
    }
    .quotes-slideshow{
      position:relative;
      width:100%;
      max-width:1920px;
      margin:0 auto;
      background:var(--cobalt);
    }
    .quote-slide{
      position:absolute;
      top:0;
      left:0;
      width:100%;
      height:auto;
      opacity:0;
      transition:opacity .8s ease-in-out;
    }
    .quote-slide.active{opacity:1}
    .quote-slide img{
      width:100%;
      height:auto;
      display:block;
      vertical-align:middle;
    }
    /* Set aspect ratio container */
    .quotes-slideshow::before{
      content:'';
      display:block;
      padding-top:18.75%; /* 360/1920 = 0.1875 = 18.75% */
    }
    /* Scroll overlay effects */
    .quotes-section::before,
    .quotes-section::after{
      content:'';
      position:absolute;
      left:0;
      right:0;
      background:var(--cream);
      z-index:10;
      pointer-events:none;
      transition:transform .15s ease-out;
      box-shadow:0 0 30px rgba(27,63,191,.15);
    }
    .quotes-section::before{
      top:0;
      height:60px; /* Reduced from 100px */
      transform:translateY(-100%);
    }
    .quotes-section::after{
      bottom:0;
      height:60px; /* Reduced from 100px */
      transform:translateY(100%);
    }
    /* Shadow on image during overlap */
    .quotes-slideshow{
      position:relative;
      width:100%;
      max-width:1920px;
      margin:0 auto;
      background:var(--cobalt);
      transition:box-shadow .15s ease-out;
    }
    .quotes-section.has-overlay .quotes-slideshow{
      box-shadow:inset 0 15px 30px rgba(0,0,0,.12), inset 0 -15px 30px rgba(0,0,0,.12);
    }

    /* ── FEATURED BLOGS ── */
    .featured-blogs-section{
      background:var(--cream);
      padding:100px 0 120px;
      position:relative;
      z-index:3;
    }
    .fb-inner{max-width:1280px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:240px 1fr;gap:40px;align-items:start}
    .fb-header{}
    .fb-lbl{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--peri);margin-bottom:10px}
    .fb-ttl{font-size:clamp(32px,4.2vw,56px);font-weight:800;color:var(--cobalt);line-height:1.05;letter-spacing:-.02em}
    .fb-ttl em{font-family:'Playfair Display',serif;font-style:italic;font-weight:500;color:var(--peri);letter-spacing:0}
    .fb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
    .fb-card{
      background:var(--cobalt);
      border:2px solid var(--cobalt);
      padding:0;
      cursor:pointer;
      transition:transform .25s var(--ease),box-shadow .25s;
      display:flex;
      flex-direction:column;
      min-height:420px;
      box-shadow:0 4px 16px rgba(27,63,191,.25);
      overflow:hidden;
    }
    .fb-card:hover{
      transform:translateY(-6px);
      box-shadow:0 12px 32px rgba(27,63,191,.35);
    }
    .fb-img{
      width:100%;
      height:180px;
      overflow:hidden;
      background:var(--cream);
      flex-shrink:0;
    }
    .fb-img img{
      width:100%;
      height:100%;
      object-fit:cover;
      object-position:center;
      display:block;
    }
    .fb-content{
      padding:28px 24px 24px;
      display:flex;
      flex-direction:column;
      gap:16px;
      flex-grow:1;
    }
    .fb-cat{
      font-size:11px;
      font-weight:700;
      letter-spacing:.1em;
      text-transform:uppercase;
      color:var(--peri);
    }
    .fb-title{
      font-size:clamp(18px,1.8vw,22px);
      font-weight:800;
      color:var(--cream);
      line-height:1.25;
      letter-spacing:-.015em;
      flex-grow:1;
    }
    .fb-excerpt{
      font-size:14px;
      line-height:1.6;
      color:var(--cream);
      opacity:.75;
    }
    .fb-meta{
      display:flex;
      align-items:center;
      justify-content:space-between;
      padding-top:12px;
      border-top:1px solid rgba(245,240,232,.15);
    }
    .fb-date{font-size:12px;color:var(--cream);opacity:.5;font-weight:600}
    .fb-read{
      font-size:13px;
      font-weight:700;
      color:var(--peri);
      text-decoration:none;
      transition:color .2s;
    }
    .fb-read:hover{color:var(--cream)}
    
    /* Featured blogs - View All Button */
    .fb-btn-container{
      text-align:left;
      margin-top:24px;
    }
    .fb-view-all{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:14px 32px;
      background:var(--cobalt);
      color:var(--cream);
      font-size:15px;
      font-weight:700;
      text-decoration:none;
      border-radius:50px;
      transition:background .2s,transform .15s;
    }
    .fb-btn-arrow{
      transition:transform .2s;
    }
    .fb-view-all:hover{
      background:#142e99;
      transform:translateY(-2px);
    }
    .fb-view-all:hover .fb-btn-arrow{
      transform:translateX(3px);
    }
    .fb-view-all:active{
      transform:translateY(0);
    }

    /* ── ABOUT SECTION ── */
    .about-inner{
      max-width:1100px;margin:0 auto;padding:0 48px;
      display:flex;align-items:center;justify-content:center;gap:80px;
    }

    /* Blob + quote column — LEFT */
    .ab-left{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:28px}

    .ab-col{display:flex;align-items:center;position:relative}
    .ab-wrap{position:relative;flex-shrink:0}
    .ab-blue{width:235px;height:235px;z-index:2}
    .ab-peri{width:230px;height:230px;margin-left:-12px;z-index:1}
    .ab-body{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block}

    /* Blob bounce-settle — no fade, just physical drop */
    .ab-wrap{transform:translateY(-16px);transition:transform .65s cubic-bezier(.34,1.4,.64,1)}
    .ab-col.entered .ab-wrap{transform:translateY(0)}
    .ab-col.entered .ab-peri{transition-delay:.1s}

    /* Ground shadow */
    .ab-wrap::after{
      content:'';position:absolute;bottom:-10px;left:15%;
      width:70%;height:14px;
      background:radial-gradient(ellipse at center,rgba(27,63,191,.12) 0%,transparent 72%);
      border-radius:50%;z-index:0;pointer-events:none;
    }

    /* Pupils */
    .ab-pupil{position:absolute;background:#1a1a1a;z-index:3;transition:transform .45s ease-out}
    .ab-blue .ab-pupil{width:8%;height:8%;border-radius:50%}
    .ab-blue .ab-pl{left:34.5%;top:44%}
    .ab-blue .ab-pr{left:61%;top:44%}
    .ab-peri .ab-pupil{width:6.5%;height:8.5%;border-radius:50%}
    .ab-peri .ab-pl{left:32%;top:46.5%}
    .ab-peri .ab-pr{left:53.5%;top:46.5%}

    /* Cheeks */
    .ab-cheek{position:absolute;object-fit:contain;opacity:0.5;z-index:2;pointer-events:none;transition:transform .5s cubic-bezier(.34,1.5,.64,1)}
    .ab-blue .ab-cl{left:31%;top:60%;width:10%;height:auto}
    .ab-blue .ab-cr{left:69%;top:60%;width:10%;height:auto}
    .ab-peri .ab-cl{left:25%;top:62%;width:10%;height:auto}
    .ab-peri .ab-cr{left:56%;top:62%;width:10%;height:auto}

    /* Ornaments — scroll-rotated via JS, met state adds extra rotation */
    .ab-ornament{position:absolute;object-fit:contain;z-index:4;pointer-events:none;will-change:transform}
    .ab-star{width:17%;top:10%;right:3%;transform-origin:center}
    .ab-flower{width:15%;top:10%;right:6%;transform-origin:center}

    /* Met state animation */
    .ab-col.met .ab-blue .ab-pl,
    .ab-col.met .ab-blue .ab-pr{transform:translateX(8px)}
    .ab-col.met .ab-peri .ab-pl,
    .ab-col.met .ab-peri .ab-pr{transform:translateX(-7px)}
    .ab-col.met .ab-cheek{transform:scale(1.16)}

    /* Italic quote below blobs */
    .ab-quote{font-size:clamp(13px,1.3vw,16px);font-weight:400;color:var(--cobalt);opacity:.50;line-height:1.6;font-style:italic;text-align:center;max-width:400px}

    /* Text column — RIGHT */
    .ab-text{flex:1;min-width:0;max-width:440px}
    .ab-lbl{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--peri);margin-bottom:10px}
    .ab-hdg{line-height:1.08;margin-bottom:22px}
    .ab-h1{display:block;font-family:'DM Sans',sans-serif;font-weight:800;font-size:clamp(42px,5.2vw,72px);color:var(--cobalt);letter-spacing:-.025em}
    .ab-h2{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
    .ab-h2-plain{font-family:'DM Sans',sans-serif;font-weight:800;font-size:clamp(42px,5.2vw,72px);color:var(--cobalt);letter-spacing:-.025em}
    .ab-h2-em{font-family:'Playfair Display',serif;font-style:italic;font-weight:500;font-size:clamp(44px,5.4vw,74px);color:var(--peri);letter-spacing:0}
    .ab-body-text{font-size:clamp(16px,1.4vw,19px);line-height:1.78;font-weight:400;color:var(--cobalt)}
    .ab-body-text b{font-weight:700}

    /* ── CONTACT SECTION ── */
    .contact-section{
      background:var(--cobalt);
      padding:100px 0 120px;
      position:relative;
    }
    .contact-inner{
      max-width:1280px;
      margin:0 auto;
      padding:0 48px;
      display:grid;
      grid-template-columns:400px 1fr;
      gap:80px;
      align-items:start;
    }
    
    /* Left side - Contact details */
    .contact-info{}
    .contact-ttl{
      font-size:clamp(36px,4.5vw,64px);
      font-weight:800;
      color:var(--cream);
      line-height:1.1;
      letter-spacing:-.02em;
      margin-bottom:48px;
    }
    .contact-ttl em{
      font-family:'Playfair Display',serif;
      font-style:italic;
      font-weight:500;
      color:var(--peri);
    }
    .contact-detail{
      margin-bottom:32px;
    }
    .contact-label{
      font-size:13px;
      font-weight:700;
      letter-spacing:.1em;
      text-transform:uppercase;
      color:var(--peri);
      margin-bottom:8px;
    }
    .contact-value{
      font-size:18px;
      font-weight:600;
      color:var(--cream);
      line-height:1.6;
    }
    .contact-value a{
      color:var(--cream);
      text-decoration:none;
      transition:color .2s;
    }
    .contact-value a:hover{
      color:var(--gold);
    }
    .contact-social{
      margin-top:48px;
    }
    .contact-social-label{
      font-size:13px;
      font-weight:700;
      letter-spacing:.1em;
      text-transform:uppercase;
      color:var(--peri);
      margin-bottom:16px;
    }
    .social-links{
      display:flex;
      gap:16px;
    }
    .social-link{
      width:44px;
      height:44px;
      border-radius:50%;
      background:rgba(245,240,232,.1);
      display:flex;
      align-items:center;
      justify-content:center;
      color:var(--cream);
      text-decoration:none;
      font-size:20px;
      transition:background .2s,transform .2s;
    }
    .social-link:hover{
      background:var(--peri);
      transform:translateY(-2px);
    }
    
    /* Right side - Form */
    .contact-form{}
    .form-row{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:20px;
      margin-bottom:20px;
    }
    .form-group{
      display:flex;
      flex-direction:column;
    }
    .form-label{
      font-size:14px;
      font-weight:600;
      color:var(--cream);
      margin-bottom:8px;
    }
    .form-input,
    .form-select,
    .form-textarea{
      background:rgba(245,240,232,.08);
      border:1px solid rgba(245,240,232,.15);
      border-radius:8px;
      padding:14px 16px;
      font-family:'DM Sans',sans-serif;
      font-size:15px;
      color:var(--cream);
      transition:border-color .2s,background .2s;
    }
    .form-input::placeholder,
    .form-textarea::placeholder{
      color:rgba(245,240,232,.4);
    }
    .form-input:focus,
    .form-select:focus,
    .form-textarea:focus{
      outline:none;
      border-color:var(--peri);
      background:rgba(245,240,232,.12);
    }
    .form-textarea{
      resize:vertical;
      min-height:160px;
      font-family:'DM Sans',sans-serif;
    }
    .form-submit{
      width:100%;
      background:var(--cream);
      color:var(--cobalt);
      font-family:'DM Sans',sans-serif;
      font-weight:700;
      font-size:16px;
      padding:18px 32px;
      border:none;
      border-radius:50px;
      cursor:pointer;
      transition:background .2s,transform .15s;
      margin-top:40px;
    }
    .form-submit:hover{
      background:var(--gold);
      transform:translateY(-2px);
    }
    .form-submit:active{
      transform:translateY(0);
    }
    .form-submit:disabled{
      opacity:.5;
      cursor:not-allowed;
      transform:none;
    }
    .form-status{
      text-align:center;
      margin-top:16px;
      font-size:14px;
      font-weight:600;
      line-height:1.5;
      min-height:20px;
    }
    .form-status.success{color:var(--peri)}
    .form-status.error{color:var(--peri)}

    /* Dropdown option colours — consistent across devices */
    .form-select option{
      background-color:#1B3FBF;
      color:#F5F0E8;
    }

    /* Inline field validation */
    .field-error{
      display:block;
      font-size:12px;
      font-weight:600;
      color:var(--gold);
      margin-top:5px;
      min-height:16px;
      line-height:1.4;
    }
    .form-input.invalid,
    .form-select.invalid,
    .form-textarea.invalid{
      border-color:var(--gold);
    }

    /* ── FOOTER QUOTE ── */
    .footer-quote{
      grid-column:1 / -1;
      text-align:center;
      padding:40px 20px 0;
    }
    .footer-quote-text{
      font-family:'DM Sans',sans-serif;
      font-style:normal;
      font-size:13px;
      color:var(--peri);
      line-height:1.6;
      margin:0;
      padding:0;
    }

    /* ── RESPONSIVE ── */
    @media(max-width:860px){
      .hb{display:flex}
      .nav-links{display:none}
      nav{padding:0 20px}
      /* Hero mobile */
      .hero{flex-direction:column;align-items:center;padding:32px 20px 48px;gap:44px;min-height:auto}
      :root{--cell:106px}
      .puzzle-area{order:1}
      .hero-text{order:2;width:100%;max-width:480px;align-items:center}
      .headline{width:auto;max-width:100%;align-self:center}
      .hl1{font-size:clamp(44px,11vw,62px);padding-right:32px;padding-left:0}
      .hl2{padding-left:32px;padding-right:0}
      .wfound{font-size:clamp(44px,11vw,62px)}
      .wus,.wex{font-size:clamp(50px,12.5vw,70px)}
      .subtext{font-size:18px}
      .cta{font-size:18px;padding:17px 48px}
      .bwrap{overflow:hidden;border-radius:50%}
      /* Services mobile */
      .svc-section{padding:56px 0 72px}
      .sec-inner{padding:0 20px}
      .sec-lbl{text-align:center}
      .sec-ttl{text-align:center}
      .svc-grid{grid-template-columns:repeat(2,1fr)}
      /* About mobile */
      .about-section{padding:56px 0 72px}
      .about-inner{flex-direction:column;padding:0 28px;gap:36px}
      .ab-left{order:-1}
      .ab-text{max-width:100%;text-align:center}
      .ab-lbl{text-align:center}
      .ab-hdg{text-align:center}
      .ab-h2{justify-content:center}
      .ab-body-text{text-align:center}
      .ab-blue{width:170px;height:170px}
      .ab-peri{width:170px;height:170px;margin-left:-10px}
      .ab-wrap::after{bottom:-8px;height:10px}
      .ab-h1{font-size:clamp(32px,8.5vw,46px)}
      .ab-h2-plain{font-size:clamp(32px,8.5vw,46px)}
      .ab-h2-em{font-size:clamp(36px,9.5vw,52px)}
      /* Featured blogs mobile */
      .featured-blogs-section{padding:72px 0 72px}
      /* Reduce quote overlays on mobile */
      .quotes-section::before,
      .quotes-section::after{height:25px}
      /* Zoom slideshow on mobile — crop blank sides, keep text visible */
      .quotes-slideshow::before{padding-top:22%}
      .quote-slide{height:100%;overflow:hidden}
      .quote-slide img{height:100%;width:100%;object-fit:cover;object-position:center}
      .fb-inner{display:flex;flex-direction:column;gap:12px;padding:0 28px}
      /* Flatten header so children can be reordered independently */
      .fb-header{display:contents}
      .fb-lbl{order:1;text-align:center;width:100%;margin-bottom:0}
      .fb-ttl{order:2;text-align:center;width:100%;margin-bottom:0}
      .fb-grid{display:grid;grid-template-columns:1fr;gap:32px;order:3;max-width:340px;margin:36px auto 0;width:100%}
      .fb-card{min-height:380px}
      .fb-img{height:160px}
      .fb-btn-container{order:4;text-align:center;margin-top:28px;width:100%}
      /* Contact mobile — flatten contact-info so children reorder within contact-inner */
      .contact-inner{display:flex;flex-direction:column;gap:32px;padding:0 28px;align-items:center}
      .contact-info{display:contents}
      .contact-ttl{order:1;text-align:center;margin-bottom:0;width:100%}
      .contact-form{order:2;width:100%;max-width:480px}
      .contact-details-grid{order:3;width:100%;display:grid;grid-template-columns:1fr;gap:20px;text-align:center;margin-top:52px}
      .contact-detail{margin-bottom:0;padding-bottom:0}
      .contact-social{order:4;text-align:center;width:100%;margin-top:8px}
      .social-links{justify-content:center}
      .footer-quote{order:5;width:100%}
      .form-row{grid-template-columns:1fr}
    }
    @media(max-width:480px){
      .svc-grid{grid-template-columns:1fr}
      .ab-blue{width:140px;height:140px}
      .ab-peri{width:140px;height:140px;margin-left:-8px}
      .ab-col.met .ab-blue .ab-pl,
      .ab-col.met .ab-blue .ab-pr{transform:translateX(5px)}
      .ab-col.met .ab-peri .ab-pl,
      .ab-col.met .ab-peri .ab-pr{transform:translateX(-5px)}
      .ab-wrap::after{bottom:-6px;height:8px}
      .ab-quote{font-size:13px}
    }
    @media(max-width:400px){
      :root{--cell:88px}
      .hl1{padding-right:20px}
      .hl2{padding-left:20px}
    }
    /* ── JOY CHATBOT ── */
    .chat-toggle{
      position:fixed;
      bottom:28px;
      right:28px;
      width:64px;
      height:64px;
      border-radius:50%;
      border:none;
      cursor:pointer;
      z-index:1000;
      padding:0;
      background:transparent;
      transition:transform .3s var(--ease),box-shadow .3s;
      box-shadow:0 4px 20px rgba(246,103,37,.3);
    }
    .chat-toggle:hover{
      transform:scale(1.08);
      box-shadow:0 6px 28px rgba(246,103,37,.4);
    }
    .chat-toggle:active{transform:scale(.95)}
    .chat-toggle img{width:100%;height:100%;border-radius:50%;display:block}
    .chat-toggle::before{
      content:'';
      position:absolute;
      inset:-4px;
      border-radius:50%;
      border:2px solid var(--gold);
      opacity:0;
      animation:joy-pulse 2.5s ease-out infinite;
    }
    @keyframes joy-pulse{
      0%{transform:scale(1);opacity:.6}
      70%{transform:scale(1.35);opacity:0}
      100%{transform:scale(1.35);opacity:0}
    }
    .chat-toggle.hidden{transform:scale(0);opacity:0;pointer-events:none}

    .chat-window{
      position:fixed;
      bottom:28px;
      right:28px;
      width:380px;
      height:560px;
      max-height:calc(100vh - 56px);
      max-width:calc(100vw - 32px);
      background:#FFFDFB;
      border-radius:20px;
      box-shadow:0 12px 48px rgba(246,103,37,.18),0 2px 8px rgba(0,0,0,.06);
      z-index:1001;
      display:flex;
      flex-direction:column;
      overflow:hidden;
      transform:scale(0) translateY(20px);
      transform-origin:bottom right;
      opacity:0;
      pointer-events:none;
      transition:transform .35s var(--ease),opacity .25s ease;
    }
    .chat-window.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}

    .chat-header{
      background:var(--orange);
      padding:18px 20px;
      display:flex;
      align-items:center;
      gap:14px;
      flex-shrink:0;
      position:relative;
    }
    .chat-header::after{
      content:'';
      position:absolute;
      bottom:0;left:0;right:0;
      height:3px;
      background:var(--gold);
    }
    .chat-header-avatar{
      width:42px;height:42px;
      border-radius:50%;
      border:2px solid var(--gold);
      flex-shrink:0;
    }
    .chat-header-info{flex:1;min-width:0}
    .chat-header-name{font-size:16px;font-weight:700;color:#fff;line-height:1.2}
    .chat-header-status{
      font-size:12px;
      color:rgba(255,255,255,.75);
      font-weight:500;
      display:flex;
      align-items:center;
      gap:6px;
    }
    .joy-status-dot{
      width:7px;height:7px;
      border-radius:50%;
      background:var(--gold);
      display:inline-block;
      animation:joy-dot 2s ease-in-out infinite;
    }
    @keyframes joy-dot{
      0%,100%{opacity:1}
      50%{opacity:.4}
    }
    .chat-close{
      background:none;border:none;cursor:pointer;color:#fff;
      opacity:.7;transition:opacity .2s,transform .2s;
      padding:4px;display:flex;align-items:center;justify-content:center;
    }
    .chat-close:hover{opacity:1;transform:rotate(90deg)}

    .chat-body{
      flex:1;
      overflow-y:auto;
      padding:20px 16px;
      display:flex;
      flex-direction:column;
      gap:6px;
      background:#FFF9EE;
      scroll-behavior:smooth;
    }
    .chat-body::-webkit-scrollbar{width:4px}
    .chat-body::-webkit-scrollbar-track{background:transparent}
    .chat-body::-webkit-scrollbar-thumb{background:var(--orange);border-radius:4px;opacity:.4}

    .msg-row{
      display:flex;align-items:flex-end;gap:8px;max-width:85%;
      animation:msg-in .35s var(--ease) both;
    }
    @keyframes msg-in{
      from{opacity:0;transform:translateY(10px)}
      to{opacity:1;transform:translateY(0)}
    }
    .msg-row.sent{align-self:flex-end;flex-direction:row-reverse}
    .msg-row.received{align-self:flex-start}
    .msg-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;margin-bottom:2px}
    .msg-bubble{
      padding:12px 16px;font-size:14px;line-height:1.55;
      font-weight:400;word-wrap:break-word;white-space:pre-wrap;
    }
    .msg-row.sent .msg-bubble{
      background:var(--orange);color:#fff;border-radius:16px 16px 4px 16px;
    }
    .msg-row.received .msg-bubble{
      background:#fff;color:#3D2308;border-radius:16px 16px 16px 4px;
      box-shadow:0 1px 4px rgba(246,103,37,.08);
    }
    .msg-time{font-size:10px;color:#8B6B4A;margin-top:4px;padding:0 44px;opacity:.55}
    .msg-time.sent-time{text-align:right}
    .msg-time.received-time{text-align:left}

    .typing-row{display:flex;align-items:flex-end;gap:8px;align-self:flex-start;max-width:85%}
    .typing-dots{
      background:#fff;border-radius:16px 16px 16px 4px;
      box-shadow:0 1px 4px rgba(246,103,37,.08);
      padding:14px 20px;display:flex;gap:5px;align-items:center;
    }
    .typing-dots span{
      width:7px;height:7px;border-radius:50%;
      background:var(--orange);opacity:.5;
      animation:joy-typing .9s ease-in-out infinite;
    }
    .typing-dots span:nth-child(2){animation-delay:.15s}
    .typing-dots span:nth-child(3){animation-delay:.3s}
    @keyframes joy-typing{
      0%,60%,100%{transform:translateY(0);opacity:.35}
      30%{transform:translateY(-5px);opacity:1}
    }

    .welcome-msg{text-align:center;padding:8px 16px 16px}
    .welcome-msg p{font-size:13px;color:#3D2308;opacity:.4;line-height:1.5}

    .chat-input-area{
      padding:12px 16px 16px;background:#FFFDFB;
      border-top:1px solid rgba(246,103,37,.1);flex-shrink:0;
    }
    .chat-input-wrap{
      display:flex;align-items:flex-end;gap:10px;
      background:#FFF9EE;border-radius:14px;padding:6px 6px 6px 16px;
      transition:box-shadow .2s;
    }
    .chat-input-wrap:focus-within{box-shadow:0 0 0 2px rgba(246,103,37,.15)}
    .chat-input{
      flex:1;border:none;background:transparent;
      font-family:'DM Sans',sans-serif;font-size:14px;color:#3D2308;
      resize:none;outline:none;line-height:1.5;max-height:80px;padding:8px 0;
    }
    .chat-input::placeholder{color:#8B6B4A;opacity:.6}
    .chat-send{
      width:38px;height:38px;border-radius:10px;border:none;
      background:var(--orange);color:#fff;cursor:pointer;
      display:flex;align-items:center;justify-content:center;flex-shrink:0;
      transition:background .2s,transform .15s;
    }
    .chat-send:hover{background:#d8541a;transform:scale(1.05)}
    .chat-send:active{transform:scale(.95)}
    .chat-send:disabled{opacity:.35;cursor:not-allowed;transform:none}
    .chat-send svg{display:block}
    .chat-created{text-align:center;padding:0 16px 10px;background:#FFFDFB}
    .chat-created span{font-size:10px;color:#8B6B4A;opacity:.45;letter-spacing:.02em}

    /* Joy action buttons */
    .joy-actions{
      display:flex;gap:8px;padding:4px 0 4px 36px;flex-wrap:wrap;
      animation:msg-in .35s var(--ease) both;
    }
    .joy-action-btn{
      padding:10px 18px;border-radius:50px;
      font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;
      text-decoration:none;cursor:pointer;
      transition:transform .15s,background .2s;display:inline-block;
    }
    .joy-action-btn:hover{transform:translateY(-1px)}
    .joy-action-write{background:var(--orange);color:#fff}
    .joy-action-write:hover{background:#d8541a}
    .joy-action-call{background:var(--orange);color:var(--cream)}
    .joy-action-call:hover{background:#d8541a}

    /* Click-outside backdrop */
    .chat-backdrop{
      display:none;
      position:fixed;
      inset:0;
      z-index:1000;
      background:transparent;
    }
    .chat-backdrop.open{display:block}

    /* Joy nudge bubble */
    .joy-nudge{
      position:fixed;
      bottom:100px;
      right:24px;
      background:#fff;
      border-radius:12px;
      padding:10px 32px 10px 14px;
      box-shadow:0 4px 20px rgba(246,103,37,.2),0 1px 4px rgba(0,0,0,.06);
      z-index:999;
      cursor:pointer;
      opacity:0;
      transform:translateY(8px) scale(.95);
      pointer-events:none;
      transition:opacity .35s var(--ease),transform .35s var(--ease);
      max-width:220px;
    }
    .joy-nudge.show{
      opacity:1;
      transform:translateY(0) scale(1);
      pointer-events:all;
    }
    .joy-nudge-text{
      font-family:'DM Sans',sans-serif;
      font-size:13px;
      font-weight:600;
      color:#3D2308;
      line-height:1.4;
    }
    .joy-nudge-close{
      position:absolute;
      top:6px;
      right:10px;
      font-size:16px;
      color:#8B6B4A;
      opacity:.5;
      cursor:pointer;
      line-height:1;
      transition:opacity .2s;
    }
    .joy-nudge-close:hover{opacity:1}
    .joy-nudge-tail{
      position:absolute;
      bottom:-6px;
      right:28px;
      width:12px;
      height:12px;
      background:#fff;
      transform:rotate(45deg);
      box-shadow:2px 2px 4px rgba(246,103,37,.08);
      border-radius:0 0 3px 0;
    }

    @media(max-width:480px){
      .chat-window{
        bottom:0;right:0;width:100%;height:100%;
        max-height:100vh;max-width:100vw;border-radius:0;
      }
      .chat-toggle{bottom:20px;right:20px;width:56px;height:56px}
      .joy-nudge{bottom:84px;right:16px}
    }

  
