:root{
  --preload-ms:10000;
  --overlay-opacity:.3;
  --blob-rx:520; --blob-ry:320;
  --blob-noise:.14; --blob-wave:.08;
  --blob-breathe:.03; --blob-smooth:.7;

  --ui-font: "Montserrat", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Spotlight layout */
  --spot-w: min(1100px, 92vw);
  --spot-h: min(560px, 80vh);
  --spot-gap: 18px;

  /* Transitions */
  --fade-ms: 260ms;
  --fade-ease: cubic-bezier(.2,.8,.2,1);
}

html,body{height:100%;margin:0;overflow:hidden;background:#fff;color:#111827;font-family:var(--ui-font)}
p{font-weight:400;}
#app{position:fixed;inset:0;opacity:0;transition:opacity .6s ease;}
#app.is-ready{opacity:1}

/* PRELOADER */
.pre{position:fixed;inset:0;z-index:999999;background:#000}
.pre video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.pre svg{position:absolute;inset:0;width:100%;height:100%;display:block;pointer-events:none;z-index:1}
.pre.is-done{opacity:0;visibility:hidden;transition:opacity .6s,visibility .6s}

/* TOP: centered logo */
.topbar-center{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:7;pointer-events:none}
#cornerLogo{width:120px;filter:drop-shadow(0 8px 24px rgba(0,0,0,.35));opacity:1;transform:translateY(-6px); 
    margin-top: 15px; transition:opacity .45s,transform .45s;pointer-events:none}
#cornerLogo.is-in{opacity:1;transform:none}

/* Burger (top-left) */
.topbar-left{position:fixed;top:14px;left:14px;display:flex;align-items:center;gap:14px;z-index:7}
.burger-btn{
  width:44px;height:44px;border:1px solid #000;background:transparent;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;outline:none;
  transition:transform .12s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}
.burger-btn:hover{
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  transform:translateY(-1px);
  background:#df061b;
  border-color:#df061b;
}
.burger-btn:active{transform:scale(.98)}
.burger-btn:hover .burger-icon span{ background:#fff; }
.burger-icon{width:22px;height:16px;position:relative}
.burger-icon span{position:absolute;left:0;right:0;height:2px;background:#000;border-radius:2px}
.burger-icon span:nth-child(1){top:0}.burger-icon span:nth-child(2){top:7px}.burger-icon span:nth-child(3){top:14px}
.burger-icon{cursor:pointer;}

/* TOP RIGHT: Branches */
.topbar-right{position:fixed; top:14px; right:14px; z-index:7}
.branches-btn{
  appearance:none; display:inline-flex; align-items:center; justify-content:center;
  height:44px; padding:0 14px;
  background:transparent; border:1px solid #000; border-radius:0;
  color:#000; text-transform:uppercase; letter-spacing:.04em;
  font:700 12px/1 var(--ui-font);
  cursor:pointer; transition:transform .12s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}
.branches-btn:hover{
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  transform:translateY(-1px);
  background:#df061b;
  color:#fff;
  border-color:#df061b;
}
.branches-btn:active{
  transform:translateY(0);
  box-shadow:none;
}

/* Hide vertical note & contact */
.vert-note{display:none!important}
.contact{display:none!important}

/* Bottom centered newsletter link */
.right-corner{
  position:fixed;bottom:1%;left:50%;
  transform:translateX(-50%);
  color:#000;font:12px/1.3 var(--ui-font);
  z-index:6;text-transform:uppercase;padding:8px 12px;
}
.right-corner a{color:#000;text-decoration:none}

/* BRAND LIGHTBOX */
.lb{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;z-index:9}
.lb.is-visible{opacity:1;pointer-events:auto}
.lb-back{position:absolute;inset:0;background:rgba(0,0,0,.38);backdrop-filter:blur(5px) saturate(110%)}
.lb-card{position:relative;max-width:min(560px,86vw);margin:24px;padding:50px 30px 25px;background:#fff;border:1px solid rgba(17,24,39,.16);border-radius:16px;box-shadow:0 28px 80px rgba(0,0,0,.30), 0 6px 20px rgba(0,0,0,.12);color:#000}
.lb-close{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:999px;border:1px solid rgba(17,24,39,.12);background:#fff;cursor:pointer}
.lb-btn{background:transparent;width:100%;padding:10px;text-transform:uppercase;border:1px solid #000;cursor:pointer;transition:.2s}
.lb-btn:hover{background:#000;color:#fff}
#lbDesc{font:300 14px/1.4 var(--ui-font);padding-bottom:15px}
#lbTitle{text-transform:uppercase;font:700 18px/1.2 var(--ui-font);color:#000}
[inert]{pointer-events:none;} [inert] *{pointer-events:none}

/* NEWSLETTER */
.nl{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;z-index:10}
.nl.is-visible{opacity:1;pointer-events:auto}
.nl-back{position:absolute;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(6px) saturate(115%)}
.nl-card{position:relative;max-width:min(420px,86vw);width:100%;margin:24px;padding:30px;background:#fff;border:1px solid rgba(17,24,39,.16);border-radius:5px;box-shadow:0 28px 80px rgba(0,0,0,.30), 0 6px 20px rgba(0,0,0,.12);color:#000;font-family:var(--ui-font)}
.nl-close{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:999px;border:none;background:#fff;cursor:pointer;font-size:1em}
.nl-title{margin:0 30px 8px 0;font:400 18px/1.2 var(--ui-font);text-transform:uppercase}
.nl-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.nl-field label{display:none;font:700 12px/1.2 var(--ui-font);letter-spacing:.02em;opacity:.8;color:#000;padding-top:15px}
.nl-field input[type="email"]{width:100%;border:none;border-bottom:1px solid #000;border-radius:0;background:transparent;color:#000;padding:12px 0;font:14px/1.3 var(--ui-font)}
.nl-field input[type="email"]:focus-visible {
    outline: none;
}
.nl-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;margin-top:8px}
.nl-btn{appearance:none;padding:10px 14px;cursor:pointer;font:12px/1 var(--ui-font);text-transform:uppercase;letter-spacing:.04em;width:100%;border-radius:0;background:transparent;color:#000;border:1px solid #000}
.nl-hint{margin:8px 0 0 0;font:12px/1.3 var(--ui-font);color:#0b5;min-height:1.3em}

/* MENU (unchanged core styles) */
.menu{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;z-index:11}
.menu.is-visible{opacity:1;pointer-events:auto}
.menu-back{position:absolute;inset:0;background:rgba(0,0,0,.50);backdrop-filter:blur(7px) saturate(115%)}
.menu-card{
  position:relative;width:min(900px,92vw);margin:24px;padding:24px;background:#fff;border:1px solid rgba(17,24,39,.16);border-radius:5px;box-shadow:0 28px 80px rgba(0,0,0,.30), 0 6px 20px rgba(0,0,0,.12);color:#000;
  display:grid;grid-template-rows:auto 1fr;gap:16px;min-height:480px;max-height:480px;overflow:hidden;
  font-family:var(--ui-font);
}
.menu-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:999px;border:none;background:#fff;cursor:pointer;font-size:1em}
.menu-title{position:absolute;left:-9999px}
.menu-tabs{border-bottom:1px solid rgba(0,0,0,1);padding-bottom:8px}
.menu-list{display:flex;gap:18px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.menu-list a{display:block;padding:6px 0;text-decoration:none;color:#000;font:700 14px/1.2 var(--ui-font);text-transform:uppercase;letter-spacing:.02em;border-bottom:0}
.menu-list a.is-active{font-weight:800}
.menu-list a,
.menu-sub a,
.burger-btn,
.branches-btn,
.carousel-arrow,
.dlg-arrow,
#bottomCTAs button{ cursor:pointer; }
.menu-sub{display:flex;gap:18px;list-style:none;margin:8px 0 0 0;padding:0;flex-wrap:wrap}
.menu-sub a{display:block;padding:6px 0;text-decoration:none;color:#000;font:500 13px/1.2 var(--ui-font);text-transform:uppercase;letter-spacing:.02em;border-bottom:0}
.menu-sub a.is-active{font-weight:700}

/* Team buttons like branches */
.team-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  padding:12px 14px;
  border:1px solid #000;
  border-radius:0;
  text-transform:uppercase;
  letter-spacing:.06em;
  font:700 12px/1 var(--ui-font);
  background:transparent;
  color:#000;
  text-decoration:none;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}
.team-btn:hover{
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  transform:translateY(-1px);
  background:#df061b;
  color:#fff;
  border-color:#df061b;
}
.team-btn:active{
  transform:translateY(0);
  box-shadow:none;
}
.team-btn-inline{
  width:auto;
  min-width:0;
  padding:10px 14px;
}
.menu-split{display:grid;grid-template-columns:1.1fr 1fr;gap:16px;min-height:0}
.menu-prev-text,.menu-prev-media{ position:relative; }
.menu-prev-text{font:400 14px/1.5 var(--ui-font);max-height:440px;overflow:auto;padding-right:30px; }
.menu-prev-media{min-height:0;display:flex;align-items:start;justify-content:center;height:350px;overflow:hidden}
.menu-prev-media img{width:100%;height:100%;object-fit:contain;display:block;opacity:1;transition:opacity var(--fade-ms) var(--fade-ease);}
.is-swapping .menu-prev-text{animation:fadeSwap var(--fade-ms) var(--fade-ease);}
.is-swapping .menu-prev-media img{opacity:0;}
@keyframes fadeSwap{ 0%{opacity:0; transform:translateY(6px)} 100%{opacity:1; transform:translateY(0)} }

/* ======================= BRANCHES — ACCORDION ======================= */
.branches{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;z-index:12}
.branches.is-visible{opacity:1;pointer-events:auto}
.branches-back{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(9px) saturate(120%)}
.branches-card{
  position: relative;width: min(900px, 92vw);margin: 24px;padding: 30px;background: #fff;
  border: 1px solid rgba(17,24,39,.16);border-radius: 5px;box-shadow: 0 36px 100px rgba(0,0,0,.40);
  color: #000;max-height: 86vh;display: flex;flex-direction: column;overflow: hidden;
  font-family:var(--ui-font);
}
.branches-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:999px;border:none;background:#fff;cursor:pointer;font-size:1em}
.branches-title{margin:0 40px 18px 0;font:400 22px/1.2 var(--ui-font);text-transform:uppercase;flex:0 0 auto}
.branches-table-wrap{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;padding-right:4px}
.acc-item{border:none;padding:10px 0}
.acc-item + .acc-item{border-top:1px dashed rgba(17,24,39,.15)}
.acc-head{appearance:none;width:100%;display:flex;align-items:center;gap:16px;background:transparent;border:none;cursor:pointer;text-align:left;padding:8px 0}
.acc-head .acc-brand{text-transform:uppercase;font-weight:400;font-size:1em;line-height:1.2;letter-spacing:.02em;flex:1 1 auto}
.acc-head .acc-icon{flex:0 0 auto;width:16px;height:16px;display:inline-block;position:relative;transform:rotate(0deg);transition:transform .2s ease}
.acc-head .acc-icon::before,.acc-head .acc-icon::after{content:"";position:absolute;left:0;top:50%;width:100%;height:2px;background:#000;transform:translateY(-50%)}
.acc-head .acc-icon::after{transform:translateY(-50%) rotate(90deg)}
.acc-item.is-open .acc-head .acc-icon{transform:rotate(45deg)}
.acc-panel{overflow:hidden;max-height:0;transition:max-height .28s ease}
.acc-item.is-open .acc-panel{max-height:800px}
.acc-grid{
  display:grid;
  grid-template-columns:26% 30% 44%;
  gap:14px 24px;
  align-items:start;
  padding:6px 0 14px 0;
}
.acc-grid.acc-grid-compact{ grid-template-columns:26% 44% 30%; }
.acc-grid.acc-grid-2col{ grid-template-columns:45% 50%; }
.acc-left{ text-align:left; }
.acc-right{ text-align:right; }
.acc-grid .col-brand{text-transform:uppercase;font-weight:400;font-size:1em;line-height:1.2;letter-spacing:.02em}
.acc-col-stack{display:flex;flex-direction:column;gap:8px;font-size:12px}
.acc-label{font-size:13px;text-transform:uppercase}
.acc-grid a{color:#000;text-decoration:none}
.acc-grid a:hover,.acc-grid a:focus{text-decoration:none}

/* custom cursor */
#app canvas{cursor:auto; position: fixed; top:0; left:0;}
.custom-cursor{
  position:fixed;left:0;top:0;width:36px;height:auto;
  transform:translate(-50%,-50%) scale(1);
  pointer-events:none;z-index:999999;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.35));
  opacity:0;transition:opacity .15s,transform .08s
}
.custom-cursor.is-on{opacity:.95}
.custom-cursor.is-down{transform:translate(-50%,-50%) scale(.9)}
.custom-cursor.is-hidden{opacity:0}
@media (hover:none),(pointer:coarse){ .custom-cursor{display:none} }

/* fancy card anim */
@keyframes pop-in{ 0%{transform:scale(.94) translateY(10px);opacity:0;filter:blur(2px)}
  60%{transform:scale(1.02) translateY(0);opacity:1;filter:blur(0)}
  100%{transform:scale(1) translateY(0);opacity:1;filter:blur(0)} }
@keyframes pop-out{ 0%{transform:scale(1) translateY(0);opacity:1;filter:0}
  100%{transform:scale(.98) translateY(6px);opacity:0;filter:blur(1px)} }
.pop-card{transform:scale(.94) translateY(10px);opacity:0;will-change:transform,opacity,filter}
.lb.is-visible   .pop-card,
.menu.is-visible .pop-card,
.nl.is-visible   .pop-card,
.branches.is-visible .pop-card{animation:pop-in .42s cubic-bezier(.2,.8,.2,1) forwards}
.lb:not(.is-visible)   .pop-card,
.menu:not(.is-visible) .pop-card,
.nl:not(.is-visible)   .pop-card,
.branches:not(.is-visible) .pop-card{animation:pop-out .18s ease forwards}

/* insurance: menu text always visible black */
.menu-card, .menu-card *{ color:#000; }
.menu-list a{ color:#000; text-decoration:none; }
.menu-list a:hover{ text-decoration:none; }


/* ===== 3D Carousel UI ===== */
.carousel-ui{
  position: fixed;
  left: 0; right: 0;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 9999;
  display: flex;
  justify-content: space-between;
  padding: 0 24px;
}
.carousel-arrow{
  pointer-events: auto;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: none;
  background: transparent;
  font-size: 34px;
  line-height: 1;
  display: grid;
  place-items: center;
  cursor: pointer;
}
.carousel-arrow:active{ transform: scale(0.98); }
@media (max-width: 700px){
  .carousel-ui{ padding: 0 14px; }
  .carousel-arrow{ width: 46px; height: 46px; font-size: 30px; }
}

/* Mobile adjustments */
@media (max-width: 900px){
  .menu-split{ grid-template-columns:1fr !important; }
  .menu-prev-media{ display:none !important; }
  .menu-prev-text{ padding-right:0; }
}
@media (max-width: 700px){
  .acc-grid.acc-grid-2col{ grid-template-columns:1fr; }
  .acc-right{ text-align:left; }
  .acc-contact-row{ justify-content:flex-start !important; }
  .branches-btn{ width:100%; justify-content:center; }
}
@media (max-width: 640px){
  #modelLabel{
    top:8% !important;
    transform:translate(-50%, 0px) !important;
    font-size:clamp(16px, 4vw, 24px) !important;
  }
  .carousel-arrow{ width:42px; height:42px; }
}

/* Fallback when backdrop-filter is unsupported */
@supports not (backdrop-filter: blur(2px)){
  .lb-back{background:rgba(0,0,0,.65);}
  .menu-back{background:rgba(0,0,0,.65);}
  .branches-back{background:rgba(0,0,0,.70);}
  .nl-back{background:rgba(0,0,0,.70);}
}

/* Hide floating UI when a dialog/lightbox is open */
body.dialog-open .carousel-arrow,
body.dialog-open #modelLabel,
body.dialog-open #spotifyCorner,
body.dialog-open #bottomCTAs{
  display:none!important;
}
