
:root{
  --navy:#071B33;
  --navy-2:#0B1D3A;
  --blue:#1687FF;
  --sky:#1E90FF;
  --teal:#00BFA6;
  --coral:#FF7A66;
  --cloud:#F6F2EB;
  --white:#FFFDF8;
  --slate:#5B6B7F;
  --line:#E7EEF7;
  --success:#19B77A;
  --warning:#FFC857;
  --danger:#FF5D5D;
  --radius:24px;
  --shadow:0 18px 50px rgba(7,27,51,.10);
  --soft-shadow:0 10px 30px rgba(7,27,51,.08);
}

/* CrewMark Icon utility — inline SVG referenced from the sprite at
   /shared/icons.svg. Stroke uses currentColor so the icon inherits the
   parent's text colour. Default size 18px; override per use-site. */
.cmi{width:18px;height:18px;display:inline-block;flex-shrink:0;vertical-align:middle;color:currentColor;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cmi-sm{width:14px;height:14px}
.cmi-lg{width:22px;height:22px}
.cmi-xl{width:28px;height:28px}

/* Pill toggle — visual stand-in for an on/off switch in a static mockup.
   Used in Settings page in place of the 🔵 emoji. */
.toggle-pill{display:inline-block;width:32px;height:18px;border-radius:99px;background:linear-gradient(135deg,var(--blue),var(--teal));position:relative;vertical-align:middle}
.toggle-pill:after{content:"";position:absolute;top:2px;right:2px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.18)}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
/* Force the `hidden` attribute to win even when an element has inline
   `display:flex` (used by our modal overlays — duty-modal, finding-modal,
   proposal-modal, email-modal, gdpr-modal). Without this the modal is
   visible from page load because inline styles outrank the UA default
   `[hidden]{display:none}` rule. */
[hidden]{display:none !important}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--navy);
  background:linear-gradient(180deg,#f8fbff 0%,#fffdf8 48%,#f6f2eb 100%);
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.site-header{
  position:sticky;top:0;z-index:20;
  background:rgba(255,253,248,.88);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(7,27,51,.08);
}
.nav{height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;gap:12px;font-weight:900}
.logo img{width:48px;height:48px;object-fit:contain}
.logo small{display:block;color:var(--coral);font-weight:800;font-size:12px;letter-spacing:.02em;margin-top:-5px}
.logo span{font-size:24px;letter-spacing:-.03em}
.nav-links{display:flex;gap:26px;align-items:center;font-weight:700;font-size:14px;color:#14304f}
.nav-actions{display:flex;gap:14px;align-items:center}
.btn{
  border:0;border-radius:14px;padding:13px 18px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;gap:8px;justify-content:center;
  transition:.2s ease;background:#fff;color:var(--navy);box-shadow:var(--soft-shadow)
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--coral),#ff664f);color:white}
.btn-blue{background:linear-gradient(135deg,var(--blue),#005ce6);color:#fff}
.btn-ghost{border:1px solid var(--line);box-shadow:none;background:#fff}
.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:99px;font-size:13px;font-weight:800;background:#fff4ef;color:#a53c2e}
.hero{
  position:relative;overflow:hidden;
  padding:88px 0 70px;
  background:
    radial-gradient(circle at 78% 20%,rgba(30,144,255,.22),transparent 34%),
    radial-gradient(circle at 12% 70%,rgba(255,122,102,.18),transparent 34%),
    linear-gradient(180deg,#eef7ff,#fffdf8 74%);
}
.hero:before{
  content:"";position:absolute;inset:0;
  background:url('../assets/mockups/website-homepage.webp') center/cover no-repeat;
  opacity:.06;filter:blur(1px);
}
.hero .container{position:relative;display:grid;grid-template-columns:1fr 1.06fr;gap:48px;align-items:center}
h1,h2,h3{line-height:1.05;margin:0;letter-spacing:-.045em}
h1{font-size:clamp(48px,7vw,86px)}
h2{font-size:clamp(34px,4vw,56px);text-align:center;margin-bottom:18px}
h3{font-size:24px}
.lead{font-size:20px;color:#24415f;max-width:620px;margin:24px 0}
.gradient-word{color:var(--teal)}
.coral{color:var(--coral)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:28px 0}
.trust{display:flex;align-items:center;gap:12px;color:#435b73;font-weight:700}
.avatar-stack{display:flex}
.avatar-stack span{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--teal));border:2px solid #fff;margin-left:-8px}
.avatar-stack span:first-child{margin-left:0}
.stars{color:#FFB800;letter-spacing:1px}
.mock-dashboard{
  background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.8);
  box-shadow:var(--shadow);border-radius:32px;padding:18px;display:grid;grid-template-columns:.85fr 1.15fr;gap:16px;
}
.upload-card,.screen-card,.feature-card,.card{
  background:rgba(255,255,255,.86);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--soft-shadow)
}
.upload-card{padding:24px}
.drop{border:1.5px dashed #bfd2e8;border-radius:18px;display:grid;place-items:center;min-height:150px;color:var(--slate);margin:18px 0}
.pdf{font-weight:900;background:var(--coral);color:#fff;padding:10px 12px;border-radius:10px}
.checkline{display:flex;align-items:center;gap:10px;font-weight:700;margin:10px 0;color:#35506b}
.checkline:before{content:"✓";display:grid;place-items:center;width:20px;height:20px;border-radius:50%;background:#e6fbf5;color:var(--teal);font-weight:900}
.screen-card{padding:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.status-ring{
  width:130px;height:130px;border-radius:50%;display:grid;place-items:center;margin:auto;
  background:conic-gradient(var(--teal) 0 100%,#e9eef5 0);
  position:relative;font-weight:900;font-size:30px
}
.status-ring:after{content:"";position:absolute;inset:13px;border-radius:50%;background:#fff}
.status-ring span{position:relative;z-index:2;text-align:center}.status-ring small{display:block;font-size:13px;color:var(--slate)}

/* Hero mock-dashboard fit-fix.
   The designer's global h3 is 24px with heavy negative letter-spacing,
   but the mock-dashboard splits into a .85fr + 1.15fr grid where the
   upload-card column is only ~200px wide. At 24px the words "Upload",
   "your", "roster" stack vertically. Same for "Next Duty" / "DXB → LHR"
   inside the .85fr screen-card .grid-2 inner cards. We scope this
   override strictly to .mock-dashboard so the rest of the page keeps
   the designer's headline sizes untouched. */
.mock-dashboard h3{font-size:18px;letter-spacing:-.02em;line-height:1.15}
.mock-dashboard .drop p{font-size:14px;text-align:center;line-height:1.4;margin:8px 0 0}
.mock-dashboard .checkline{font-size:14px;margin:8px 0}
.mock-dashboard .card p{font-size:13px;line-height:1.4;margin:4px 0}
.mock-dashboard .card b{font-size:13px}
.mock-dashboard .card{padding:14px !important}
.mock-dashboard .grid-2{gap:10px}
.mock-dashboard .status-ring{width:110px;height:110px;font-size:24px}
.mock-dashboard .status-ring:after{inset:10px}
.section{padding:76px 0}
.section-subtitle{text-align:center;color:var(--slate);margin:0 auto 34px;max-width:720px;font-size:18px}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature-card{padding:24px}
.icon{
  width:48px;height:48px;border-radius:16px;display:grid;place-items:center;font-size:24px;
  background:linear-gradient(135deg,#eef7ff,#e8fffa);color:var(--blue);margin-bottom:16px
}
.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:36px;align-items:center}
.panel-image{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.testimonial{padding:24px;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--soft-shadow)}
.cta{
  margin:60px 0;background:linear-gradient(135deg,var(--navy),#0c4da2);
  color:#fff;border-radius:32px;padding:46px;display:flex;justify-content:space-between;align-items:center;gap:24px;overflow:hidden;position:relative
}
.cta:after{content:"✈";position:absolute;right:42px;top:18px;font-size:80px;opacity:.14}
.footer{background:var(--navy);color:#dce9f5;padding:54px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr) 1.4fr;gap:28px}
.footer h4{color:#fff;margin:0 0 14px}.footer a{display:block;margin:8px 0;color:#dce9f5}
.email{display:flex;background:#fff;border-radius:14px;padding:6px;gap:6px}
.email input{border:0;padding:10px;min-width:0;flex:1}
.email button{border:0;border-radius:10px;background:var(--coral);color:#fff;font-weight:800;padding:10px 14px}
.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;background:#f8fbff}
.sidebar{background:linear-gradient(180deg,#06162d,#082a54);color:#fff;padding:28px 18px;display:flex;flex-direction:column;gap:18px}
/* Branded sidebar lockup — vertical: icon → "CrewMark" → "built for crew, by crew".
   The icon PNG was opaque-white-backgrounded out of the box; we flood-filled the
   white background to alpha=0 (see (a) PROJECT_INDEX.md §4 + the
   crewmark-icon.original-opaque.png backup). Now the icon sits cleanly on the navy
   gradient — no card, no halo. Light drop-shadow only for subtle separation. */
.sidebar .logo{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:12px;margin:4px 0 24px;padding:6px 8px;
  text-decoration:none
}
.sidebar .logo img{
  width:84px;height:84px;display:block;object-fit:contain;
  filter:drop-shadow(0 3px 8px rgba(0,0,0,.25))
}
.sidebar .logo > div{display:flex;flex-direction:column;align-items:center;gap:2px;line-height:1}
.sidebar .logo span{font-size:26px;font-weight:900;color:#fff;letter-spacing:-.025em;line-height:1}
.sidebar .logo small{
  font-size:12px;font-weight:800;color:var(--coral);letter-spacing:.01em;
  margin-top:0;line-height:1.2
}
/* Persistent "Upload Roster" CTA sitting between the logo and the nav.
   Coral gradient pops against the navy sidebar; same href across every
   page so crew always know where to drop a fresh roster. */
.side-upload{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(135deg,var(--coral),#ff5d3f);
  color:#fff;font-weight:800;font-size:14px;letter-spacing:.01em;
  padding:14px 16px;border-radius:14px;text-decoration:none;
  box-shadow:0 6px 18px rgba(255,122,102,.35);
  transition:transform .15s ease,box-shadow .15s ease;
  border:1px solid rgba(255,255,255,.18);
}
.side-upload:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,122,102,.45)}
.side-upload svg{flex-shrink:0}
.side-link{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:14px;color:#d9e9ff;font-weight:700}
.side-link.active{background:linear-gradient(135deg,#0d63d9,#1687ff);color:#fff}
.side-card{margin-top:auto;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px}
.app-main{padding:28px 34px}
.app-top{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:28px}
.search{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px 18px;min-width:360px;color:var(--slate)}
.profile{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px 14px}
.profile .avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--coral))}
.app-grid{display:grid;grid-template-columns:1.2fr .75fr .75fr;gap:18px}
.big-blue{background:linear-gradient(135deg,#0461d9,#03337f);color:#fff;padding:28px;border-radius:26px;box-shadow:var(--shadow)}
.data-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--soft-shadow)}
.timeline{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.day{padding:18px;border-radius:18px;background:#fff;border:1px solid var(--line);text-align:center}.day.today{border:2px solid var(--blue);background:#f1f7ff}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}.table th{text-align:left;color:var(--slate);font-size:13px}.table td{background:#fff;padding:16px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.table td:first-child{border-left:1px solid var(--line);border-radius:14px 0 0 14px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 14px 14px 0}
.tag{padding:5px 9px;border-radius:99px;font-size:12px;font-weight:800;display:inline-flex}.tag.ok{background:#e6fbf5;color:#087a68}.tag.warn{background:#fff3d6;color:#a76500}.tag.red{background:#ffe9e7;color:#b5483b}
.mockup-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.mockup-gallery a{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--soft-shadow)}
.mockup-gallery img{aspect-ratio:4/3;object-fit:cover}
.mockup-gallery span{display:block;padding:14px 16px;font-weight:800}
@media(max-width:900px){
  .nav-links{display:none}.hero .container,.split,.mock-dashboard,.footer-grid,.features-grid,.testimonials,.app-grid{grid-template-columns:1fr}
  .app-shell{grid-template-columns:1fr}.sidebar{display:none}.search{min-width:0;width:100%}.app-top{flex-direction:column;align-items:stretch}
  h1{font-size:44px}.mockup-gallery{grid-template-columns:1fr}
}

/* -----------------------------------------------------------------------
   Dashboard (app) typography scale.
   -----------------------------------------------------------------------
   The landing-page hero uses a huge headline scale (h1 up to 86px, h2 up
   to 56px). That's wrong for the *signed-in* dashboard, where the same
   tags appear as section headers and KPI numbers — they were rendering
   massive ("Good afternoon, CrewMark!" filling half the viewport,
   "PRG→MUC · MUC→CGN" overflowing the next-duty card).
   We scope a tighter scale to .app-main so the landing page is untouched.
*/
.app-main{padding:24px 28px}
.app-main h1{font-size:22px;letter-spacing:-.015em;line-height:1.2;font-weight:800}
.app-main h2{font-size:26px;text-align:left;letter-spacing:-.02em;line-height:1.15;margin:0 0 6px;font-weight:800}
.app-main h3{font-size:13px;letter-spacing:.06em;line-height:1.2;margin:0 0 12px;font-weight:800;color:var(--slate);text-transform:uppercase}
.app-main h4{font-size:13px;line-height:1.25;margin:14px 0 6px;font-weight:800;color:var(--navy);letter-spacing:-.005em}
.app-main h5{font-size:12px;line-height:1.25;margin:10px 0 4px;font-weight:700;color:var(--slate);text-transform:uppercase;letter-spacing:.05em}
/* Stat values inside nested data-cards (modal metric tiles, etc.) keep
   the data-card chrome but don't need its 18px padding — that's handled
   inline by callers. */
.app-main .app-top{margin-bottom:18px}
.app-main .search{padding:10px 14px;min-width:300px;font-size:13px;border-radius:14px}
.app-main .profile{padding:6px 10px;border-radius:14px}
.app-main .profile .avatar{width:34px;height:34px}
.app-main .profile b{font-size:13px}
.app-main .profile small{font-size:11px}
.app-main .app-grid{gap:14px}
.app-main .data-card{padding:18px 20px;border-radius:18px}
.app-main .data-card p{font-size:13px;margin:6px 0}
.app-main .data-card h2{font-size:24px;margin:0 0 4px}
.app-main .big-blue{padding:20px 22px;border-radius:20px}
.app-main .big-blue h2{font-size:30px;margin:8px 0 6px;color:#fff}
.app-main .big-blue h3{color:rgba(255,255,255,.78);font-size:11px;margin:0 0 8px;text-transform:uppercase;letter-spacing:.08em}
.app-main .big-blue b{font-size:11px;color:rgba(255,255,255,.78);text-transform:uppercase;letter-spacing:.08em;font-weight:800}
.app-main .big-blue small{color:rgba(255,255,255,.7);font-size:11px}
.app-main .big-blue p{margin:4px 0;font-size:13px}
.app-main .status-ring{width:108px;height:108px;font-size:24px;margin:6px auto}
.app-main .status-ring small{font-size:11px}
.app-main .status-ring:after{inset:11px}
.app-main .timeline{gap:8px}
.app-main .day{padding:12px 8px;font-size:12px;border-radius:14px}
.app-main .day b{font-size:13px}
.app-main .table td{padding:12px 14px;font-size:13px}
.app-main .tag{font-size:11px;padding:4px 8px}
/* Greeting hero strip — used at the top of dashboard.html. Tight padding
   so the headline acts as a section intro, not a billboard. */
.app-main .greeting-card{background:linear-gradient(135deg,#eef7ff,#fff);padding:18px 22px;border-radius:18px;margin-bottom:14px;border:1px solid var(--line)}
.app-main .greeting-card h2{font-size:22px;margin:0 0 2px}
.app-main .greeting-card p{margin:0;font-size:13px;color:var(--slate)}

/* ====================================================================
   Dashboard widgets — Sophie-Martin mockup layout (2026-05-12).
   Scoped to .app-main so the landing page is untouched. Each rule is
   targeted via a `.dash-*` class on the element so the data-card chrome
   stays intact and we just layer the dashboard-specific finish on top.
   ==================================================================== */

/* Top-bar quick-action buttons (bell with red badge, lightning Quick Apps) */
.top-icon-btn{position:relative;width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--navy);transition:transform .15s ease,box-shadow .15s ease;padding:0}
.top-icon-btn:hover{transform:translateY(-1px);box-shadow:var(--soft-shadow)}
.top-icon-btn.lightning{background:linear-gradient(135deg,#eaf3ff,#dceeff);color:var(--blue);border-color:#cfe3ff}
.top-icon-btn .badge-dot{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:99px;background:var(--danger);color:#fff;font-size:10px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;border:2px solid #fff}

/* Hero greeting card with CrewMark-branded aircraft image */
/* Hero card. Image is positioned absolutely (see .dash-hero-img below) so it
   can extend into the card padding and touch the right/top/bottom edges of
   the card. The min-height keeps the card the same height the old fixed
   500×167 image used to give us, so the layout doesn't jump when the image
   loads. overflow:hidden + the parent's border-radius crops the image to the
   rounded corner on the right. */
.dash-hero{position:relative;display:flex;align-items:center;gap:20px;padding:22px 28px;border-radius:22px;margin-bottom:14px;background:radial-gradient(circle at 80% 30%,rgba(255,255,255,.65),transparent 50%),linear-gradient(135deg,#c7e5ff,#eef7ff 60%,#fff);overflow:hidden;border:1px solid rgba(255,255,255,.7);box-shadow:var(--soft-shadow);min-height:180px}
.dash-hero > div{position:relative;z-index:2;max-width:55%}
.dash-hero h2{font-size:28px;margin:0 0 4px;letter-spacing:-.02em}
.dash-hero p{color:#4a6680;margin:0;font-size:14px}
.dash-hero-airplane{width:230px;height:90px;color:#0b3a78;flex-shrink:0}
/* Photo variant — branded aircraft image as a scenic banner on the right side
   of the hero card. Matches the Emirates-style takeoff reference where the
   plane + clouds blend seamlessly into the card's light-blue gradient.

   Tuning notes (2026-05-12):
   - Bumped from 380→500px so the widebody reads at presence-matching scale.
   - Removed border-radius — the mask handles the soft edge; an inner radius
     was making it look like a card-within-a-card.
   - Extended the mask fade range to 0→45% (was 0→28%) so the clouds dissolve
     gradually into the card background rather than cutting off hard.
   - Slightly lighter drop-shadow because the mask itself softens the edges. */
.dash-hero-img{
  /* Anchor to the right/top/bottom of the hero card so the image touches the
     card edges instead of sitting inside the padding. width:62% sets how far
     left the image extends — the mask fades the left edge so the plane melts
     into the card's light-blue gradient rather than ending in a hard cutoff.
     pointer-events:none keeps clicks reaching anything underneath (future
     overlay buttons, etc.). The image is now sized by the card, so no fixed
     width / aspect-ratio / drop-shadow needed. */
  position:absolute;
  top:0;right:0;bottom:0;
  width:62%;height:100%;
  object-fit:cover;
  -webkit-mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.18) 15%,rgba(0,0,0,.6) 32%,#000 45%);
          mask-image:linear-gradient(to right,transparent 0%,rgba(0,0,0,.18) 15%,rgba(0,0,0,.6) 32%,#000 45%);
  pointer-events:none
}
@media(max-width:1100px){.dash-hero-airplane,.dash-hero-img{display:none}}

/* Standard dashboard card header (icon bubble + title, with optional link on the right) */
.dash-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.dash-card-head h3,.dash-card-head .title{display:flex;align-items:center;gap:8px;margin:0;text-transform:none;color:var(--navy);font-size:14px;letter-spacing:-.005em;font-weight:800}
.dash-card-head .icon-chip{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:9px;background:#eef7ff;color:var(--blue);flex-shrink:0}
.dash-card-head .icon-chip.teal{background:#e6fbf5;color:var(--teal)}
.dash-card-head .icon-chip.coral{background:#ffeae3;color:var(--coral)}
.dash-card-head .icon-chip.amber{background:#fff3d6;color:#a76500}
.dash-link{color:var(--blue);font-weight:800;font-size:12px}

/* 3-column grids for the dashboard rows */
.dash-grid-3{display:grid;grid-template-columns:1.25fr 1fr 1fr;gap:14px}
.dash-grid-3 + .dash-grid-3,
.dash-grid-3 + .dash-week-timeline,
.dash-week-timeline + .dash-grid-3{margin-top:14px}

/* Next Duty (blue gradient with airplane decoration in the corner) */
.dash-next-duty{position:relative;overflow:hidden;background:linear-gradient(135deg,#1078e6 0%,#0461d9 60%,#054a9e 100%);color:#fff;border:none}
.dash-next-duty::after{content:"";position:absolute;right:-30px;bottom:-25px;width:230px;height:140px;opacity:.16;background:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M22 16v-2l-8.5-5V3.5a1.5 1.5 0 0 0-3 0V9L2 14v2l8.5-2.5V19L8 20.5V22l4-1 4 1v-1.5L13.5 19v-5.5L22 16z'/%3E%3C/svg%3E") center/contain no-repeat;pointer-events:none}
.dash-next-duty-tag{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.18);color:#fff;font-size:11px;font-weight:800;padding:5px 10px;border-radius:99px;letter-spacing:.02em;backdrop-filter:blur(4px)}
.dash-next-duty .eyebrow{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.dash-next-duty h2{font-size:30px;color:#fff;margin:14px 0 4px;line-height:1.05;letter-spacing:-.015em}
.dash-next-duty .next-duty-sub{font-size:12px;color:rgba(255,255,255,.78);font-weight:700;letter-spacing:.02em;margin:0 0 16px}
.dash-next-duty .next-duty-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px;position:relative;z-index:2}
.dash-next-duty .next-duty-row label{display:block;font-size:10px;font-weight:800;letter-spacing:.08em;color:rgba(255,255,255,.65);text-transform:uppercase;margin-bottom:4px}
.dash-next-duty .next-duty-row .val{font-size:18px;font-weight:800;margin-bottom:3px;line-height:1.1}
.dash-next-duty .next-duty-row small{color:rgba(255,255,255,.7);font-size:11px}
.dash-next-duty .view-details{display:inline-block;margin-top:18px;color:#fff;font-size:13px;font-weight:800;position:relative;z-index:2}
.dash-next-duty .tag.ok{background:rgba(255,255,255,.2);color:#fff;font-size:10px;padding:3px 8px}

/* Legality Status — circular ring centered */
.dash-legality{text-align:left}
.dash-legality .ring-wrap{display:flex;justify-content:center;margin:4px 0 10px}
.dash-legality .ring{width:130px;height:130px;border-radius:50%;position:relative;background:conic-gradient(var(--teal) 0% 100%,#e9eef5 0%);display:grid;place-items:center}
.dash-legality .ring::after{content:"";position:absolute;inset:10px;background:#fff;border-radius:50%}
.dash-legality .ring-content{position:relative;z-index:2;text-align:center}
.dash-legality .ring-content .pct{font-size:24px;font-weight:800;color:var(--navy);line-height:1}
.dash-legality .ring-content .lbl{font-size:10px;font-weight:800;color:var(--slate);margin-top:2px;letter-spacing:.06em;text-transform:uppercase}
.dash-legality .legal-line{display:inline-flex;align-items:center;gap:6px;color:#087a68;font-weight:700;font-size:13px;margin:0 0 2px}

/* This Week Summary — icon+label+value rows */
.dash-week-rows .row{display:flex;align-items:center;gap:12px;padding:7px 0}
.dash-week-rows .row + .row{border-top:1px solid rgba(231,238,247,.6)}
.dash-week-rows .icon{width:28px;height:28px;border-radius:9px;background:#eef7ff;color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px}
.dash-week-rows .lbl{flex:1;font-size:13px;color:var(--slate);font-weight:600}
.dash-week-rows .val{font-weight:800;font-size:14px;color:var(--navy)}

/* Weekly Duty Timeline */
.dash-week-timeline-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.dash-week-nav{display:flex;align-items:center;gap:6px;background:#f8fbff;border:1px solid var(--line);border-radius:99px;padding:4px 10px;font-size:12px;font-weight:700}
.dash-week-nav button{background:none;border:none;color:var(--slate);cursor:pointer;padding:2px 6px;font-size:14px;line-height:1}
.dash-week-nav button:hover{color:var(--blue)}
.dash-week-days{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.dash-day-card{border:1px solid var(--line);border-radius:14px;padding:10px;text-align:left;position:relative;background:#fff;min-height:118px}
.dash-day-card.today{border-color:var(--blue);border-width:1.5px;background:#f1f7ff;box-shadow:0 0 0 4px rgba(22,135,255,.06)}
.dash-day-card.rest{background:#f8fbff}
.dash-day-dot{width:8px;height:8px;border-radius:50%;background:#d4dce8;margin-bottom:6px}
.dash-day-dot.duty{background:var(--success)}
.dash-day-dot.today{background:var(--blue)}
.dash-day-card .dow{font-size:10px;color:var(--slate);font-weight:800;letter-spacing:.05em;text-transform:uppercase}
.dash-day-card .dom{font-size:14px;font-weight:800;color:var(--navy);margin:2px 0 6px}
.dash-day-card .route{font-size:12px;font-weight:800;line-height:1.2;color:var(--navy)}
.dash-day-card .flight{font-size:10px;color:var(--slate);margin-top:2px;font-weight:700}
.dash-day-card .time{font-size:10px;color:var(--slate);margin-top:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.dash-day-card .pill{display:inline-block;padding:3px 8px;border-radius:99px;font-size:10px;font-weight:800;background:#e6fbf5;color:#087a68;margin-top:8px}
.dash-day-card .pill.rest-pill{background:#eef7ff;color:var(--blue)}
.dash-day-card .pill.off-pill{background:#f1f4f8;color:var(--slate)}

/* Swap Opportunities */
.dash-swap-item{display:grid;grid-template-columns:38px 1fr auto;gap:10px;align-items:center;padding:10px 0}
.dash-swap-item + .dash-swap-item{border-top:1px solid rgba(231,238,247,.7)}
.dash-swap-avatar{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;border:2px solid #fff;box-shadow:0 2px 6px rgba(7,27,51,.12)}
.dash-swap-avatar.a{background:linear-gradient(135deg,#1687ff,#0461d9)}
.dash-swap-avatar.b{background:linear-gradient(135deg,var(--coral),#ff5d3f)}
.dash-swap-avatar.c{background:linear-gradient(135deg,#00bfa6,#079a85)}
.dash-swap-item .top{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.dash-swap-route{font-size:13px;font-weight:800;color:var(--navy)}
.dash-swap-meta{font-size:11px;color:var(--slate);margin-top:2px;font-weight:600}
.dash-swap-by{font-size:11px;color:var(--slate);margin-top:1px;font-weight:600}
.dash-swap-actions .btn{padding:7px 12px;font-size:12px;border-radius:10px;box-shadow:none}

/* Quick Actions tiles */
.dash-quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dash-quick-tile{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border:1px solid var(--line);border-radius:14px;font-size:12px;font-weight:700;color:var(--navy);text-decoration:none;background:#fff;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;text-align:center}
.dash-quick-tile:hover{transform:translateY(-2px);border-color:#cfe3ff;box-shadow:var(--soft-shadow)}
.dash-quick-tile .icon-bubble{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,#eef7ff,#dceeff);color:var(--blue);display:inline-flex;align-items:center;justify-content:center}

/* Today's Briefing */
.dash-briefing-item{padding:10px 0}
.dash-briefing-item + .dash-briefing-item{border-top:1px solid rgba(231,238,247,.6)}
.dash-briefing-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}
.dash-briefing-head b{font-size:13px;color:var(--navy)}
.dash-briefing-body{font-size:12px;color:var(--slate);line-height:1.45;margin:0}
.dash-briefing-foot{font-size:11px;color:var(--slate);margin-top:12px;font-weight:700}
.tag.coral-pill{background:#ffeae3;color:#c54327}
.tag.teal-pill{background:#e6fbf5;color:#087a68}
.tag.amber-pill{background:#fff3d6;color:#a76500}

/* Document Alerts rows */
.dash-doc-row{display:grid;grid-template-columns:30px 1fr auto auto;gap:10px;align-items:center;padding:10px 0;cursor:pointer}
.dash-doc-row + .dash-doc-row{border-top:1px solid rgba(231,238,247,.6)}
.dash-doc-row .icon{width:30px;height:30px;border-radius:9px;background:#f1f4f8;display:inline-flex;align-items:center;justify-content:center;color:var(--slate)}
.dash-doc-row .name{font-size:13px;font-weight:800;color:var(--navy)}
.dash-doc-row .sub{font-size:11px;color:var(--slate);margin-top:1px;font-weight:600}
.dash-doc-row .chev{color:var(--slate);font-size:16px}

/* Offline Access */
.dash-offline-bar{width:100%;height:6px;background:#e7eef7;border-radius:99px;overflow:hidden;margin:10px 0 6px}
.dash-offline-bar > div{height:100%;background:linear-gradient(90deg,var(--teal),var(--success));border-radius:99px}

/* Weather card */
.dash-weather-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.dash-weather-city{font-size:14px;font-weight:800;color:var(--navy)}
.dash-weather-city small{display:block;color:var(--slate);font-size:11px;font-weight:700;margin-top:2px}
.dash-weather-temp{font-size:30px;font-weight:800;color:var(--navy);line-height:1}
.dash-weather-cond{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--slate);margin-top:10px;font-weight:700}
.dash-weather-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;font-size:11px;color:var(--slate);margin-top:12px;font-weight:600}
.dash-weather-stats div{text-align:center}

/* Footer banner — 4-up feature strip at the bottom */
.dash-footer-banner{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px 22px;margin-top:14px;box-shadow:var(--soft-shadow)}
.dash-footer-item{display:flex;align-items:center;gap:12px;font-size:12px;font-weight:700}
.dash-footer-item .icon{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,#eef7ff,#dceeff);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-footer-item .icon.teal{background:linear-gradient(135deg,#e6fbf5,#caf3e6);color:var(--teal)}
.dash-footer-item .icon.coral{background:linear-gradient(135deg,#ffeae3,#ffd0c2);color:var(--coral)}
.dash-footer-item .icon.indigo{background:linear-gradient(135deg,#e3e8ff,#cfd8ff);color:#5a6cdf}
.dash-footer-item b{display:block;color:var(--navy);font-weight:800;font-size:13px}
.dash-footer-item small{display:block;color:var(--slate);font-size:11px;font-weight:700;margin-top:1px}

@media(max-width:1200px){.dash-grid-3{grid-template-columns:1fr 1fr}.dash-footer-banner{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.dash-grid-3,.dash-footer-banner{grid-template-columns:1fr}.dash-week-days{grid-template-columns:repeat(4,1fr)}}

/* ====================================================================
   Roster page — month nav, week strip, duty cards, daily timeline,
   sidebar action stacks. Sophie-Martin mockup (2026-05-12).
   ==================================================================== */

/* Calendar header — month nav + Today/Week/Month toggle */
.roster-cal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.roster-cal-month{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:800;letter-spacing:-.01em}
.roster-cal-month button{background:none;border:none;cursor:pointer;color:var(--slate);font-size:18px;padding:4px 8px;line-height:1;border-radius:8px}
.roster-cal-month button:hover{background:#f1f4f8;color:var(--blue)}
.roster-view-toggle{display:flex;align-items:center;gap:4px;background:#f1f4f8;border-radius:12px;padding:4px}
.roster-view-toggle button{background:none;border:none;cursor:pointer;padding:6px 14px;font-size:12px;font-weight:800;color:var(--slate);border-radius:8px;transition:all .12s ease}
.roster-view-toggle button.active{background:var(--blue);color:#fff;box-shadow:0 1px 4px rgba(22,135,255,.3)}
.roster-view-toggle .icon-btn{background:#fff;border:1px solid var(--line);width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;margin-left:6px}

/* Week strip — same look as dashboard day cards */
.roster-week-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}

/* Filters bar */
.roster-filters{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap}
.roster-filter-pill{padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;display:inline-flex;flex-direction:column;gap:2px;min-width:110px;font-size:12px;font-weight:700;color:var(--navy);cursor:pointer}
.roster-filter-pill small{color:var(--slate);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.roster-filter-pill select{border:none;background:none;font-size:12px;font-weight:800;color:var(--navy);padding:0;outline:none}
.roster-filter-btn{padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:13px;font-weight:800;display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:var(--navy)}
.roster-filter-btn .count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:var(--blue);color:#fff;border-radius:99px;font-size:10px;font-weight:800}
.roster-filter-btn.refresh{width:42px;height:42px;padding:0;justify-content:center}

/* Week overview header */
.roster-overview-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.roster-overview-head .left{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.roster-overview-head h3{margin:0;font-size:15px;text-transform:none;color:var(--navy);letter-spacing:-.005em}
.roster-overview-head .range{font-size:12px;color:var(--slate);font-weight:700}
.roster-overview-head .totals{font-size:12px;color:var(--slate);font-weight:700}

/* Duty row — date column on the left + duty card on the right */
.roster-duty-row{display:grid;grid-template-columns:80px 1fr;gap:14px;align-items:flex-start;padding:14px 0;border-top:1px solid rgba(231,238,247,.5)}
.roster-duty-row:first-of-type{border-top:none}
.roster-duty-date{text-align:center;padding-top:8px}
.roster-duty-date .dot{width:8px;height:8px;border-radius:50%;background:var(--success);margin:0 auto 6px}
.roster-duty-date .dot.rest{background:var(--blue)}
.roster-duty-date .dow{font-size:10px;color:var(--slate);font-weight:800;letter-spacing:.05em;text-transform:uppercase}
.roster-duty-date .dom{font-size:22px;font-weight:800;color:var(--navy);line-height:1;margin:2px 0}
.roster-duty-date .mon{font-size:11px;color:var(--slate);font-weight:700;text-transform:uppercase}
.roster-duty-date .pill{display:inline-block;margin-top:6px;padding:3px 10px;border-radius:99px;font-size:10px;font-weight:800;background:#e6fbf5;color:#087a68}
.roster-duty-date .pill.rest-pill{background:#eef7ff;color:var(--blue)}
.roster-duty-date .pill.off-pill{background:#f1f4f8;color:var(--slate)}

/* Duty card */
.roster-duty-card{background:#f8fbff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}
.roster-duty-card:hover{border-color:#cfe3ff;box-shadow:var(--soft-shadow)}
.roster-duty-card-head{display:flex;align-items:baseline;gap:14px;margin-bottom:12px;flex-wrap:wrap}
.roster-duty-card-head .ek{font-size:11px;font-weight:800;letter-spacing:.05em;color:var(--slate);text-transform:uppercase}
.roster-duty-card-head .route{font-size:20px;font-weight:800;color:var(--navy);margin:0;letter-spacing:-.015em;line-height:1.1}
.roster-duty-card-head .time{font-size:13px;font-weight:800;color:var(--navy);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;margin-left:auto}
.roster-duty-card-head .block-sub{font-size:11px;color:var(--slate);font-weight:700}
.roster-duty-card-head .dots-menu{background:none;border:none;cursor:pointer;color:var(--slate);font-size:18px;padding:0 6px;line-height:1}

/* 4-col meta tile inside the duty card */
.roster-duty-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:10px}
.roster-duty-meta > div{padding:0 12px;border-right:1px solid var(--line)}
.roster-duty-meta > div:last-child{border-right:none}
.roster-duty-meta > div:first-child{padding-left:0}
.roster-duty-meta label{display:block;font-size:10px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);margin-bottom:4px}
.roster-duty-meta .val{font-size:14px;font-weight:800;color:var(--navy);line-height:1.1}
.roster-duty-meta .sub{display:block;font-size:11px;color:var(--slate);font-weight:600;margin-top:2px}

/* 3-col sub-grid (Hotel/Transport/Notes) */
.roster-duty-sub{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.roster-duty-sub .sub-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:10px;font-size:12px}
.roster-duty-sub .sub-card .ic{width:28px;height:28px;border-radius:8px;background:#eef7ff;color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.roster-duty-sub .sub-card .text{flex:1;min-width:0}
.roster-duty-sub .sub-card .text b{display:block;font-size:10px;color:var(--slate);font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}
.roster-duty-sub .sub-card .text .name{font-size:12px;font-weight:800;color:var(--navy);line-height:1.2}
.roster-duty-sub .sub-card .text .meta{display:block;color:var(--slate);font-size:11px;margin-top:2px;font-weight:600}

/* Rest day card */
.roster-rest-card{background:linear-gradient(180deg,#f1f7ff,#f8fbff);border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.roster-rest-card .text h2{font-size:18px;margin:0 0 4px;letter-spacing:-.01em}
.roster-rest-card .text p{margin:0;color:var(--slate);font-size:13px}
.roster-rest-card .illu{width:120px;height:80px;color:var(--blue);opacity:.55;flex-shrink:0}

/* Daily Timeline */
.roster-daily-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin:18px 0 10px;flex-wrap:wrap}
.roster-daily-head h3{margin:0;font-size:14px;text-transform:none;color:var(--navy);letter-spacing:-.005em}
.roster-daily-events{position:relative;padding-left:100px}
.roster-daily-events::before{content:"";position:absolute;left:92px;top:18px;bottom:18px;width:2px;background:#d4dce8}
.roster-event{position:relative;display:grid;grid-template-columns:36px 1fr auto;gap:12px;align-items:center;padding:10px 0}
.roster-event .ev-time{position:absolute;left:-100px;width:80px;text-align:right;font-size:13px;font-weight:800;color:var(--navy);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.roster-event::after{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--success);border:3px solid #fff;box-shadow:0 0 0 1px #cfd9e5}
.roster-event.posit::after{background:var(--blue)}
.roster-event.svc::after{background:var(--coral)}
.roster-event .ic{width:30px;height:30px;border-radius:9px;background:#eef7ff;color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.roster-event .content{display:flex;flex-direction:column;gap:2px;min-width:0}
.roster-event .content b{font-size:13px;color:var(--navy)}
.roster-event .content span{font-size:12px;color:var(--slate);font-weight:600}
.roster-event .right{text-align:right;font-size:11px;color:var(--slate);font-weight:700;display:flex;flex-direction:column;gap:2px}
.roster-event .right .status{color:var(--teal)}

/* Aside cards (Quick Actions, Export & Sync, Legalities mini) */
.roster-aside-row{display:grid;grid-template-columns:36px 1fr auto;gap:12px;align-items:center;padding:10px 0;cursor:pointer;color:var(--navy);text-decoration:none}
.roster-aside-row + .roster-aside-row{border-top:1px solid rgba(231,238,247,.6)}
.roster-aside-row .icon{width:36px;height:36px;border-radius:11px;background:#eef7ff;color:var(--blue);display:inline-flex;align-items:center;justify-content:center}
.roster-aside-row .icon.coral{background:#ffeae3;color:var(--coral)}
.roster-aside-row .icon.teal{background:#e6fbf5;color:var(--teal)}
.roster-aside-row .icon.amber{background:#fff3d6;color:#a76500}
.roster-aside-row b{display:block;font-size:13px;font-weight:800}
.roster-aside-row small{display:block;font-size:11px;color:var(--slate);font-weight:600;margin-top:1px}
.roster-aside-row .chev{color:var(--slate);font-size:16px}

.roster-summary-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.roster-summary-head h3{margin:0;font-size:15px;text-transform:none;color:var(--navy);letter-spacing:-.005em}
.roster-summary-head .period{font-size:11px;color:var(--slate);font-weight:700}
.roster-summary-head .dl{background:none;border:1px solid var(--line);border-radius:8px;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;color:var(--slate);cursor:pointer}

@media(max-width:1200px){.roster-duty-meta{grid-template-columns:1fr 1fr}.roster-duty-meta > div{border-right:none}.roster-duty-sub{grid-template-columns:1fr}.roster-overview-head .totals{margin-left:0}}
@media(max-width:900px){.roster-duty-row{grid-template-columns:60px 1fr}}

/* ====================================================================
   Legalities page — 4 status cards, tabs, limit progress, rolling table,
   compliance checks, rule explanation, swap impact checker.
   ==================================================================== */

/* Page header — title + subtitle on the left, actions on the right */
.app-main .page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.app-main .page-head h1{margin:0}
.app-main .page-head .subtitle{margin:2px 0 0;font-size:13px;color:var(--slate);font-weight:600}
.app-main .page-head .actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* 4-up status strip — coloured per status */
.legal-status-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.legal-status-card{position:relative;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:#fff;box-shadow:var(--soft-shadow);overflow:hidden}
.legal-status-card .ic{width:36px;height:36px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:8px}
.legal-status-card.ok{background:linear-gradient(180deg,#e6fbf5,#fff);border-color:#cef2e3}
.legal-status-card.ok .ic{background:var(--teal);color:#fff}
.legal-status-card.info{background:linear-gradient(180deg,#eef7ff,#fff);border-color:#cfe3ff}
.legal-status-card.info .ic{background:var(--blue);color:#fff}
.legal-status-card.warn{background:linear-gradient(180deg,#fff3d6,#fff);border-color:#f0d999}
.legal-status-card.warn .ic{background:#ffba3a;color:#fff}
.legal-status-card.breach{background:linear-gradient(180deg,#ffe9e7,#fff);border-color:#f7c9c5}
.legal-status-card.breach .ic{background:var(--danger);color:#fff}
.legal-status-card h3{margin:0 0 4px;font-size:14px;text-transform:none;color:var(--navy);letter-spacing:-.005em}
.legal-status-card .value{font-size:22px;font-weight:800;color:var(--navy);line-height:1;margin:4px 0}
.legal-status-card .meta{font-size:11px;color:var(--slate);font-weight:600;margin:2px 0 0}
.legal-status-card .meta b{color:var(--navy);font-weight:800}
.legal-status-card .barwrap{width:100%;height:6px;background:#e7eef7;border-radius:99px;overflow:hidden;margin:10px 0 4px}
.legal-status-card .barwrap > div{height:100%;background:linear-gradient(90deg,var(--blue),var(--teal));border-radius:99px}
.legal-status-card .barwrap.warn > div{background:linear-gradient(90deg,#ffba3a,#ff7a4a)}
.legal-status-card .barwrap.breach > div{background:linear-gradient(90deg,#ff7a4a,var(--danger))}
.legal-status-card a{color:var(--blue);font-weight:800;font-size:12px;display:inline-block;margin-top:6px}

/* Tabs (Overview / FTL Checks / Rules & Guidance / History) */
.legal-tabs{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.legal-tabs .tabs{display:flex;gap:6px}
.legal-tabs button{background:none;border:none;cursor:pointer;font-size:13px;font-weight:800;color:var(--slate);padding:10px 14px;border-bottom:2px solid transparent;letter-spacing:-.005em}
.legal-tabs button.active{color:var(--blue);border-bottom-color:var(--blue)}
.legal-tabs .updated{font-size:11px;color:var(--slate);font-weight:600;display:inline-flex;align-items:center;gap:4px;padding:8px 0}

/* Limit progress card (Flight Time Limits / Duty Time Limits / Rest Reqs) */
.legal-limit-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:14px}
.legal-limit-card h3{display:flex;align-items:center;gap:6px;margin:0 0 12px;font-size:14px;text-transform:none;color:var(--navy);letter-spacing:-.005em}
.legal-limit-card h3 small{color:var(--slate);font-size:11px;font-weight:700;margin-left:4px}
.legal-limit-card h3 .info-i{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#eef7ff;color:var(--blue);font-size:9px;font-weight:800;margin-left:4px}
.legal-limit{margin-bottom:14px}
.legal-limit-head{display:flex;align-items:baseline;justify-content:space-between;font-size:12px;font-weight:700;color:var(--navy);margin-bottom:4px}
.legal-limit-head .pct{font-size:12px;font-weight:800;font-family:ui-monospace,monospace}
.legal-limit-head .pct.ok{color:var(--teal)}
.legal-limit-head .pct.warn{color:#a76500}
.legal-limit-head .pct.breach{color:var(--danger)}
.legal-limit-bar{width:100%;height:6px;background:#e7eef7;border-radius:99px;overflow:hidden}
.legal-limit-bar > div{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--teal),var(--success))}
.legal-limit-bar.warn > div{background:linear-gradient(90deg,#ffba3a,#ff7a4a)}
.legal-limit-bar.breach > div{background:linear-gradient(90deg,#ff7a4a,var(--danger))}
.legal-card-foot{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#087a68;font-weight:700;margin-top:6px;padding-top:10px;border-top:1px solid rgba(231,238,247,.7);flex-wrap:wrap;gap:6px}
.legal-card-foot a{color:var(--blue);font-weight:800}
.legal-card-foot.warn{color:#a76500}
.legal-card-foot.breach{color:var(--danger)}

/* Rolling Totals table */
.legal-rolling-table{width:100%;border-collapse:separate;border-spacing:0}
.legal-rolling-table th{text-align:left;font-size:11px;font-weight:800;letter-spacing:.04em;color:var(--slate);text-transform:uppercase;padding:10px 12px;border-bottom:1px solid var(--line)}
.legal-rolling-table td{padding:14px 12px;border-bottom:1px solid rgba(231,238,247,.5);font-size:13px;color:var(--navy);font-weight:700}
.legal-rolling-table td .pct{font-weight:800;font-family:ui-monospace,monospace;font-size:12px;margin-left:8px}
.legal-rolling-table td .pct.ok{color:var(--teal)}
.legal-rolling-table td .pct.warn{color:#a76500}
.legal-rolling-table td .pct.breach{color:var(--danger)}
.legal-rolling-table tr:last-child td{border-bottom:none}

/* Compliance Checks list */
.legal-check-row{display:flex;align-items:center;gap:10px;padding:9px 0;font-size:13px;font-weight:700;color:var(--navy)}
.legal-check-row + .legal-check-row{border-top:1px solid rgba(231,238,247,.6)}
.legal-check-row .ic{width:20px;height:20px;border-radius:50%;background:#e6fbf5;color:var(--teal);display:inline-flex;align-items:center;justify-content:center}
.legal-check-row .lbl{flex:1}
.legal-check-row .status{font-size:11px;font-weight:800;padding:3px 10px;border-radius:99px;background:#e6fbf5;color:#087a68}
.legal-check-row.warn .ic{background:#fff3d6;color:#a76500}
.legal-check-row.warn .status{background:#fff3d6;color:#a76500}
.legal-check-row.breach .ic{background:#ffe9e7;color:var(--danger)}
.legal-check-row.breach .status{background:#ffe9e7;color:#b5483b}

/* Rule Explanation card */
.legal-rule-card{background:linear-gradient(180deg,#f8fbff,#fff)}
.legal-rule-card h4{margin:14px 0 4px;font-size:13px;color:var(--navy)}
.legal-rule-card h4:first-of-type{margin-top:0}
.legal-rule-card p{margin:0 0 6px;font-size:13px;color:var(--slate);line-height:1.55}
.legal-rule-card ul{margin:6px 0 0;padding-left:18px;font-size:13px;color:var(--slate);line-height:1.7}
.legal-rule-card ul li b{color:var(--navy);font-weight:700}

/* Swap Impact Checker */
.legal-swap-impact{display:grid;grid-template-columns:1.1fr auto 1fr 1fr;gap:14px;align-items:stretch;margin-top:8px}
.legal-swap-impact .proposed{background:#f8fbff;border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.legal-swap-impact .proposed .head{font-size:11px;font-weight:800;letter-spacing:.04em;color:var(--slate);text-transform:uppercase;margin-bottom:8px}
.legal-swap-impact .proposed .leg{padding:8px 0}
.legal-swap-impact .proposed .leg + .leg{border-top:1px solid rgba(231,238,247,.6)}
.legal-swap-impact .proposed .leg .date{font-size:11px;color:var(--slate);font-weight:700;margin-bottom:2px}
.legal-swap-impact .proposed .leg .route{font-size:14px;font-weight:800;color:var(--navy);margin-bottom:2px}
.legal-swap-impact .proposed .leg .meta{display:flex;gap:14px;font-size:11px;color:var(--slate);font-weight:600}
.legal-swap-impact .proposed .leg .meta b{color:var(--navy);display:block}
.legal-swap-impact .arrow{align-self:center;color:var(--slate);font-size:22px}
.legal-swap-impact .verdict{background:linear-gradient(180deg,#e6fbf5,#fff);border:1px solid #cef2e3;border-radius:14px;padding:14px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}
.legal-swap-impact .verdict .big{font-size:36px;line-height:1;color:var(--teal)}
.legal-swap-impact .verdict b{font-size:14px;color:#087a68}
.legal-swap-impact .verdict p{margin:0;font-size:12px;color:var(--slate);font-weight:600}
.legal-swap-impact .verdict a{color:var(--blue);font-weight:800;font-size:12px;margin-top:4px}
.legal-swap-impact .impact-summary{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.legal-swap-impact .impact-summary .head{font-size:11px;font-weight:800;letter-spacing:.04em;color:var(--slate);text-transform:uppercase;margin-bottom:8px}
.legal-swap-impact .impact-summary .row{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding:6px 0;font-size:12px}
.legal-swap-impact .impact-summary .row + .row{border-top:1px solid rgba(231,238,247,.5)}
.legal-swap-impact .impact-summary .row .lbl{color:var(--slate);font-weight:700}
.legal-swap-impact .impact-summary .row .delta{font-weight:800;color:var(--teal);font-family:ui-monospace,monospace}
.legal-swap-impact .impact-summary .row .total{color:var(--navy);font-weight:800;font-family:ui-monospace,monospace}

@media(max-width:1200px){.legal-status-row{grid-template-columns:1fr 1fr}.legal-limit-row{grid-template-columns:1fr}.legal-swap-impact{grid-template-columns:1fr}.legal-swap-impact .arrow{text-align:center;transform:rotate(90deg)}}
@media(max-width:720px){.legal-status-row{grid-template-columns:1fr}}

/* ====================================================================
   Swap Market — tabs, banner, filter row, listings table, detail panel,
   pros/cons, compatibility ring, crew notes.
   ==================================================================== */

/* Tabs row */
.swap-tabs-row{display:flex;align-items:center;gap:0;margin-bottom:14px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.swap-tabs-row button{background:none;border:none;cursor:pointer;font-size:13px;font-weight:800;color:var(--slate);padding:10px 16px;border-bottom:2px solid transparent;letter-spacing:-.005em;display:inline-flex;align-items:center;gap:6px}
.swap-tabs-row button.active{color:var(--blue);border-bottom-color:var(--blue)}
.swap-tabs-row button .badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:99px;background:var(--blue);color:#fff;font-size:10px;font-weight:800;margin-left:2px}

/* Info banner with × close */
.swap-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;background:linear-gradient(180deg,#eef7ff,#fff);border:1px solid #cfe3ff;border-radius:14px;margin-bottom:14px}
.swap-banner .ic{width:38px;height:38px;border-radius:11px;background:#fff;color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--soft-shadow)}
.swap-banner .text b{font-size:14px;color:var(--navy)}
.swap-banner .text p{margin:2px 0 0;font-size:12px;color:var(--slate);font-weight:600}
.swap-banner a{margin-left:auto;color:var(--blue);font-weight:800;font-size:13px;white-space:nowrap}
.swap-banner button.close{background:none;border:none;cursor:pointer;color:var(--slate);font-size:16px;padding:4px 8px}

/* Filter row (search + filter pill + sort) */
.swap-filter-bar{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.swap-search{flex:1;min-width:260px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-size:13px;color:var(--slate);display:flex;align-items:center;gap:8px}
.swap-search input{flex:1;border:none;background:transparent;outline:none;font-size:13px;color:var(--navy);font-weight:600}

/* Sub-filter pills row */
.swap-subfilter{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}

/* Swap table */
.swap-table{width:100%;border-collapse:separate;border-spacing:0}
.swap-table th{text-align:left;font-size:10px;font-weight:800;letter-spacing:.05em;color:var(--slate);text-transform:uppercase;padding:10px 12px;border-bottom:1px solid var(--line);background:#fff}
.swap-table td{padding:14px 12px;border-bottom:1px solid rgba(231,238,247,.5);font-size:13px;color:var(--navy);font-weight:700;vertical-align:middle;background:#fff}
.swap-table tr{cursor:pointer;transition:background-color .12s ease}
.swap-table tr.selected td{background:#eef7ff}
.swap-table tr:not(.selected):hover td{background:#f8fbff}
.swap-table .route{font-size:13px;font-weight:800;color:var(--navy);margin-bottom:2px}
.swap-table .date{font-size:11px;color:var(--slate);font-weight:600}
.swap-table .crew{display:flex;align-items:center;gap:8px}
.swap-table .crew .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--coral));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;box-shadow:0 2px 4px rgba(7,27,51,.12)}
.swap-table .crew .name{font-size:12px;font-weight:800;color:var(--navy)}
.swap-table .crew .role{font-size:10px;color:var(--slate);font-weight:600;margin-top:1px}

/* Match score circular gauge */
.match-gauge{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;position:relative;font-size:11px;font-weight:800;color:var(--navy)}
.match-gauge::after{content:"";position:absolute;inset:4px;border-radius:50%;background:#fff}
.match-gauge span{position:relative;z-index:2}

/* Detail panel — right column when a swap is selected */
.swap-detail{padding:18px 20px}
.swap-detail .back{display:inline-flex;align-items:center;gap:6px;color:var(--slate);font-size:12px;font-weight:700;cursor:pointer;background:none;border:none;padding:0;margin-bottom:12px}
.swap-detail .back:hover{color:var(--blue)}
.swap-detail .head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}
.swap-detail .head h2{margin:0;font-size:18px;letter-spacing:-.01em}
.swap-detail .head .close{background:none;border:none;cursor:pointer;color:var(--slate);font-size:18px;padding:0 4px}
.swap-detail .posted{font-size:11px;color:var(--slate);font-weight:600;margin:0 0 14px}

.swap-detail-section{margin-bottom:16px}
.swap-detail-section h4{margin:0 0 8px;font-size:13px;color:var(--navy);font-weight:800;letter-spacing:-.005em}
.swap-detail-card{background:#f8fbff;border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.swap-detail-card .duty-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:6px}
.swap-detail-card .duty-route{font-size:16px;font-weight:800;color:var(--navy);letter-spacing:-.01em}
.swap-detail-card .duty-ek{font-size:11px;font-weight:800;color:var(--slate);letter-spacing:.04em}
.swap-detail-card .duty-date{font-size:12px;color:var(--slate);font-weight:700;margin-bottom:10px}
.swap-detail-card .duty-date .ontime{display:inline-block;margin-left:6px;padding:2px 8px;background:#e6fbf5;color:#087a68;border-radius:99px;font-size:10px;font-weight:800}
.swap-detail-card .meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 0}
.swap-detail-card .meta-grid > div{padding:0 12px;border-right:1px solid var(--line)}
.swap-detail-card .meta-grid > div:last-child{border-right:none}
.swap-detail-card .meta-grid label{display:block;font-size:9px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);margin-bottom:2px}
.swap-detail-card .meta-grid .val{font-size:12px;font-weight:800;color:var(--navy);line-height:1.1}
.swap-detail-card .meta-grid .sub{display:block;font-size:10px;color:var(--slate);font-weight:600;margin-top:1px}

/* Legality check (green card) */
.swap-legality{background:linear-gradient(180deg,#e6fbf5,#fff);border:1px solid #cef2e3;border-radius:12px;padding:14px}
.swap-legality b{display:block;color:#087a68;font-size:14px;font-weight:800}
.swap-legality p{margin:2px 0 6px;font-size:12px;color:var(--slate);font-weight:600}
.swap-legality a{color:var(--blue);font-weight:800;font-size:12px}

/* Pros & Cons */
.swap-proscons{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.swap-proscons .pros{background:#f8fbff;border:1px solid #cef2e3;border-radius:10px;padding:10px 12px}
.swap-proscons .cons{background:#fff;border:1px solid #ffeae3;border-radius:10px;padding:10px 12px}
.swap-proscons h5{margin:0 0 6px;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;gap:4px}
.swap-proscons .pros h5{color:#087a68}
.swap-proscons .cons h5{color:#c54327}
.swap-proscons ul{margin:0;padding:0;list-style:none}
.swap-proscons li{display:flex;align-items:flex-start;gap:6px;padding:3px 0;font-size:11px;font-weight:600;color:var(--navy)}
.swap-proscons .pros li::before{content:"✓";color:var(--teal);font-weight:800;width:12px;flex-shrink:0}
.swap-proscons .cons li::before{content:"✕";color:var(--coral);font-weight:800;width:12px;flex-shrink:0}

/* Compatibility ring */
.swap-compat{display:flex;align-items:center;gap:14px;background:#f8fbff;border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.swap-compat .ring{width:72px;height:72px;border-radius:50%;position:relative;display:grid;place-items:center;flex-shrink:0;background:conic-gradient(var(--teal) 0 96%,#e7eef7 0)}
.swap-compat .ring::after{content:"";position:absolute;inset:7px;background:#fff;border-radius:50%}
.swap-compat .ring span{position:relative;z-index:2;font-size:16px;font-weight:800;color:var(--navy)}
.swap-compat .text b{display:block;font-size:13px;color:var(--navy)}
.swap-compat .text p{margin:2px 0 0;font-size:11px;color:var(--slate);font-weight:600;line-height:1.4}
.swap-compat .text a{color:var(--blue);font-weight:800;font-size:11px}

/* Crew notes */
.swap-notes{background:#f8fbff;border-left:3px solid var(--blue);border-radius:0 10px 10px 0;padding:10px 14px;font-style:italic;font-size:12px;color:var(--navy);line-height:1.5}
.swap-notes .author{font-style:normal;font-weight:800;color:var(--slate);font-size:11px;margin-top:4px}

/* Footer actions for the detail panel */
.swap-actions{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.swap-actions .btn{width:100%;justify-content:center}
.swap-actions .report{text-align:center;color:var(--slate);font-size:11px;text-decoration:none;margin-top:4px;font-weight:700}

/* Pagination footer */
.swap-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:12px;font-size:12px;color:var(--slate);font-weight:600}
.swap-pagination .pages{display:flex;gap:4px}
.swap-pagination .pages button{background:#fff;border:1px solid var(--line);border-radius:8px;width:28px;height:28px;font-size:12px;font-weight:700;cursor:pointer;color:var(--navy)}
.swap-pagination .pages button.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.swap-pagination .pages button.nav{color:var(--slate)}

/* "Can't find the right swap" footer */
.swap-cta{display:flex;align-items:center;gap:14px;padding:14px 18px;background:linear-gradient(180deg,#eef7ff,#fff);border:1px solid #cfe3ff;border-radius:14px;margin-top:14px}
.swap-cta .ic{width:38px;height:38px;border-radius:11px;background:#fff;color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--soft-shadow)}
.swap-cta .text b{font-size:14px;color:var(--navy)}
.swap-cta .text p{margin:2px 0 0;font-size:12px;color:var(--slate);font-weight:600}
.swap-cta .btn{margin-left:auto;flex-shrink:0}

@media(max-width:1100px){.swap-proscons{grid-template-columns:1fr}.swap-detail-card .meta-grid{grid-template-columns:1fr 1fr}}

/* ====================================================================
   Settings page — profile, subscription, linked devices, preferences,
   privacy, connected apps, support, CrewMark footer card.
   ==================================================================== */

/* Large profile card */
.settings-profile{padding:18px 20px}
.settings-profile-head{display:flex;align-items:center;gap:18px;margin-bottom:14px}
.settings-avatar-wrap{position:relative;flex-shrink:0}
.settings-avatar{width:96px;height:96px;border-radius:18px;background:linear-gradient(135deg,var(--blue),var(--coral));object-fit:cover;box-shadow:var(--soft-shadow)}
.settings-avatar-edit{position:absolute;bottom:-4px;right:-4px;width:28px;height:28px;border-radius:50%;background:var(--blue);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 6px rgba(7,27,51,.2)}
.settings-profile-head h2{font-size:22px;margin:0 0 6px;letter-spacing:-.015em}
.settings-profile-head .role-pill{background:#eef7ff;color:var(--blue);padding:4px 10px;border-radius:99px;font-size:12px;font-weight:800;display:inline-block}

/* Settings list row — generic row used across multiple cards */
.settings-row{display:grid;grid-template-columns:30px 1fr auto;gap:12px;align-items:center;padding:11px 0}
.settings-row + .settings-row{border-top:1px solid rgba(231,238,247,.6)}
.settings-row .ic{width:30px;height:30px;border-radius:9px;background:#eef7ff;color:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.settings-row .ic.coral{background:#ffeae3;color:var(--coral)}
.settings-row .ic.teal{background:#e6fbf5;color:var(--teal)}
.settings-row .ic.amber{background:#fff3d6;color:#a76500}
.settings-row .ic.slate{background:#f1f4f8;color:var(--slate)}
.settings-row .label{font-size:13px;font-weight:800;color:var(--navy);line-height:1.2}
.settings-row .label small{display:block;font-size:11px;color:var(--slate);font-weight:600;margin-top:2px}
.settings-row .right{display:inline-flex;align-items:center;gap:8px;color:var(--slate);font-size:12px;font-weight:700}
.settings-row .right .chev{color:var(--slate);font-size:14px}
.settings-row.action{cursor:pointer}
.settings-row.action:hover{background:#f8fbff}

/* iOS-style toggle switch (visual only — wire to data layer where needed) */
.toggle{display:inline-block;width:38px;height:22px;background:#cfd9e5;border-radius:99px;position:relative;cursor:pointer;transition:background-color .15s ease;flex-shrink:0}
.toggle::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.15);transition:transform .15s ease}
.toggle.on{background:linear-gradient(135deg,var(--blue),var(--teal))}
.toggle.on::after{transform:translateX(16px)}

/* Subscription / Linked Devices badges */
.settings-pill{padding:3px 10px;border-radius:99px;font-size:11px;font-weight:800;display:inline-block}
.settings-pill.active{background:#e6fbf5;color:#087a68}
.settings-pill.connected{background:#e6fbf5;color:#087a68}
.settings-pill.current{background:#e6fbf5;color:#087a68}
.settings-pill.warn{background:#fff3d6;color:#a76500}
.settings-pill.blue{background:#eef7ff;color:var(--blue)}

/* Subscription/MFA value layouts */
.settings-line{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px;color:var(--navy);font-weight:700}
.settings-line .lbl{color:var(--slate);font-weight:700;font-size:13px}
.settings-line .val{font-weight:800}

/* CrewMark footer brand card */
.settings-brand{background:linear-gradient(135deg,#eef7ff,#fff);position:relative;overflow:hidden;padding:24px}
.settings-brand img{width:54px;height:54px;border-radius:14px;margin-bottom:10px}
.settings-brand h3{margin:0 0 2px;font-size:22px;text-transform:none;color:var(--navy);letter-spacing:-.015em}
.settings-brand .tagline{font-size:12px;color:var(--coral);font-weight:800;margin-bottom:14px}
.settings-brand .version{font-size:13px;color:var(--navy);font-weight:800;margin-bottom:2px}
.settings-brand .version-sub{font-size:11px;color:var(--slate);font-weight:600;display:flex;align-items:center;gap:8px}
.settings-brand .decoration{position:absolute;right:-20px;bottom:-30px;color:var(--blue);opacity:.1;width:200px;height:140px}

@media(max-width:1100px){.app-main .app-grid{grid-template-columns:1fr}}
