/* ============================================================
   MV HOTELS WATCH — Design System
   Editorial / watchdog aesthetic. Near-black + shades of blue.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&family=Libre+Franklin:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root{
  /* Palette — navy blue */
  --ink:        #0A0E16;   /* near-black text */
  --ink-soft:   #1A2230;
  --paper:      #F6F8FC;   /* page base */
  --paper-2:    #FFFFFF;   /* cards */
  --navy:       #07182F;   /* deep navy (header / dark sections) */
  --navy-2:     #0C2746;
  --navy-3:     #123A66;
  --slate-deep: #0A0E16;   /* footer (navy/near-black) */
  --blue:       #1257E8;   /* primary action blue */
  --blue-bright:#3B82F6;
  --blue-700:   #0B3FA8;
  --blue-tint:  #E7EEFC;   /* soft blue wash */
  --blue-line:  #BFD2F2;
  --line:       rgba(10,14,22,.12);
  --line-soft:  rgba(10,14,22,.07);
  --muted:      #586273;
  --muted-2:    #8590A2;
  --good:       #0E7C5A;
  --warn:       #B26A00;

  --maxw: 1180px;
  --radius: 4px;
  --radius-lg: 10px;
  --shadow: 0 1px 2px rgba(7,24,47,.06), 0 8px 30px rgba(7,24,47,.06);
  --shadow-lg: 0 20px 60px rgba(7,24,47,.16);

  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Libre Franklin', -apple-system, BlinkMacSystemFont, sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:17px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* subtle paper texture */
  background-image:
    radial-gradient(circle at 1px 1px, rgba(7,24,47,.035) 1px, transparent 0);
  background-size: 22px 22px;
}

img{ max-width:100%; display:block; }
a{ color:var(--blue); text-decoration:none; }
a:hover{ text-decoration:underline; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.wrap-narrow{ max-width:780px; margin:0 auto; padding:0 28px; }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.08; color:var(--ink); letter-spacing:-.01em; margin:0 0 .4em; }
h1{ font-size:clamp(2.5rem,6vw,4.6rem); font-weight:600; }
h2{ font-size:clamp(1.7rem,3.4vw,2.6rem); }
h3{ font-size:1.3rem; }
p{ margin:0 0 1.1em; }
.lede{ font-size:1.22rem; color:var(--ink-soft); line-height:1.55; }

.kicker{
  font-family:var(--font-body);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--blue-700);
  display:inline-flex; align-items:center; gap:.5em;
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--blue); display:inline-block; }

.section{ padding:84px 0; }
.section-tight{ padding:54px 0; }
.eyebrow{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; font-weight:700; color:var(--muted); }

/* ---------- Header / Nav ---------- */
.topbar{
  background:var(--navy);
  color:#cdddf5;
  font-size:.78rem;
  letter-spacing:.02em;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.topbar .wrap{ display:flex; justify-content:space-between; align-items:center; gap:16px; height:38px; }
.topbar .ticker{ overflow:hidden; white-space:nowrap; flex:1; -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.topbar .ticker span{ display:inline-block; padding-left:100%; animation:ticker 38s linear infinite; }
.topbar .ticker b{ color:#fff; font-weight:600; }
.topbar .ticker em{ color:var(--blue-bright); font-style:normal; margin:0 26px; }
@keyframes ticker{ from{transform:translateX(0)} to{transform:translateX(-100%)} }
.topbar .meta{ color:#8fb0dc; flex-shrink:0; }

header.site{
  position:sticky; top:0; z-index:50;
  background:rgba(7,24,47,.96);
  backdrop-filter:blur(8px);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}
header.site .bar{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand{ display:flex; align-items:center; gap:13px; color:#fff; text-decoration:none; }
.brand:hover{ text-decoration:none; }
.brand .mark{
  width:38px; height:38px; flex-shrink:0; border-radius:3px;
  background:linear-gradient(150deg,var(--blue) 0%, var(--blue-700) 100%);
  position:relative; display:grid; place-items:center;
  box-shadow:0 0 0 1px rgba(255,255,255,.12) inset;
}
.brand .mark::before{ content:""; position:absolute; inset:7px; border:2px solid rgba(255,255,255,.85); border-radius:50%; }
.brand .mark::after{ content:""; position:absolute; width:18px; height:2px; background:#fff; transform:rotate(-20deg); }
.brand .name{ font-family:var(--font-display); font-weight:600; font-size:1.28rem; letter-spacing:-.01em; line-height:1; }
.brand .name small{ display:block; font-family:var(--font-body); font-weight:600; font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; color:var(--blue-bright); margin-top:4px; }

nav.main{ display:flex; align-items:center; gap:4px; }
nav.main a{
  color:#c7d6ee; font-weight:500; font-size:.92rem; padding:9px 14px; border-radius:4px;
  position:relative; letter-spacing:.01em;
}
nav.main a:hover{ color:#fff; text-decoration:none; background:rgba(255,255,255,.06); }
nav.main a.active{ color:#fff; }
nav.main a.active::after{ content:""; position:absolute; left:14px; right:14px; bottom:2px; height:2px; background:var(--blue-bright); }
.nav-cta{ background:var(--blue); color:#fff !important; padding:10px 18px !important; border-radius:5px; font-weight:600; }
.nav-cta:hover{ background:var(--blue-bright); }
.burger{ display:none; background:none; border:0; color:#fff; font-size:1.6rem; cursor:pointer; padding:6px; }

@media(max-width:960px){
  nav.main{
    position:fixed; inset:74px 0 auto 0; flex-direction:column; align-items:stretch; gap:0;
    background:var(--navy); padding:10px 16px 22px; border-bottom:1px solid rgba(255,255,255,.1);
    transform:translateY(-130%); transition:transform .32s cubic-bezier(.4,0,.2,1); box-shadow:var(--shadow-lg);
  }
  nav.main.open{ transform:translateY(0); }
  nav.main a{ padding:14px 8px; border-bottom:1px solid rgba(255,255,255,.06); border-radius:0; }
  nav.main a.active::after{ display:none; }
  .nav-cta{ margin-top:12px; text-align:center; }
  .burger{ display:block; }
  .topbar .meta{ display:none; }
}

/* ---------- Buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:.55em; font-family:var(--font-body); font-weight:600;
  font-size:.95rem; padding:13px 24px; border-radius:6px; border:1px solid transparent; cursor:pointer;
  transition:.18s; letter-spacing:.01em; }
.btn:hover{ text-decoration:none; }
.btn-primary{ background:var(--blue); color:#fff; }
.btn-primary:hover{ background:var(--blue-700); transform:translateY(-1px); }
.btn-dark{ background:var(--ink); color:#fff; }
.btn-dark:hover{ background:var(--navy-2); transform:translateY(-1px); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--ink); background:#fff; }
.btn-light{ background:#fff; color:var(--navy); }
.btn-light:hover{ background:var(--blue-tint); }

/* ---------- Hero ---------- */
.hero{ background:var(--navy); color:#eaf1fb; position:relative; overflow:hidden; }
.hero::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(1100px 500px at 78% -10%, rgba(59,130,246,.25), transparent 60%),
    radial-gradient(800px 500px at 0% 110%, rgba(18,87,232,.22), transparent 55%);
}
.hero::after{
  content:""; position:absolute; inset:0; opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:44px 44px;
  -webkit-mask-image:radial-gradient(800px 500px at 70% 20%, #000, transparent 80%);
          mask-image:radial-gradient(800px 500px at 70% 20%, #000, transparent 80%);
}
.hero .wrap{ position:relative; z-index:2; padding-top:96px; padding-bottom:96px; }
.hero h1{ color:#fff; max-width:16ch; }
.hero h1 em{ font-style:italic; color:var(--blue-bright); }
.hero .lede{ color:#b9cbe6; max-width:56ch; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }

.hero-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; margin-top:64px; border-top:1px solid rgba(255,255,255,.14); }
.hero-stats .stat{ padding:24px 22px 6px 0; border-right:1px solid rgba(255,255,255,.1); }
.hero-stats .stat:last-child{ border-right:0; }
.hero-stats .num{ font-family:var(--font-display); font-size:2.5rem; font-weight:600; color:#fff; line-height:1; letter-spacing:-.02em; }
.hero-stats .num span{ color:var(--blue-bright); font-size:1.1rem; }
.hero-stats .lab{ font-size:.78rem; color:#9fb6d8; margin-top:8px; letter-spacing:.04em; }
@media(max-width:760px){ .hero-stats{ grid-template-columns:repeat(2,1fr); } .hero-stats .stat:nth-child(2){border-right:0;} }

/* ---------- Cards / grids ---------- */
.grid{ display:grid; gap:26px; }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-2{ grid-template-columns:repeat(2,1fr); }
@media(max-width:880px){ .g-3{ grid-template-columns:1fr 1fr; } }
@media(max-width:620px){ .g-3,.g-2{ grid-template-columns:1fr; } }

.card{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow); transition:.2s; }
.card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); border-color:var(--blue-line); }

/* Article card */
.article{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; transition:.2s; }
.article:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); border-color:var(--blue-line); }
.article .thumb{ aspect-ratio:16/9; background:var(--navy-2); position:relative; overflow:hidden;
  background-image:linear-gradient(135deg,var(--navy) 0%, var(--blue-700) 100%); }
.article .thumb .tag{ position:absolute; top:14px; left:14px; background:#fff; color:var(--navy); font-size:.66rem;
  font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:5px 10px; border-radius:3px; }
.article .thumb .glyph{ position:absolute; inset:0; display:grid; place-items:center; color:rgba(255,255,255,.14); font-family:var(--font-display); font-size:5rem; }
.article .body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.article .body .when{ font-size:.74rem; color:var(--muted); letter-spacing:.04em; margin-bottom:9px; }
.article .body h3{ font-size:1.22rem; margin-bottom:.5em; }
.article .body h3 a{ color:var(--ink); }
.article .body h3 a:hover{ color:var(--blue); }
.article .body p{ color:var(--muted); font-size:.95rem; margin-bottom:1em; }
.article .body .src{ margin-top:auto; font-size:.76rem; color:var(--muted-2); }
.article .body .src a{ font-weight:600; }

/* ---------- Tables ---------- */
.table-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--paper-2); box-shadow:var(--shadow); }
table.data{ width:100%; border-collapse:collapse; font-size:.93rem; min-width:560px; }
table.data thead th{ background:var(--navy); color:#dce8fa; text-align:left; padding:15px 18px; font-weight:600;
  font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; position:sticky; top:0; }
table.data th.num, table.data td.num{ text-align:right; font-variant-numeric:tabular-nums; }
table.data tbody td{ padding:14px 18px; border-bottom:1px solid var(--line-soft); }
table.data tbody tr:hover{ background:var(--blue-tint); }
table.data tbody tr:last-child td{ border-bottom:0; }
table.data .rank{ font-family:var(--font-display); font-weight:600; color:var(--blue-700); width:40px; }
table.data .amt{ font-family:var(--font-display); font-weight:600; font-size:1.02rem; color:var(--ink); }
.sc-top td{ background:rgba(18,87,232,.05); }
.pill{ display:inline-block; font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:3px 9px; border-radius:30px; }
.pill-blue{ background:var(--blue-tint); color:var(--blue-700); }
.pill-good{ background:rgba(14,124,90,.12); color:var(--good); }
.pill-warn{ background:rgba(178,106,0,.12); color:var(--warn); }

/* ---------- Notice / disclaimer boxes ---------- */
.notice{ border:1px solid var(--blue-line); background:var(--blue-tint); border-radius:var(--radius-lg); padding:20px 24px; font-size:.92rem; color:var(--ink-soft); }
.notice strong{ color:var(--navy); }
.notice.warn{ border-color:rgba(178,106,0,.4); background:rgba(178,106,0,.07); }

/* ---------- Section header ---------- */
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:38px; flex-wrap:wrap; }
.sec-head .left{ max-width:60ch; }
.sec-head h2{ margin-bottom:.2em; }
.sec-head p{ color:var(--muted); margin:0; }

/* ---------- Page banner (interior pages) ---------- */
.page-banner{ background:var(--navy); color:#fff; position:relative; overflow:hidden; }
.page-banner::after{ content:""; position:absolute; inset:0; opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:40px 40px; -webkit-mask-image:radial-gradient(700px 320px at 85% 10%, #000, transparent 75%); }
.page-banner .wrap{ position:relative; z-index:2; padding:70px 28px 64px; }
.page-banner h1{ color:#fff; font-size:clamp(2.2rem,5vw,3.6rem); max-width:18ch; }
.page-banner p{ color:#b9cbe6; max-width:60ch; margin:0; font-size:1.1rem; }
.crumbs{ font-size:.76rem; letter-spacing:.04em; color:#7f9bc4; margin-bottom:18px; }
.crumbs a{ color:#a9c2e6; }

/* ---------- Forms ---------- */
.field{ margin-bottom:20px; }
.field label{ display:block; font-weight:600; font-size:.85rem; margin-bottom:7px; color:var(--ink-soft); letter-spacing:.01em; }
.field label .req{ color:var(--blue); }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--font-body); font-size:1rem; color:var(--ink);
  padding:13px 15px; border:1px solid var(--line); border-radius:6px; background:#fff; transition:.16s;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:0; border-color:var(--blue); box-shadow:0 0 0 3px rgba(18,87,232,.14); }
.field textarea{ min-height:140px; resize:vertical; }
.field .hint{ font-size:.78rem; color:var(--muted); margin-top:6px; }
.form-card{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px; box-shadow:var(--shadow); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media(max-width:560px){ .form-row{ grid-template-columns:1fr; } }
.form-status{ display:none; padding:14px 18px; border-radius:6px; margin-bottom:18px; font-size:.92rem; }
.form-status.ok{ display:block; background:rgba(14,124,90,.1); color:var(--good); border:1px solid rgba(14,124,90,.3); }

/* ---------- Directory list ---------- */
.dir-controls{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:26px; align-items:center; }
.dir-controls input, .dir-controls select{ padding:11px 14px; border:1px solid var(--line); border-radius:6px; font-family:var(--font-body); font-size:.95rem; background:#fff; }
.dir-controls input{ flex:1; min-width:220px; }

/* ---------- Careers list ---------- */
.job{ background:var(--paper-2); border:1px solid var(--line); border-radius:var(--radius-lg); padding:22px 26px;
  display:flex; justify-content:space-between; align-items:center; gap:20px; transition:.18s; margin-bottom:14px; }
.job:hover{ border-color:var(--blue-line); box-shadow:var(--shadow); }
.job .role{ font-family:var(--font-display); font-weight:600; font-size:1.2rem; margin-bottom:4px; }
.job .where{ font-size:.85rem; color:var(--muted); }
.job .meta{ text-align:right; flex-shrink:0; }
.job .meta .pill{ margin-bottom:8px; }
@media(max-width:600px){ .job{ flex-direction:column; align-items:flex-start; } .job .meta{ text-align:left; } }

/* ---------- CTA band ---------- */
.cta-band{ background:linear-gradient(120deg,var(--navy) 0%, var(--blue-700) 120%); color:#fff; border-radius:var(--radius-lg); padding:54px 48px; position:relative; overflow:hidden; }
.cta-band::after{ content:""; position:absolute; right:-60px; top:-60px; width:320px; height:320px; border:2px solid rgba(255,255,255,.12); border-radius:50%; }
.cta-band h2{ color:#fff; max-width:20ch; }
.cta-band p{ color:#cfe0f7; max-width:52ch; }

/* ---------- Footer ---------- */
footer.site{ background:var(--slate-deep); color:#CBD6E1; padding:64px 0 30px; margin-top:0; font-size:.92rem; }
footer.site .cols{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; padding-bottom:42px; border-bottom:1px solid rgba(255,255,255,.1); }
@media(max-width:820px){ footer.site .cols{ grid-template-columns:1fr 1fr; gap:30px; } }
@media(max-width:480px){ footer.site .cols{ grid-template-columns:1fr; } }
footer.site h4{ color:#fff; font-family:var(--font-body); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; margin-bottom:16px; }
footer.site a{ color:#CBD6E1; display:block; padding:5px 0; }
footer.site a:hover{ color:#fff; text-decoration:none; }
footer.site .brand-foot{ display:flex; align-items:center; gap:12px; margin-bottom:14px; }
footer.site .brand-foot .name{ font-family:var(--font-display); color:#fff; font-size:1.25rem; }
footer.site .about-foot{ max-width:34ch; color:#AAB8C6; }
footer.site .legal{ display:flex; justify-content:space-between; gap:20px; padding-top:24px; font-size:.8rem; color:#9DACBA; flex-wrap:wrap; }
footer.site .legal a{ display:inline; }

/* ---------- Reveal on load / scroll ---------- */
/* ---------- Reveal (pure CSS — content stays visible even if JS doesn't load) ---------- */
@keyframes revealIn{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:none; } }
.reveal{ animation:revealIn .7s cubic-bezier(.2,.7,.2,1) both; }
.reveal.in{ opacity:1; transform:none; }
.d1{ animation-delay:.07s; } .d2{ animation-delay:.14s; } .d3{ animation-delay:.21s; } .d4{ animation-delay:.28s; }
@media (prefers-reduced-motion: reduce){ .reveal{ animation:none; } }

/* ---------- Misc ---------- */
.divider{ height:1px; background:var(--line); border:0; margin:0; }
.small{ font-size:.82rem; color:var(--muted); }
.center{ text-align:center; }
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.tag-row{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
ul.clean{ list-style:none; padding:0; margin:0; }
ul.ticks{ list-style:none; padding:0; margin:0 0 1em; }
ul.ticks li{ padding:8px 0 8px 30px; position:relative; border-bottom:1px solid var(--line-soft); }
ul.ticks li::before{ content:"→"; position:absolute; left:0; color:var(--blue); font-weight:700; }
