:root{
  --bg:#0b1a2a; --ink:#fff; --muted:#7f8ea3;
  --gold:#E7C978; --gold-strong:#F2D889;
  --surface:#0e1d2e; --frame:rgba(255,255,255,.08); --frame2:rgba(255,255,255,.14);
  --halo:rgba(255,255,255,.22);
  --glass-blur:34px; --glass-sat:170%; --glass-bright:1.06;
  --radius:16px; --inner-radius:12px; --max:1120px;
  --shadow:0 30px 90px rgba(0,0,0,.6);

  /* Open/Closed accents (match Project Discovery exactly) */
  --open-glass: rgba(32,168,106,.16);
  --open-border: rgba(32,168,106,.45);
  --open-glow: 0 20px 60px rgba(32,168,106,.22);
  --closed-glass: rgba(242,155,119,.16);
  --closed-border: rgba(242,155,119,.45);
  --closed-glow: 0 20px 60px rgba(242,155,119,.22);
}

/* Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;
  font-weight:300;-webkit-font-smoothing:antialiased;
  background:var(--bg);color:var(--ink);padding-top:84px;
}
h1,h2,h3{font-weight:900;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
.muted-strong{color:var(--muted);font-weight:900}

/* ======================================
   ReModa™ — Global Trademark Control
   NORMALIZED across all contexts
   ====================================== */

/* Kill browser defaults */
sup.tm {
  font-size: inherit;
  vertical-align: baseline;
}

/* Our controlled trademark */
.tm {
  font-weight: 300;
  font-size: 0.55em;      /* FIXED ratio everywhere */
  line-height: 1;
  vertical-align: super;
  margin-left: 1px;
  opacity: 0.75;
}

/* Topbar */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  backdrop-filter:saturate(140%) blur(10px);
  background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.15));
  border-bottom:1px solid rgba(255,255,255,.05);
}
.topbar-inner{
  height:84px;max-width:var(--max);margin:0 auto;padding:10px 16px;
  display:flex;align-items:center;justify-content:space-between;
}
.brand-icon{height:64px;width:64px;border-radius:10px;object-fit:cover}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);
  color:#fff;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:700;transition:all .25s ease;
}
.chip:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.35)}
.topbar::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:
    radial-gradient(140% 240% at 50% 100%, var(--gold-strong) 0%, rgba(242,216,137,.65) 35%, transparent 70%),
    linear-gradient(90deg, transparent 0%, rgba(231,201,120,.65) 50%, transparent 100%);
  box-shadow:0 0 10px rgba(242,216,137,.45), 0 0 22px rgba(242,216,137,.22);
  -webkit-mask-image: radial-gradient(900px 120px at 50% 100%, black 45%, transparent 100%);
          mask-image: radial-gradient(900px 120px at 50% 100%, black 45%, transparent 100%);
}

/* Hero */
.logo-top{max-width:var(--max);margin:10px auto 0;display:flex;justify-content:center}
.logo-top img{height:200px;width:auto}
.hero{text-align:center;padding:24px 20px 16px}
.hero h1{margin:0;font-size:clamp(32px,5vw,56px);line-height:1.05}
.hero p{margin:6px 0 0;color:var(--muted);font-size:clamp(14px,2vw,18px)}

/* Intro */
.intro{max-width:var(--max);margin:0 auto;padding:0 20px 36px;color:var(--muted);text-align:center}
.intro p{margin:0;font-size:clamp(14px,2.3vw,18px);line-height:1.6}
.glow-line{margin:12px auto 0;width:min(220px,38%);height:2px;border-radius:2px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  filter:blur(.4px);}

/* Grid / Cards */
.wrap{max-width:var(--max);margin:0 auto;padding:20px}
.grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid{grid-template-columns:1fr}}

.card{
  position:relative;overflow:hidden;border-radius:var(--radius);
  background:var(--surface);box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.06);
  backdrop-filter:blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright));
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright));
  transition:transform .35s ease,box-shadow .35s ease,filter .35s ease;
  display:flex;flex-direction:column;animation:floaty 7s ease-in-out infinite alternate;
}
@keyframes floaty{from{transform:translateY(-2px)}to{transform:translateY(4px)}}
.card:hover{transform:translateY(-10px);filter:saturate(108%)}
.card-media{position:relative;height:170px;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;filter:contrast(1.02) saturate(112%)}
.card:hover .card-media img{transform:scale(1.07)}
.card-media::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(to top, rgba(0,0,0,0) 60%, rgba(0,0,0,.6)),
    linear-gradient(to bottom, rgba(0,0,0,0) 68%, rgba(0,0,0,.75));
}
.card-body{padding:18px}
.card-title{font-weight:900;font-size:20px;margin:0 0 6px}
.card-desc{color:var(--muted);margin:0;font-size:15px}
.crystal{
  position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background:
    linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,0)40%),
    linear-gradient(315deg,rgba(255,255,255,.06),rgba(255,255,255,0)50%);
  mix-blend-mode:screen;opacity:.35;
}

/* ===== HARD OVERRIDE: disable any card animations (no floaty) ===== */
.card {
  animation: none !important;
}

/* Unique Design + Build (span-2) */
.design-build{grid-column:span 2;display:flex;flex-direction:column;padding:0;overflow:hidden}
.split-panels{display:grid;grid-template-columns:1fr 1fr;position:relative}
.split-panels::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:rgba(255,255,255,.12)}
.panel{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;min-height:340px;transition:transform .4s ease, filter .4s ease;perspective:600px}
.panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.85) contrast(1.02) saturate(115%);transition:transform .6s cubic-bezier(.2,.8,.2,1), filter .6s ease;transform:translateZ(0)}
.panel:hover img{transform:scale(1.06) translateZ(10px);filter:brightness(1) saturate(120%)}
.panel-content{position:relative;z-index:2;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.68) 90%);padding:30px 24px 26px;backdrop-filter:blur(6px) saturate(140%)}
.panel-title{font-size:clamp(22px,2.8vw,28px);font-weight:800;margin:0 0 4px}
.panel-title::after{content:"";display:block;height:2px;margin-top:8px;border-radius:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.8}
.panel-desc{font-size:15px;color:#fff;margin:8px 0 14px}
.panel-link{display:inline-block;padding:10px 18px;border-radius:999px;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.22);color:#fff;font-weight:800;text-decoration:none;font-size:14px;transition:transform .2s ease, border-color .2s ease, background .2s ease}
.panel-link:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.14)}
@media(max-width:840px){.design-build{grid-column:span 1}.split-panels{grid-template-columns:1fr}.split-panels::before{display:none}}

/* Expander controls for standard cards */
.expander-row{display:flex;justify-content:flex-end;align-items:center;padding:8px 12px 0 12px}
.expander-toggle{height:36px;width:36px;border-radius:12px;background:rgba(255,255,255,.10);border:1.5px solid rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(6px);transition:transform .2s ease, background .2s ease, border-color .2s ease}
.expander-toggle:hover{transform:translateY(-1px);background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.35)}
.chev{width:14px;height:14px;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(45deg);opacity:.9;transition:transform .25s ease}
.card.open .chev{transform:rotate(-135deg)}
.expander{position:absolute;left:12px;right:12px;bottom:12px;z-index:2;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:10px;display:flex;gap:8px;flex-wrap:wrap;transform:translateY(12px);opacity:0;pointer-events:none;backdrop-filter:blur(10px) saturate(140%);box-shadow:0 6px 30px rgba(0,0,0,.35),0 0 16px rgba(255,255,255,.08);transition:opacity .25s ease,transform .25s ease}
.card.open .expander{opacity:1;transform:none;pointer-events:auto}
.chip-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.10);border:1.5px solid rgba(255,255,255,.22);color:#fff;text-decoration:none;font-weight:700;font-size:14px;transition:transform .2s ease,border-color .2s ease,background .2s ease}
.chip-chip:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.14)}

/* Footer (uniform with Project Discovery) */
footer{margin:18px 0 28px;text-align:center;color:var(--muted);font-size:13px}
footer .gold-line{width:60%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:0 auto 10px;border-radius:2px}
footer .built{margin-top:6px;font-size:12px}
footer .built .brand{color:#fff;font-weight:900}
footer .built .dev{color:var(--muted);font-weight:900}
footer .built .small-muted{color:var(--muted)}





/* ------- Connect modal & Visit modal (styling stays) ------- */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:18px;z-index:2000;background:rgba(0,0,0,.55)}
.modal[open]{display:flex}
.modal-card{
  max-width:860px;width:100%;max-height:86vh;display:flex;flex-direction:column;
  background:var(--surface);color:var(--ink);
  border:1px solid rgba(255,255,255,.14);border-radius:16px;box-shadow:var(--shadow);
  backdrop-filter:blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright));
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright));
  overflow:hidden;
}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.12)}
.modal-title{font-weight:900;margin:0}
.modal-close{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);color:#fff;border-radius:10px;padding:8px 10px;font-weight:800;cursor:pointer}
.modal-body{padding:14px 16px;color:var(--muted);line-height:1.6;overflow:auto}
.modal-body h4{color:#fff;margin:12px 0 6px}

/* Connect list + ghost links */
.connect-list{display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.10);border-radius:16px;overflow:hidden;background:rgba(255,255,255,.04)}
.connect-row{display:flex;align-items:center;gap:12px;padding:10px 12px;transition:background .15s ease}
.connect-row:hover{background:rgba(255,255,255,.06)}
.connect-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}
.connect-icon{width:18px;height:18px;opacity:.9;flex:0 0 18px}
.connect-main{display:flex;flex-direction:column;gap:1px}
.connect-title{color:#fff;font-weight:800;font-size:13.5px;letter-spacing:.01em}
.connect-sub{color:var(--muted);font-size:12px}
.connect-cta{margin-left:auto;display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.link-ghost{
  display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:10px;
  border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);
  font-weight:800;font-size:12px;
}
.link-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22)}
.icon-12{width:12px;height:12px;opacity:.9}

/* Open/Closed badge + card glass */
.oc-badge{
  display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);
  font-size:12px;font-weight:800;white-space:nowrap
}
.oc-dot{width:7px;height:7px;border-radius:50%}
.oc-open .oc-dot{background:#6fe7b7;box-shadow:0 0 8px rgba(111,231,183,.6)}
.oc-closed .oc-dot{background:#f29b77;box-shadow:0 0 8px rgba(242,155,119,.6)}
.oc-open{color:#eafff7}
.oc-closed{color:#ffece6}
.card-open{background:var(--open-glass)!important;border-color:var(--open-border)!important;box-shadow:var(--open-glow)!important}
.card-closed{background:var(--closed-glass)!important;border-color:var(--closed-border)!important;box-shadow:var(--closed-glow)!important}

/* Small form fields for Plan a Visit */
.cols-2{grid-template-columns:1fr 1fr}
.field{display:flex;flex-direction:column;gap:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:10px 12px}
label{font-size:13px;color:#cfe0ff}
input,textarea{width:100%;border:none;outline:none;background:transparent;color:#fff;font-size:15px}
textarea{min-height:110px;resize:vertical}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 14px;border-radius:12px;font-weight:800;cursor:pointer;
  border:none;background:#fff;color:#0b1a2a;box-shadow:0 6px 20px rgba(0,0,0,.25);
  transition:transform .15s ease;text-decoration:none;
}
.btn:hover{transform:translateY(-1px)}
.btn.outline{
  background:rgba(255,255,255,.10);color:#fff;border:1.5px solid rgba(255,255,255,.22);box-shadow:none;
}
.pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#fff;font-weight:800;font-size:12px}
.brand-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:28px;border-radius:9px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);
}
.brandmark{width:16px;height:16px;opacity:.55}
.copy-pill{color:#eaeef7;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:10px;font-weight:800;font-size:12px}

/* -------- Added: full-span feature cards -------- */
.span-3{grid-column:1/-1}
.strip{
  display:flex;gap:12px;overflow-x:auto;padding:12px;scroll-snap-type:x mandatory;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:12px
}
.strip::-webkit-scrollbar{height:8px}
.strip::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:8px}
.strip-item{flex:0 0 62%;height:220px;position:relative;border-radius:12px;overflow:hidden;scroll-snap-align:center}
@media(max-width:840px){.strip-item{flex-basis:86%}}
.strip-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(112%)}

/* Before/After slider */
.ba-wrap{position:relative;height:320px;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.10)}
.ba-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(255,255,255,.85);
  box-shadow:0 0 0 1px rgba(0,0,0,.4);cursor:ew-resize
}
.ba-knob{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25)
}
.ba-knob svg{width:18px;height:18px}

/* Back to top */
#backTop{
  position:fixed;right:18px;bottom:18px;z-index:1400;opacity:0;pointer-events:none;
  display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(8px);transition:opacity .2s ease, transform .2s ease;
}
#backTop.show{opacity:1;pointer-events:auto}
#backTop:hover{transform:translateY(-2px);background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.35)}
#backTop svg{width:18px;height:18px;color:#fff}

@media(max-width:840px){
  .design-build{grid-column:span 1}
  .split-panels{grid-template-columns:1fr}
  .split-panels::before{display:none}
}
@media(max-width:980px){
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .grid{grid-template-columns:1fr}
}
/* ===== Studio modal & admin panel ===== */
.studio-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.studio-header-row h4 {
  margin: 0;
  color: #fff;
}

.studio-admin-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}
.studio-admin-trigger span {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
}

.studio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 12px;
}

.studio-item {
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.studio-item-thumb {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  height: 120px;
}
.studio-item-thumb img,
.studio-item-thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.studio-item-type {
  position: absolute;
  right: 8px;
  top: 8px;
  font-size: 10px;
  font-weight: 800;
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(0,0,0,.6);
  border: 1px solid rgba(255,255,255,.24);
}

.studio-item-title {
  font-size: 13px;
  font-weight: 800;
}
.studio-item-note {
  font-size: 12px;
  color: var(--muted);
}

.studio-item-actions {
  margin-top: 4px;
  display: flex;
  justify-content: flex-end;
}
.studio-remove-btn {
  border: none;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  background: rgba(255,255,255,.12);
  color: #fff;
}

.studio-admin-panel {
  margin-top: 4px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.02);
  display: none;
  flex-direction: column;
  gap: 8px;
}
.studio-admin-panel.active {
  display: flex;
}

.studio-admin-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 6px;
}
@media (min-width: 720px) {
  .studio-admin-row {
    grid-template-columns: 130px minmax(0, 1fr);
  }
}
.studio-admin-row input,
.studio-admin-row textarea,
.studio-admin-row select {
  font-size: 13px;
}

.studio-admin-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}
.studio-admin-actions .hint {
  font-size: 11px;
  color: var(--muted);
}
.studio-admin-actions .btn-small {
  border-radius: 10px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 800;
  border: none;
  background: #fff;
  color: #0b1a2a;
  cursor: pointer;
}
/* ===== Studio: live feel, separator, spacing, lightbox ===== */

/* live badge near Studio title */
.studio-live-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.studio-live-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(111,231,183,.4);
  background: rgba(8, 40, 24, 0.8);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #eafff7;
}
.studio-live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #6fe7b7;
  box-shadow: 0 0 8px rgba(111,231,183,.9);
  animation: studio-pulse 1.4s ease-in-out infinite;
}
@keyframes studio-pulse {
  0% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.4); opacity: .7; }
  100% { transform: scale(1); opacity: 1; }
}

/* extra spacing between Open Studio button and text */
.card.span-3 .card-body .card-desc {
  margin-bottom: 8px;
}
.card.span-3 .card-body .chip-chip#openStudio {
  margin-top: 6px;
}

/* gold separator strip under Studio card */
.studio-separator {
  grid-column: 1 / -1;
  height: 1px;
  margin: 10px 4px 4px;
  border-radius: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--gold),
    transparent
  );
  opacity: 0.9;
  filter: blur(.1px);
}

/* gentle motion for strip items */
.strip-item {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  scroll-snap-align: center;
  animation: strip-drift 16s ease-in-out infinite alternate;
}
.strip-item:nth-child(2) { animation-delay: 2s; }
.strip-item:nth-child(3) { animation-delay: 4s; }
.strip-item:nth-child(4) { animation-delay: 6s; }
.strip-item:nth-child(5) { animation-delay: 8s; }

@keyframes strip-drift {
  0% { transform: translateY(0px) scale(1); }
  50% { transform: translateY(-4px) scale(1.01); }
  100% { transform: translateY(0px) scale(1); }
}

/* Lightbox for enlarged studio image/video (reuses modal layout but full bleed media) */
.studio-lightbox-media {
  max-height: 70vh;
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 10px;
}
.studio-lightbox-media img,
.studio-lightbox-media video {
  width: 100%;
  height: 100%;
  max-height: 70vh;
  object-fit: cover;
}

/* title/note in lightbox */
.studio-lightbox-title {
  font-size: 14px;
  font-weight: 800;
  margin-bottom: 4px;
}
.studio-lightbox-note {
  font-size: 13px;
  color: var(--muted);
}

/* ===== Before/After slider: multi-slide nav ===== */

.ba-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 8px;
  font-size: 11px;
  color: var(--muted);
}
.ba-nav-left {
  display: flex;
  align-items: center;
  gap: 6px;
}
.ba-nav-buttons {
  display: inline-flex;
  gap: 6px;
}
.ba-nav-btn {
  border-radius: 999px;
  width: 26px;
  height: 26px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.06);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.ba-nav-btn svg {
  width: 14px;
  height: 14px;
}

/* slide index dots */
.ba-dots {
  display: inline-flex;
  gap: 4px;
}
.ba-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.22);
}
.ba-dot.active {
  background: var(--gold);
}

/* multiple BA slides layering */
.ba-slides {
  position: relative;
  height: 320px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
}
.ba-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.ba-slide.active {
  opacity: 1;
  pointer-events: auto;
}
/* Slight motion for studio items (reuse strip drift) */
.studio-item {
  animation: strip-drift 22s ease-in-out infinite alternate;
}
.studio-item:nth-child(2) { animation-delay: 2s; }
.studio-item:nth-child(3) { animation-delay: 4s; }
.studio-item:nth-child(4) { animation-delay: 6s; }

/* ===== Connect modal – social icons row ===== */
.connect-social-row {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.connect-social-label {
  font-size: 12px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.connect-social-icons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.social-icon-badge {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.06);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  cursor: pointer;
}
.social-icon-badge:hover {
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.32);
}
.social-icon-badge svg {
  width: 14px;
  height: 14px;
  opacity: .9;
}


/* ===== Studio Highlights marquee (hub strip) — big & smooth CSS-only ===== */

.card.span-3[aria-label="Studio Highlights"] .strip {
  overflow: hidden;
  padding: 14px 0 24px;
}

/* MOVING TRACK – driven purely by CSS now */
.card.span-3[aria-label="Studio Highlights"] .strip-track {
  display: inline-flex;
  gap: 26px;
  will-change: transform;
  animation: studio-marquee 10s linear infinite; /* speed: adjust here if needed */
}

/* Pause motion while user hovers / presses */
.card.span-3[aria-label="Studio Highlights"] .strip:hover .strip-track {
  animation-play-state: paused;
}

/* LARGE hero panels */
.card.span-3[aria-label="Studio Highlights"] .strip-item {
  flex: 0 0 135%;
  max-width: 135%;
  height: 360px;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 8px 26px rgba(0,0,0,.25);
}
.card.span-3[aria-label="Studio Highlights"] .strip-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* DESKTOP – show more context, still big */
@media (min-width: 900px) {
  .card.span-3[aria-label="Studio Highlights"] .strip-item {
    flex: 0 0 85%;
    max-width: 85%;
    height: 420px;
  }
}

/* Continuous scrolling loop.
   We duplicate items in JS, so -50% = one full set. */
@keyframes studio-marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ===== HARD OVERRIDE: Studio Highlights strip – no animation, swipe only ===== */

/* Strip container: horizontal scroll/swipe */
.card.span-3[aria-label="Studio Highlights"] .strip {
  overflow-x: auto;
  overflow-y: hidden;
  padding: 14px 0 24px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

/* Track: just a flex row, NO animation */
.card.span-3[aria-label="Studio Highlights"] .strip-track {
  display: inline-flex;
  gap: 18px;
  min-width: 100%;
  animation: none !important;
  transform: translateX(0) !important;
}

/* Big hero panels, swipeable */
.card.span-3[aria-label="Studio Highlights"] .strip-item {
  flex: 0 0 85%;
  max-width: 85%;
  height: 340px;
  border-radius: 20px;
  overflow: hidden;
  scroll-snap-align: center;
  box-shadow: 0 8px 26px rgba(0,0,0,.25);
}
.card.span-3[aria-label="Studio Highlights"] .strip-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Phones: slightly narrower, shorter */
@media (max-width: 768px) {
  .card.span-3[aria-label="Studio Highlights"] .strip-item {
    flex: 0 0 92%;
    max-width: 92%;
    height: 300px;
  }
}

/* Desktops: a bit wider and taller */
@media (min-width: 1024px) {
  .card.span-3[aria-label="Studio Highlights"] .strip-item {
    flex: 0 0 70%;
    max-width: 70%;
    height: 380px;
  }
}


/* ===============================
   ReModa Outdoors — CLEAN BASE
   =============================== */

.card.outdoors {
  background-color: #2A5D34;
  border-color: rgba(42,93,52,.9);
  box-shadow:
    0 30px 90px rgba(0,0,0,.6),
    0 0 0 1px rgba(42,93,52,.45);
  position: relative;
}

/* Inner subtle frame */
.card.outdoors::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: var(--inner-radius);
  pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}

/* Text styling */
.card.outdoors .card-title,
.card.outdoors .card-desc,
.card.outdoors a {
  color: #ffffff !important;
}

/* Muted Outdoors word */
.card.outdoors .muted-strong {
  color: rgba(235,245,238,.9);
}



/* Gold divider */
.card.outdoors .card-title::after {
  content: "";
  display: block;
  height: 2px;
  margin-top: 8px;
  border-radius: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--gold),
    transparent
  );
}

/* CTA spacing */
.card.outdoors .card-desc {
  margin-bottom: 26px;
}

/* Disable expander UI for Outdoors only */
.card.outdoors .expander,
.card.outdoors .expander-toggle {
  display: none !important;
}

/* Division label — top-right INSIDE green area */
.card.outdoors .outdoors-division-label {
  position: absolute;
  top: 14px;
  right: 16px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(231, 201, 120, 0.9);
  pointer-events: none;
}

.card.outdoors .card-body {
  position: relative;
}

