:root{
  /* Sunlit Coastal (light) */
  --mx-bg:#F6FAFF;
  --mx-surface:#FFFFFF;
  --mx-surface2:#EEF6FF;
  --mx-text:#0B1B2B;
  --mx-muted:#445A74;
  --mx-border:#D8E6F5;
  --mx-accent:#16BFD0;
  --mx-accent2:#FFB46A;
  --mx-highlight:#D7F4F6;

  --mx-radius:18px;
  --mx-radius2:14px;
  --mx-shadow:0 18px 46px rgba(6,21,33,.10);
  --mx-shadow2:0 10px 28px rgba(6,21,33,.08);

  --mx-maxw:1020px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:radial-gradient(1000px 700px at 15% 0%, rgba(22,191,208,.14), transparent 60%),radial-gradient(900px 650px at 95% 5%, rgba(255,180,106,.18), transparent 60%),var(--mx-bg);color:var(--mx-text);font:16px/1.65 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif}
a{color:#0F5E7A;text-decoration:underline;text-underline-offset:2px;font-weight:600;transition:color .15s ease}
a:hover{color:#0A4C63}

.container{max-width:var(--mx-maxw);margin:0 auto;padding:0 18px}

/* Masthead (Clean Blog-inspired rhythm, translated) */
.mx-masthead{position:sticky;top:0;z-index:50;background:rgba(246,250,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--mx-border)}
.mx-masthead-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px}
.brand{font-weight:900;letter-spacing:.2px;color:var(--mx-text);text-decoration:none}
.brand:hover{text-decoration:none;color:var(--mx-text)}
.nav{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end}
.nav a{color:var(--mx-muted);font-weight:700;text-decoration:none}
.nav a:hover{color:var(--mx-text)}
.nav a.is-active,[aria-current="page"]{color:var(--mx-text);position:relative}
.nav a.is-active:after,[aria-current="page"]:after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;border-radius:2px;background:rgba(22,191,208,.65)}

/* Layout */
main.container{padding:28px 18px 64px}

.page-layout-ai main.container{width:min(1400px, calc(100vw - 36px));max-width:none}

/* Typography (translated editorial rhythm) */
.page h1, main.container > h1{font-size:42px;line-height:1.08;margin:0 0 10px;letter-spacing:-.02em}
.page p, main.container > p{color:var(--mx-muted);max-width:72ch}
.page h2{font-size:24px;line-height:1.2;margin:26px 0 10px;letter-spacing:-.01em}
.page h3{font-size:18px;line-height:1.3;margin:18px 0 8px}
.page ul,.page ol{padding-left:1.25rem}
.page li{margin:8px 0}
.page hr{border:0;border-top:1px solid var(--mx-border);margin:26px 0}
.page blockquote{margin:18px 0;padding:12px 14px;border-left:3px solid rgba(22,191,208,.55);background:rgba(215,244,246,.55);border-radius:0 var(--mx-radius2) var(--mx-radius2) 0}
.page code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;font-size:.95em;background:rgba(6,21,33,.06);padding:2px 6px;border-radius:10px;border:1px solid rgba(6,21,33,.08)}

/* Editorial helpers */
.mx-kicker{display:inline-block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--mx-muted);font-weight:800}
.mx-dek{font-size:18px;line-height:1.55;color:var(--mx-muted);margin:8px 0 0;max-width:70ch}
.mx-divider{height:1px;background:linear-gradient(90deg, rgba(22,191,208,.0), rgba(22,191,208,.35), rgba(255,180,106,.25), rgba(255,180,106,.0));margin:14px 0 0}

/* Hub cards: 2-up default; 1-up on very small phones */
.mx-hub-list{display:grid;grid-template-columns:1fr;gap:18px;margin-top:22px}
@media (min-width:720px){
  .mx-hub-list{grid-template-columns:repeat(2, minmax(0, 1fr))}
}

.mx-hub-card{background:linear-gradient(180deg, rgba(255,255,255,.86), rgba(238,246,255,.82));border:1px solid var(--mx-border);border-radius:var(--mx-radius);padding:18px 18px 20px;box-shadow:var(--mx-shadow2);overflow:visible;transition:transform .16s ease, box-shadow .16s ease, border-color .16s easebackground:linear-gradient(180deg,rgba(255,255,255,.98) 0%,rgba(249,252,255,.95) 26%,rgba(238,246,255,.87) 100%);box-shadow:0 1px 0 rgba(255,255,255,.78) inset,0 10px 28px rgba(6,21,33,.08);}
.mx-hub-card h2{margin:0 0 8px;font-size:19px;line-height:1.25;letter-spacing:-.01em}
.mx-hub-card p{margin:0 0 10px;color:var(--mx-muted)}
.mx-hub-card ul{margin:12px 0 0 18px;color:var(--mx-muted)}
.mx-hub-card li{margin:6px 0}
.mx-hub-card a{font-weight:700}
.mx-hub-card a:hover{text-decoration:underline}
.mx-hub-card h2 a{color:#1489A3;text-decoration:none;font-weight:800;transition:color .15s ease}
.mx-hub-card h2 a:hover{color:#0F5E7A;text-decoration:underline}

.mx-hub-card:hover{border-color:rgba(22,191,208,.45);box-shadow:var(--mx-shadow);transform:translateY(-2px)}

/* Footer */
.footer{border-top:1px solid var(--mx-border);padding:20px 0;color:var(--mx-muted)}

/* Accessibility */
.mx-skip{position:absolute;left:-999px;top:10px;background:var(--mx-surface);color:var(--mx-text);padding:10px 12px;border-radius:12px;border:1px solid var(--mx-border);z-index:10000;box-shadow:var(--mx-shadow2)}
.mx-skip:focus{left:12px}

:focus-visible{outline:3px solid rgba(22,191,208,.55);outline-offset:2px;border-radius:12px}

/* Assistant CTA (subtle callout, not an ad) */
.mx-assistant-cta{margin:26px 0 0;padding:0}
.mx-assistant-cta-inner{background:linear-gradient(180deg, rgba(22,191,208,.10), rgba(255,180,106,.10));border:1px solid rgba(22,191,208,.22);border-radius:var(--mx-radius);padding:14px 14px}
.mx-assistant-cta-inner p{margin:6px 0 10px;color:var(--mx-muted)}
.mx-btn{display:inline-block;padding:10px 12px;border-radius:14px;border:1px solid rgba(22,191,208,.30);background:rgba(22,191,208,.12);color:var(--mx-text);font-weight:900;text-decoration:none}
.mx-btn:hover{background:rgba(255,180,106,.18);border-color:rgba(255,180,106,.35)}

/* Portal (/landing.html) */
.mx-portal-hero{background:linear-gradient(180deg, rgba(22,191,208,.12), rgba(255,180,106,.10));border:1px solid var(--mx-border);border-radius:24px;padding:18px 16px;box-shadow:var(--mx-shadow2)}
.mx-portal-hero h1{margin:4px 0 8px;font-size:44px;line-height:1.06;letter-spacing:-.02em}
.mx-portal-hero .mx-dek{margin-top:6px}
.mx-portal-search{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.mx-search{flex:1;min-width:240px;display:flex;align-items:center;gap:10px;padding:12px 12px;border-radius:16px;border:1px solid var(--mx-border);background:rgba(255,255,255,.80)}
.mx-search--hero{position:relative;z-index:1;margin-top:-28px; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); background: rgba(255,255,255,0.72); box-shadow: 0 14px 30px rgba(0,0,0,0.18);}

.mx-article-surface{
  background:#fff;
  border-radius:14px;
  padding:32px;
  margin-top:40px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}


.mx-chip-label{
  text-align:center;
  font-size:0.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.7;
  margin-bottom:8px;
}

.mx-search--hero{
  margin-top:-60px;
}

@media(min-width:900px){
  .mx-search--hero{
    margin-top:-80px;
  }
}

@media(min-width:1400px){
  .mx-search--hero{
    margin-top:-100px;
  }
}
.mx-chips--hero{justify-content:center;gap:6px;margin-top:6px}
.mx-article-surface .mx-chips--hero{margin-bottom:18px}
.mx-search input{flex:1;border:0;background:transparent;font:inherit;outline:none;color:var(--mx-text)}
.mx-search input::placeholder{color:rgba(68,90,116,.75)}
.mx-search .mx-search-hint{font-size:12px;color:rgba(68,90,116,.75);white-space:nowrap}
.mx-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.mx-chip{display:inline-block;padding:8px 10px;border-radius:999px;border:1px solid rgba(255,180,106,.42);background:rgba(255,180,106,.18);color:#0B3E50;text-decoration:none;font-weight:800;font-size:13px;transition:color .15s ease, background .15s ease, border-color .15s ease}
.mx-chip:hover{background:rgba(255,180,106,.28);border-color:rgba(255,180,106,.50);color:#083444}

.mx-section{margin-top:2px}
.mx-section h2{margin:0 0 10px;font-size:18px;letter-spacing:.02em;text-transform:uppercase;color:var(--mx-muted)}
.mx-section .mx-divider{margin-top:10px}

/* Chat bubble + panel */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.mx-chat-btn{position:fixed;right:16px;bottom:16px;z-index:9999;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:999px;border:1px solid rgba(22,191,208,.25);background:rgba(255,255,255,.85);backdrop-filter:blur(10px);color:var(--mx-text);box-shadow:0 12px 30px rgba(6,21,33,.18);cursor:pointer}
.mx-chat-btn:hover{border-color:rgba(22,191,208,.45)}
.mx-chat-btn-dot{width:10px;height:10px;border-radius:999px;background:rgba(22,191,208,.95);box-shadow:0 0 0 4px rgba(22,191,208,.12)}
.mx-chat-btn-label{font-weight:900;letter-spacing:.2px}

.mx-chat{position:fixed;right:16px;bottom:70px;z-index:9999;width:392px;max-width:calc(100vw - 32px);border:1px solid rgba(6,21,33,.12);border-radius:18px;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);box-shadow:0 16px 44px rgba(6,21,33,.22);overflow:hidden}
.mx-chat-h{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 12px;border-bottom:1px solid rgba(6,21,33,.10)}
.mx-chat-title strong{display:block;font-size:14px;letter-spacing:.2px}
.mx-chat-sub{display:block;font-size:12px;color:var(--mx-muted);margin-top:2px}
.mx-chat-close{border:1px solid rgba(6,21,33,.12);background:rgba(238,246,255,.9);color:var(--mx-text);border-radius:12px;padding:6px 10px;cursor:pointer}
.mx-chat-close:hover{border-color:rgba(22,191,208,.35)}

.mx-chat-b{padding:12px 12px;max-height:min(52vh,520px);overflow:auto}
.mx-msg{margin:0 0 10px}
.mx-msg p{margin:0}
.mx-msg-system small{color:var(--mx-muted)}
.mx-msg-user p{background:rgba(6,21,33,.04);border:1px solid rgba(6,21,33,.08);border-radius:14px;padding:10px 10px}
.mx-msg-assistant p{background:rgba(22,191,208,.08);border:1px solid rgba(22,191,208,.16);border-radius:14px;padding:10px 10px}
.mx-msg-thinking small{color:var(--mx-muted)}
.mx-msg-error p{background:rgba(255,107,122,.10);border:1px solid rgba(255,107,122,.25);border-radius:14px;padding:10px 10px}

.mx-sources{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.mx-sources small{color:var(--mx-muted)}
.mx-sources a{color:#0F5E7A;text-decoration:underline;font-weight:600}
.mx-sources a:hover{color:#0A4C63}

.mx-chat-f{display:flex;gap:8px;padding:12px 12px;border-top:1px solid rgba(6,21,33,.10)}
.mx-chat-q{flex:1;min-width:0;padding:10px 10px;border-radius:14px;border:1px solid rgba(6,21,33,.12);background:rgba(238,246,255,.9);color:var(--mx-text)}
.mx-chat-q::placeholder{color:rgba(68,90,116,.75)}
.mx-chat-send{padding:10px 12px;border-radius:14px;border:1px solid rgba(22,191,208,.30);background:rgba(22,191,208,.14);color:var(--mx-text);font-weight:900;cursor:pointer}
.mx-chat-send:hover{background:rgba(255,180,106,.20);border-color:rgba(255,180,106,.35)}

@media (max-width:420px){
  .mx-chat{right:12px;left:12px;bottom:70px;width:auto;max-width:none}
  .mx-chat-btn{right:12px;bottom:12px}
}

/* ------------------------------------------------------------
   Landing-only portal (cloud hero + console mock)
   Scope: only affects /landing via body.page--landing
------------------------------------------------------------ */

.page--landing main.container{padding-top:24px}

.page--landing .mx-landing-cloud{
  position:relative;
  margin-top:18px;
  border-radius:28px;
  /* Full-bleed stretch (same approach as index hero) */
  width:100vw;
  width:100dvw;
  max-width:100vw;
  max-width:100dvw;
  left:50%;
  transform:translateX(-50%);
  /* keep it "floating" without heavy gradients */
  box-shadow:var(--mx-shadow);

  isolation:isolate;
  overflow:visible;
}

.page--landing .mx-landing-hero{
  position:relative;
  height:420px;
  border-radius:28px;
  overflow:visible; /* allow dropdown panel to extend */
}

.page--landing .mx-landing-hero__bg{
  position:absolute;
  inset:0;
  border-radius:28px;
  background-image:url('/assets/img/landing-hero.png');
  background-size:cover;
  background-position:center;
  /* Irregular cloud edge mask (applies to image only, not UI) */
  -webkit-mask-image:url('/assets/img/cloud-mask.svg');
  mask-image:url('/assets/img/cloud-mask.svg');
  -webkit-mask-size:cover;
  mask-size:cover;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-position:center;
  mask-position:center;
}

/* Fallback / extra softness: asymmetric edge haze */
.page--landing .mx-landing-hero::before{
  content:"";
  position:absolute;
  inset:-14px;
  border-radius:30px;
  pointer-events:none;
  background:
    radial-gradient(260px 170px at 12% 4%, rgba(246,250,255,.98), transparent 70%),
    radial-gradient(320px 220px at 92% 8%, rgba(246,250,255,.96), transparent 72%),
    radial-gradient(280px 260px at 5% 55%, rgba(246,250,255,.88), transparent 68%),
    radial-gradient(320px 280px at 98% 62%, rgba(246,250,255,.86), transparent 70%),
    radial-gradient(460px 260px at 42% -10%, rgba(246,250,255,.78), transparent 70%);
  filter:blur(10px);
  mix-blend-mode:screen;
  opacity:.95;
}

.page--landing .mx-landing-search-wrap{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-18px; /* slight overhang */

  /* Center to the same content column width as the sections below,
     while the hero itself can stay full-bleed. */
  width:min(var(--mx-maxw), calc(100% - 36px));

  display:flex;
  justify-content:center;
  z-index:60;
}

.page--landing .mx-landing-search{
  position:relative;
  width:100%;
  display:flex;
  justify-content:center;
}

.page--landing .mx-search--xl{
  width:min(860px, 100%);
  padding:14px 14px;
  border-radius:20px;
  box-shadow:0 18px 46px rgba(6,21,33,.18);

  position:relative;
  overflow:visible;
  z-index:70;
}

.page--landing .mx-search--xl input{font-size:16px
  position:relative;
  overflow:visible;
  z-index:70;
}

.page--landing .mx-search-btn{
  border:1px solid rgba(6,21,33,.12);
  background:rgba(238,246,255,.95);
  color:var(--mx-text);
  padding:10px 14px;
  border-radius:999px;
  font-weight:900;
}

.page--landing .mx-admin-mock{
  margin-top:34px;
  border:1px solid var(--mx-border);
  background:rgba(255,255,255,.86);
  border-radius:18px;
  box-shadow:var(--mx-shadow2);
  padding:14px 14px;
}

.page--landing .mx-admin-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(6,21,33,.08);
}

.page--landing .mx-admin-head strong{display:block;font-size:14px;letter-spacing:.2px}
.page--landing .mx-admin-sub{display:block;font-size:12px;color:var(--mx-muted);margin-top:2px}
.page--landing .mx-admin-status{font-size:12px;color:var(--mx-muted);white-space:nowrap}

.page--landing .mx-admin-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
@media (min-width:720px){
  .page--landing .mx-admin-grid{grid-template-columns:1fr 1fr}
  .page--landing .mx-admin-block--wide{grid-column:1 / -1}
}

.page--landing .mx-admin-label{font-size:12px;letter-spacing:.10em;text-transform:uppercase;color:var(--mx-muted);font-weight:900;margin-bottom:8px}

.page--landing .mx-admin-pills{display:flex;flex-wrap:wrap;gap:8px}
.page--landing .mx-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(22,191,208,.18);
  background:rgba(22,191,208,.06);
  color:var(--mx-text);
  font-weight:900;
  font-size:13px;
  text-decoration:none;
}
.page--landing .mx-pill:hover{background:rgba(255,180,106,.14);border-color:rgba(255,180,106,.28)}
.page--landing .mx-pill.is-on{border-color:rgba(22,191,208,.35);background:rgba(22,191,208,.10)}

.page--landing .mx-admin-list{margin:0;padding-left:18px;color:var(--mx-muted)}
.page--landing .mx-admin-list li{margin:8px 0}

.page--landing .mx-landing-intro{
  margin-top:16px;
}
.page--landing .mx-landing-intro h1{
  margin:0 0 6px;
  font-size:22px;
  line-height:1.25;
  letter-spacing:-.01em;
}
.page--landing .mx-landing-intro p{margin:0;color:var(--mx-muted);max-width:78ch}

.page--landing .mx-divider--spacer{margin:18px 0 0}

/* Landing directory: 3-up on desktop, 2-up most widths, 1-up tiny phones */
.page--landing .mx-hub-list--landing{grid-template-columns:1fr}
@media (min-width:520px){
  .page--landing .mx-hub-list--landing{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (min-width:980px){
  .page--landing .mx-hub-list--landing{grid-template-columns:repeat(3, minmax(0, 1fr))}
}

.page--landing .mx-section-title{margin:0 0 10px;font-size:14px;letter-spacing:.10em;text-transform:uppercase;color:var(--mx-muted)}

@media (max-width:420px){
  .page--landing .mx-landing-hero{height:340px}
  .page--landing .mx-landing-search{left:12px;right:12px;bottom:-16px}
}


/* ===== Landing-only portal refinements (cloud hero + console mock) ===== */
.page--landing .mx-portal-hero,
.page--landing .mx-landing-hero{
  position:relative;
  height:520px;
  border-radius:32px;
  overflow:visible;
  background-image:url("/assets/img/landing-hero.png");
  background-size:cover;
  background-position:center;
}

/* Irregular cloud edge using SVG mask where supported */
@supports ((-webkit-mask-image: url("/assets/img/cloud-mask.svg")) or (mask-image: url("/assets/img/cloud-mask.svg"))) {
  .page--landing .mx-portal-hero,
  .page--landing .mx-landing-hero{
    -webkit-mask-image: url("/assets/img/cloud-mask.svg");
    mask-image: url("/assets/img/cloud-mask.svg");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
  }
}

/* Asymmetric haze fallback */
.page--landing .mx-portal-hero::before{
  content:"";
  position:absolute; inset:-10px;
  pointer-events:none;
  background:
    radial-gradient(120px 90px at 12% 8%, rgba(248,252,255,.95), rgba(248,252,255,0) 70%),
    radial-gradient(180px 120px at 88% 12%, rgba(248,252,255,.92), rgba(248,252,255,0) 72%),
    radial-gradient(220px 150px at 96% 42%, rgba(248,252,255,.75), rgba(248,252,255,0) 70%),
    radial-gradient(220px 150px at 6% 55%, rgba(248,252,255,.65), rgba(248,252,255,0) 72%);
  filter: blur(1px);
}

/* Search bar lowered near bottom of hero + slight overhang */
.page--landing .mx-searchbar{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-18px;
  width:min(860px, calc(100% - 32px));
  z-index:5;
}
@media (max-width: 520px){
  .page--landing .mx-searchbar{ bottom:-14px; }
  .page--landing .mx-portal-hero{ height:440px; }
}

/* Console mock (replaces redundant chips) */
.page--landing .mx-console{
  margin: 34px auto 18px;
  width:min(980px, calc(100% - 32px));
  background: #ffffff;
  border: 1px solid rgba(10,20,30,.12);
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(10,20,30,.08);
  padding: 14px 16px;
}
.page--landing .mx-console__row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding: 10px 2px;
  border-top: 1px solid rgba(10,20,30,.06);
}
.page--landing .mx-console__top{ border-top:0; padding-top:4px; }
.page--landing .mx-console__title{ font-weight:700; letter-spacing:.2px; }
.page--landing .mx-console__status{ color: rgba(10,20,30,.62); font-size: .92rem; display:flex; align-items:center; gap:8px; }
.page--landing .mx-dot{ width:8px; height:8px; border-radius:99px; background: #16BFD0; box-shadow: 0 0 0 4px rgba(22,191,208,.15); }
.page--landing .mx-console__label{ width: 140px; color: rgba(10,20,30,.55); font-size:.9rem; padding-top:3px; }
.page--landing .mx-console__pills{ display:flex; flex-wrap:wrap; gap:8px; justify-content:flex-end; }
.page--landing .mx-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(10,20,30,.14);
  background: rgba(248,252,255,.9);
  color: rgba(10,20,30,.82);
  font-size: .92rem;
  text-decoration:none;
  white-space:nowrap;
}
.page--landing .mx-pill.is-on{ border-color: rgba(22,191,208,.55); box-shadow: 0 0 0 4px rgba(22,191,208,.12); }
.page--landing .mx-pill.is-muted{ opacity:.55; }
.page--landing .mx-console__list{ margin:0; padding-left: 18px; color: rgba(10,20,30,.75); }
.page--landing .mx-kbd{
  display:inline-flex; align-items:center; justify-content:center;
  width: 20px; height: 20px;
  border-radius: 6px;
  border: 1px solid rgba(10,20,30,.15);
  background: rgba(248,252,255,.95);
  margin-right: 8px;
  font-size:.8rem;
}

/* Flatten portal headline */
.page--landing .mx-portal-title--flat{
  font-size: clamp(1.35rem, 1.1rem + 1vw, 2.0rem);
  font-weight: 650;
  margin: 14px 0 6px;
}
.page--landing .mx-portal-dek{
  font-size: 1.02rem;
  color: rgba(10,20,30,.72);
  max-width: 62ch;
}

/* Landing directory: 3-up on desktop, 2-up most widths, 1-up tiny */
.page--landing .mx-hub-list{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 520px){
  .page--landing .mx-hub-list{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 980px){
  .page--landing .mx-hub-list{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}

/* Ensure back-to-top is visible on landing too */
.mx-backtotop{ display:inline-flex; }



/* ============================================================
   ACT 15: Landing-only fixes + restore subpage hero + back-to-top
   ============================================================ */

/* Back to top: fixed + visible (avoid chat bubble bottom-right) */
.mx-backtotop{
  position:fixed;
  left:16px;
  bottom:16px;
  width:44px;
  height:44px;
  border-radius:999px;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border:1px solid rgba(6,21,33,.14);
  background:rgba(255,255,255,.92);
  box-shadow:0 14px 40px rgba(6,21,33,.16);
  color:var(--mx-text);
  z-index:80;
}
.mx-backtotop:hover{ transform:translateY(-1px); }
.mx-backtotop:focus-visible{ outline:3px solid rgba(20,185,204,.38); outline-offset:3px; }

/* Restore subpage hero banner (all pages except landing) */
.page{ position:relative; }
.page:not(.page--landing)::before{
  content:"";
  display:block;
  /* Taller hero (≈2x) without becoming a billboard on small screens */
  height:clamp(320px, 38vw, 440px);
  /* Reduced height: Min 200px, Scales at 20vw, Max 300px */
  height: clamp(200px, 20vw, 320px);
  /* Full-bleed stretch (shared across index + subpages)
     - fills the visible viewport width
     - stays centered
     - keeps the same height so it doesn't become massive */
  width:100vw;
  width:100dvw;
  max-width:100vw;
  max-width:100dvw;
  position:relative;
  left:50%;
  transform:translateX(-50%);
  margin:12px 0 18px;
  border-radius:24px;
  background-image:url('/assets/brand/hero-banner_thin.png');
  background-size:cover;
  background-position:center;
  background-position: center 70%;
  box-shadow:var(--mx-shadow);
  border:1px solid rgba(6,21,33,.10);
}

/* Mobile: NO fade. Square edges. Full-bleed. (all pages except landing) */
@media (max-width:640px){
  .page:not(.page--landing)::before{
    border-radius:0;
    border:0;
    box-shadow:none;
    margin:0 0 18px;

    /* Remove fade overlays: only the image */
    background-image:url('/assets/brand/hero-banner_thin.png');
    background-size:cover;
    background-repeat:no-repeat;
    background-position:center 70%;
  }
}

/* Landing: use cloud hero + masked edges */
.page--landing .mx-landing-cloud{ position:relative; margin-top:18px; }
.page--landing .mx-landing-hero{
  position:relative;
  height:480px;
  border-radius:28px;
  background-image:url('/assets/img/landing-hero.png');
  background-size:cover;
  background-position:center;
  border:1px solid rgba(6,21,33,.10);
  box-shadow:var(--mx-shadow2);
  /* SVG mask (with haze fallback below) */
  -webkit-mask-image:url('/assets/img/cloud-mask.svg');
  mask-image:url('/assets/img/cloud-mask.svg');
  -webkit-mask-size:100% 100%;
  mask-size:100% 100%;
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
}
.page--landing .mx-landing-hero::before{
  content:"";
  position:absolute;
  inset:-18px;
  pointer-events:none;
  background:
    radial-gradient(360px 220px at 9% 6%, rgba(255,255,255,.98), transparent 72%),
    radial-gradient(420px 260px at 93% 10%, rgba(255,255,255,.96), transparent 74%),
    radial-gradient(360px 320px at 6% 58%, rgba(255,255,255,.86), transparent 70%),
    radial-gradient(420px 320px at 98% 62%, rgba(255,255,255,.84), transparent 72%),
    radial-gradient(520px 280px at 44% -12%, rgba(255,255,255,.72), transparent 72%);
  filter:blur(12px);
  opacity:.95;
  mix-blend-mode:screen;
}

/* Landing search bar: within hero, near bottom, slight overhang */
.page--landing .mx-landing-search{
  position:absolute;
  left:18px;
  right:18px;
  bottom:20px;
  display:flex;
  justify-content:center;
  z-index:2;
  transform:translateY(18px); /* slight overhang */
}
.page--landing .mx-search--xl{
  width:min(900px, 100%);
  padding:14px;
  border-radius:22px;
  background:rgba(255,255,255,.90);
  border:1px solid rgba(6,21,33,.14);
  box-shadow:0 18px 46px rgba(6,21,33,.18);

  position:relative;
  overflow:visible;
  z-index:70;
}
.page--landing .mx-search--xl input{ font-size:16px;
  position:relative;
  overflow:visible;
  z-index:70;
}

/* Landing console mock: vertical stack under hero */
.page--landing .mx-admin-mock{
  margin-top:44px;
  border:1px solid rgba(6,21,33,.10);
  background:rgba(255,255,255,.88);
  border-radius:20px;
  box-shadow:var(--mx-shadow);
  padding:16px;
}
.page--landing .mx-admin-mock__stack{
  display:grid;
  gap:14px;
}
.page--landing .mx-admin-mock__section{
  border:1px solid rgba(6,21,33,.08);
  border-radius:16px;
  background:rgba(246,250,255,.92);
  padding:12px 12px;
}
.page--landing .mx-admin-mock__title{
  font-weight:900;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--mx-muted);
  margin:0 0 8px;
}
.page--landing .mx-admin-mock__item{
  display:block;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(6,21,33,.08);
  background:rgba(255,255,255,.92);
  margin:8px 0 0;
  color:var(--mx-text);
  text-decoration:none;
}
.page--landing .mx-admin-mock__item.is-muted{
  opacity:.62;
}
.page--landing .mx-admin-mock__item.mx-open-chat{
  border-color:rgba(20,185,204,.28);
}
.page--landing .mx-admin-mock__item.mx-open-chat:hover{
  border-color:rgba(20,185,204,.55);
}

/* Landing directory: 3-up desktop, 2-up mid, 1-up tiny */
.page--landing .mx-hub-list--portal{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width:520px){
  .page--landing .mx-hub-list--portal{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (min-width:980px){
  .page--landing .mx-hub-list--portal{ grid-template-columns:repeat(3, minmax(0,1fr)); }
}

/* Landing-only: Actions hamburger inside the mock search bar (no global styling changes) */
.page--landing .mx-actions-hamburger{ position:relative; flex:0 0 auto; }
.page--landing .mx-actions-hamburger > summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:14px; border:1px solid rgba(6,21,33,.12); background:rgba(255,255,255,.70); }
.page--landing .mx-actions-hamburger > summary::-webkit-details-marker{ display:none; }
.page--landing .mx-actions-hamburger > summary:focus{ outline:none; box-shadow:0 0 0 3px rgba(20,185,204,.35); }
.page--landing .mx-burger{ width:18px; height:12px; display:block; position:relative; }
.page--landing .mx-burger::before,
.page--landing .mx-burger::after,
.page--landing .mx-burger{ background:transparent; }
.page--landing .mx-burger::before,
.page--landing .mx-burger::after{ content:""; position:absolute; left:0; right:0; height:2px; border-radius:2px; background:rgba(11,27,43,.85); }
.page--landing .mx-burger::before{ top:0; }
.page--landing .mx-burger::after{ bottom:0; }
.page--landing .mx-burger{ }
.page--landing .mx-burger span{ display:none; }
.page--landing .mx-actions-hamburger__panel{ position:absolute; top:52px; left:0; min-width:220px; padding:10px; border-radius:16px; border:1px solid rgba(6,21,33,.12); background:rgba(255,255,255,.96); box-shadow:0 18px 46px rgba(6,21,33,.18); z-index: 9999; }
.page--landing .mx-actions-hamburger:not([open]) .mx-actions-hamburger__panel{ display:none; }

/* Landing: hamburger expands the outside-hero chat dashboard (no dropdown menu) */
.page--landing .mx-actions-hamburger__panel.mx-chatdash{
  min-width: 0;
  width: min(920px, calc(100vw - 64px));
  padding: 0;
  border-radius: 20px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(6,21,33,.14);
  box-shadow: 0 22px 62px rgba(6,21,33,.22);
}

.page--landing .mx-chatdash__cols{
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 0;
}

.page--landing .mx-chatdash__left{
  padding: 14px;
  border-right: 1px solid rgba(6,21,33,.10);
}

.page--landing .mx-chatdash__title{
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(11,27,43,.70);
  margin: 2px 4px 10px;
}

.page--landing .mx-chatdash__item{
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(6,21,33,.10);
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 24px rgba(6,21,33,.06);
  margin: 10px 0;
  color: rgba(11,27,43,.86);
}

.page--landing .mx-chatdash__right{
  padding: 12px 14px 14px;
}

.page--landing .mx-chatdash__bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(6,21,33,.10);
  background: rgba(246,250,255,.92);
  margin-bottom: 12px;
}

.page--landing .mx-chatdash__brand{
  font-weight: 700;
  color: rgba(11,27,43,.86);
}

.page--landing .mx-chatdash__links a{
  font-size: 13px;
  color: rgba(11,27,43,.74);
  text-decoration: none;
  margin-left: 12px;
}

.page--landing .mx-chatdash__links a:hover{
  text-decoration: underline;
}

.page--landing .mx-chatdash__transcript{
  min-height: 220px;
  border-radius: 18px;
  border: 1px solid rgba(6,21,33,.10);
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 32px rgba(6,21,33,.06);
  padding: 14px;
}

.page--landing .mx-chatdash__empty{
  color: rgba(11,27,43,.66);
  line-height: 1.45;
}

.page--landing .mx-chatdash__composer{
  display:flex;
  gap: 10px;
  margin-top: 12px;
}

.page--landing .mx-chatdash__composer input{
  flex: 1;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(6,21,33,.12);
  background: rgba(255,255,255,.96);
}

.page--landing .mx-chatdash__composer button{
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(6,21,33,.12);
  background: rgba(11,27,43,.06);
  color: rgba(11,27,43,.70);
}

.page--landing .mx-actions-hamburger__item{ display:block; padding:10px 12px; border-radius:12px; border:1px solid rgba(6,21,33,.10); background:rgba(246,250,255,.95); color:var(--mx-text); text-decoration:none; margin-top:8px; }
.page--landing .mx-actions-hamburger__item:first-child{ margin-top:0; }
.page--landing .mx-actions-hamburger__item.mx-open-chat{ border-color:rgba(20,185,204,.28); }
.page--landing .mx-actions-hamburger__item.mx-open-chat:hover{ border-color:rgba(20,185,204,.55); }
.page--landing .mx-actions-hamburger__item.is-muted{ opacity:.62; }


/* Landing chat dashboard: hidden by default; opened via hamburger (details[open]) */
.page--landing .mx-chatdash{
  display: none;
  margin: 18px auto 0;
  max-width: 920px;
  border-radius: 18px;
  border: 1px solid rgba(6,21,33,.10);
  background: rgba(255,255,255,.74);
  box-shadow: 0 18px 46px rgba(6,21,33,.10);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.page--landing .mx-actions-hamburger[open] ~ .mx-chatdash{
  display: block;
}


/* Landing: outside-hero dashboard toggle (Option B) */
.page--landing .mx-chatdash{ display:none; }
.page--landing .mx-chatdash.is-expanded{ display:block; }

.mx-search:focus-within{
  border-color:#1489A3;
  box-shadow:0 0 0 3px rgba(20,137,163,.15);
}

.mx-footer{
  margin-top: 56px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(248, 250, 252, 0.72);
}

.mx-footer__inner{
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.6fr);
  gap: 36px;
  padding-top: 34px;
  padding-bottom: 40px;
}

.mx-footer__title{
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
}

.mx-footer__tagline{
  margin: 0;
  max-width: 40ch;
  line-height: 1.6;
  color: rgba(15, 23, 42, 0.72);
}

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

.mx-footer__heading{
  margin-bottom: 10px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(15, 23, 42, 0.56);
}

.mx-footer__col a{
  display: block;
  margin-bottom: 8px;
  text-decoration: none;
}

.mx-footer__col a:last-child{
  margin-bottom: 0;
}

@media (max-width: 800px){
  .mx-footer__inner{
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .mx-footer__cols{
    grid-template-columns: 1fr 1fr;
    gap: 22px;
  }
}

@media (max-width: 560px){
  .mx-footer__cols{
    grid-template-columns: 1fr;
  }
}
