:root {
    --orb-ink: #0d1f22;
    --orb-paper: #FFFFFF;
    --orb-veil: #f4fbfa;
    --orb-accent: #4b7554;
    --orb-accent-2: #17c837;
    --orb-text: #1a403e;
    --orb-text-dim: #5b8378;
    --orb-radius-xl: 22px;
    --orb-radius: 14px;
    --orb-gap: clamp(12px, 2vw, 24px);
    --orb-maxw: 1280px;
    --font-head: "Chivo", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif;
    --font-body: "Overpass", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
}

*,
*::before,
*::after {
    box-sizing: border-box
}

html:focus-within {
    scroll-behavior: smooth
}

html,
body {
    height: 100%
}

body {
    margin: 0;
    background: var(--orb-paper);
    color: var(--orb-text);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img,
picture,
svg,
video,
canvas {
    display: block;
    max-width: 100%;
    height: auto
}

iframe {
    border: 0
}

input,
button,
textarea,
select {
    font: inherit;
    color: inherit
}

a {
    color: inherit;
    text-decoration: none
}

ul[role="list"],
ol[role="list"] {
    list-style: none;
    margin: 0;
    padding: 0
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
figure {
    margin: 0
}

::selection {
    background: #DDE4FF;
    color: var(--orb-ink)
}

[hidden] {
    display: none !important
}

h1,
.h1 {
    font-family: var(--font-head);
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -0.01em
}

h2,
.h2 {
    font-family: var(--font-head);
    font-weight: 800;
    line-height: 1.18;
    letter-spacing: -0.005em
}

h3,
.h3 {
    font-family: var(--font-head);
    font-weight: 600;
    line-height: 1.22
}

.lead {
    font-size: clamp(1.05rem, 0.85rem + 0.5vw, 1.25rem);
    color: var(--orb-text-dim)
}

.containerorb {
    width: min(100% - 2*var(--orb-gap), var(--orb-maxw));
    margin-inline: auto
}

.stack-y>*+* {
    margin-top: var(--orb-gap)
}

.stack-x {
    display: flex;
    gap: var(--orb-gap);
    align-items: center
}

.is-visually-hidden {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0
}

@media (prefers-reduced-motion:reduce) {
    html:focus-within {
        scroll-behavior: auto
    }

    * {
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .001ms !important
    }
}

body {
    background:
        radial-gradient(1200px 600px at 10% -10%, #EEF2FF 0%, transparent 50%),
        radial-gradient(900px 500px at 110% 10%, #E8FFF8 0%, transparent 55%),
        var(--orb-paper);
    color: var(--orb-text);
}

.crestlinenav {
    background: #fff;
    border-bottom: 1px solid #eceff6
}

.crestlinenavwrap {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    min-height: 66px
}

.crestlinenavbrand {
    display: inline-flex;
    align-items: baseline;
    gap: 10px
}

.crestlinenavlogo {
    font-family: var(--font-head);
    font-weight: 800;
    font-size: clamp(1.125rem, 0.9rem + 1vw, 1.6rem);
    letter-spacing: .4px;
    line-height: 1;
    background:
        linear-gradient(92deg, #0e7a56 0%, #e1bc19 55%, #d27aff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow: 0 0 .01px rgba(0, 0, 0, 0.01);
}

.crestlinenavtag {
    font-family: var(--font-body);
    font-weight: 600;
    font-size: .85rem;
    padding: .28rem .5rem;
    border-radius: 999px;
    background:
        linear-gradient(135deg, #0e7a560d 0%, #611bc20d 100%);
    color: #31595a;
    border: 1px solid #e7ebf6;
}

.lusitanohero {
    position: relative;
    min-height: clamp(320px, 42vh, 520px);
    display: flex;
    align-items: center;
    background: url('../tron-img/atlantic-texture.jpg')
}

.lusitanoherooverlay {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(900px 480px at 10% -10%, rgba(9, 18, 15, 0.7) 0%, transparent 55%),
    radial-gradient(780px 420px at 110% 10%, rgba(9, 18, 17, 0.6) 0%, transparent 60%),
    linear-gradient(180deg, rgba(9, 18, 15, 0.18), rgba(9, 18, 15, 0.36));
  mix-blend-mode:multiply;
}

.lusitanoheroinner {
    position: relative;
    z-index: 1;
    padding: clamp(28px, 4vw, 56px) 0
}

.lusitanoherotitle {
    color: #fff;
    text-wrap: balance
}

.lusitanoherolead {
    color: #e9ecf7;
    max-width: 62ch;
    margin-top: 12px
}

@media (max-width:720px) {
    .crestlinenavtag {
        display: none
    }

    .lusitanoherolead {
        margin-top: 10px
    }
}

.meridiancatalog {
    padding: clamp(28px, 4vw, 52px) 0;
    background: radial-gradient(960px 480px at -10% 0%, rgba(13,18,34,.08) 0%, transparent 60%),
  radial-gradient(840px 420px at 110% 10%, rgba(13,18,34,.10) 0%, transparent 62%),
  linear-gradient(180deg, #f7faff 0%, #eef3fb 100%);;
}

.meridiancataloghead {
    display: grid;
    gap: 8px
}

.meridiancatalogtitle {
    display: flex;
    align-items: center;
    gap: 10px
}

.meridiancatalogtitle .bi {
    font-size: 1.1em;
    transform: translateY(1px)
}

.meridiancatalognote {
    color: #1f3b2c;
    font-weight: 600;
    font-size: .95rem;
    background: linear-gradient(135deg, #e7fff3, #eaf5ff);
    border: 1px solid #eaf2d9;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: .35rem .7rem;
    width: fit-content
}

.meridiancatalogstamp {
    color: #6b9094;
    font-size: .86rem
}

.crowncard {
    display: grid;
    grid-template-columns: 1fr 1.2fr 1.2fr .9fr;
    gap: clamp(14px, 2vw, 22px);
    padding: clamp(16px, 2.2vw, 26px);
    border-radius: var(--orb-radius-xl);
    background:
        linear-gradient(135deg, #0e6a1312 0%, #771bc212 60%, #d0d83a12 100%),
        #fff;
    border: 1px solid #f3fbec;
    box-shadow: 0 10px 24px rgba(23, 32, 68, .06), inset 0 1px 0 rgba(255, 255, 255, 0.697);
    align-items: center;
}

.crowncardcollogo {
    display: grid;
    align-content: center;
    justify-content: center;
    gap: 10px
}

.crowncardlogo {
    filter: drop-shadow(0 4px 10px rgba(0, 0, 0, .08))
}

.crowncardbadge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .2px;
    color: #165a46;
    background: linear-gradient(135deg, #e2f7df, #f6ebff);
    border: 1px solid #d6eecf;
    border-radius: 999px;
    padding: .28rem .55rem
}

.crowncardname {
    color: #0d1f22;
    text-align: center;
}

.crowncardstars {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 8px;
    color: #f2e71e
}

.crowncardstars .bi-star-fill,
.crowncardstars .bi-star-fill {
    font-size: 1.05rem
}

.crowncardscore {
    color: #386450;
    font-weight: 700;
    margin-left: 4px
}

.crowncardvotes {
    color: #5b836f;
    font-size: .9rem;
    margin-top: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px
}

.crowncardlist {
    display: grid;
    gap: 10px
}

.crowncardperk {
    display: flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(135deg, #eef2ff, #f5f9ff);
    border: 1px solid #e3e9ff;
    border-radius: 14px;
    padding: .55rem .7rem;
    color: #1a403e;
    font-weight: 600
}

.crowncardperk .bi-award {
    color: #38b978
}

.crowncardperk .bi-lock-fill {
    color:  #0ea755;
}

.crowncardperk .bi-gift-fill {
    color: #a61bc2
}

.crowncardcolcta {
    display: flex;
    justify-content: flex-end
}

.crowncardbtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 160px;
    padding: .9rem 1.2rem;
    border-radius: 16px;
    background: linear-gradient(92deg, #0e7a56 0%, #a61bc2 55%, #d0d83a 100%);
    color: #fff;
    font-weight: 800;
    letter-spacing: .2px;
    box-shadow: 0 10px 20px rgba(15, 88, 64, .18);
    transition: transform .2s ease, box-shadow .2s ease, filter .2s ease
}

.crowncardbtn:focus-visible {
    outline: 2px solid #d0d83a;
    outline-offset: 2px
}

.crowncardbtn:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 26px rgba(15, 88, 64, .22)
}

@media (max-width:1100px) {
    .crowncard {
        grid-template-columns: 1fr 1fr
    }

    .crowncardcolcta {
        justify-content: center;
    }
}

@media (max-width:720px) {
    .crowncard {
        grid-template-columns: 1fr;
        gap: 14px
    }

    .crowncardbtn {
        width: 100%
    }
}

.fadoinsight {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding: clamp(32px, 5vw, 72px) 0;
    background: #ffffff00;
    border-top: 1px solid transparent;
}

.fadoinsight::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(800px 420px at 0% 0%, #eef2ff 0%, transparent 60%),
        radial-gradient(1000px 520px at 100% 0%, #e8fff8 0%, transparent 62%),
        linear-gradient(180deg, #ffffff, #ffffff);
    min-height: 100%;
    pointer-events: none;
}

.fadoinsightwrap {
    position: relative
}

.fadoinsighthead {
    display: grid;
    gap: 10px;
    margin-bottom: clamp(18px, 2.6vw, 28px)
}

.fadoinsighttitle {
    display: flex;
    align-items: center;
    gap: 10px
}

.fadoinsighttitle .bi-compass-fill {
    font-size: 1.1em;
    transform: translateY(1px)
}

.fadoinsightsubtitle {
    color: #467a5d;
    max-width: 78ch
}

.fadoinsightgrid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(16px, 2.2vw, 26px)
}

.fadocard {
    border-radius: var(--orb-radius-xl);
    background: #fff;
    border: 1px solid #ecfbf5;
    box-shadow: 0 14px 28px rgba(23, 68, 66, 0.06), inset 0 1px 0 rgba(255, 255, 255, .7);
    padding: clamp(16px, 2vw, 24px);
    display: grid;
    gap: 12px
}

.fadocardheading {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #0d1f22
}

.fadocardheading i {
    color: #38b978
}

.fadocard p {
    color: #336657
}

.fadocard strong {
    color: #0e353c
}

.fadocardlist {
    display: grid;
    gap: 10px;
    margin-top: 2px
}

.fadocarditem {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    background: linear-gradient(135deg, #f6f8ff, #f9fbff);
    border: 1px solid #f8e6ff;
    border-radius: 14px;
    padding: .55rem .7rem;
    color: #1a403e
}

.fadocarditem i {
    min-width: 1.1rem;
    text-align: center;
    color: #38b978;
    transform: translateY(2px)
}

.fadometer {
    display: grid;
    gap: 8px;
    margin-top: 8px
}

.fadometerbar {
    display: block;
    width: calc(var(--w, 20%) * 1%);
    max-width: 100%;
    padding: .45rem .6rem;
    border-radius: 12px;
    color: #05bb02;
    font-weight: 700;
    background: linear-gradient(90deg, #0e7a56 0%, #a61bc2 55%, #d0d83a 100%);
    opacity: .8;
    position: relative
}

.fadosteps {
    display: grid;
    gap: 10px;
    margin-top: 2px;
    counter-reset: fado
}

.fadostepsrow {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    background: linear-gradient(135deg, #f7eeff, #fcf5ff);
    border: 1px solid #fbdfff;
    border-radius: 14px;
    padding: .6rem .75rem;
    color: #1a403e
}

.fadostepsrow i {
    color: #0ea755;
    transform: translateY(1px)
}

.fadocallout {
    margin-top: 10px;
    background: linear-gradient(135deg, #faffe6, #f3fff0);
    border: 1px solid #f4ffb8;
    color: #5b2700;
    border-radius: 14px;
    padding: .7rem .8rem
}

.fadocallout a {
    color: #8a3e00;
    text-decoration: underline
}

@media (max-width:1100px) {
    .fadoinsightgrid {
        grid-template-columns: 1fr 1fr
    }
}

@media (max-width:720px) {
    .fadoinsightgrid {
        grid-template-columns: 1fr
    }
}

.atlanticfooter {
    background: #0d1f22;
    color: #e9f7f1;
    padding: clamp(32px, 5vw, 64px) 0;
    margin-top: clamp(32px, 6vw, 80px);
}

.atlanticfooterwrap {
    display: grid;
    gap: clamp(18px, 2.5vw, 28px);
    text-align: center
}

.atlanticfooterbrand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px
}

.atlanticfooterlogo {
    font-family: var(--font-head);
    font-weight: 800;
    font-size: clamp(1.2rem, 0.9rem + 1vw, 1.7rem);
    background: linear-gradient(92deg, #0e7a56 0%, #a61bc2 55%, #d0d83a 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.atlanticfootertag {
    font-size: .85rem;
    font-weight: 600;
    color: #cfd3e8
}

.atlanticfooterdisclaimer {
    max-width: 72ch;
    margin-inline: auto;
    font-size: .95rem;
    line-height: 1.5
}

.atlanticfooterads {
    margin-top: 8px;
    font-size: .85rem;
    color: #cde0d6
}

.atlanticfooterwarn {
    color: #ffe047;
    font-weight: 700
}

.atlanticfooterlinks {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(14px, 2vw, 24px);
    justify-content: center;
    align-items: center
}

.atlanticfooterlinks img {
    height: 38px;
    width: auto;
    transition: filter .25s
}

.atlanticfooterlinks a:hover img {
    filter: grayscale(0%) brightness(110%) contrast(100%)
}

.atlanticfooternav {
    display: flex;
    gap: 24px;
    justify-content: center;
    margin-top: 6px
}

.atlanticfooternav a {
    color: #cfe8d6;
    font-size: .9rem;
    transition: color .25s
}

.atlanticfooternav a:hover {
    color: #fff
}

.atlanticfootercopy {
    font-size: .85rem;
    color: #9ebead;
    margin-top: 6px
}

.cavicookie {
    position: fixed;
    inset: auto 0 0 0;
    z-index: 70
}

.cavicookie[hidden] {
    display: none
}

.cavicookiebar {
    margin: clamp(8px, 2vw, 14px);
    padding: clamp(12px, 2vw, 16px);
    border-radius: 16px;
    background:
        linear-gradient(135deg, #0e7a560d 0%, #bb20da0d 60%, #d0d83a0d 100%),
        #ffffff;
    border: 1px solid #e6e9f5;
    box-shadow: 0 10px 28px rgba(23, 68, 55, 0.12);
    display: flex;
    gap: clamp(12px, 2vw, 18px);
    align-items: center;
    justify-content: space-between
}

.cavicookietext {
    color: #2a5158;
    font-size: .95rem;
    line-height: 1.5
}

.cavicookietext a {
    color: #38b978;
    text-decoration: underline
}

.cavicookieactions {
    display: flex;
    gap: 10px;
    flex-shrink: 0
}

.cavicookiebtn {
    appearance: none;
    border: 0;
    cursor: pointer;
    border-radius: 12px;
    padding: .6rem .9rem;
    font-weight: 800;
    letter-spacing: .2px
}

.cavicookiebtnreject {
    background: #f4f7ff;
    border: 1px solid #e5eafc;
    color: #2d6653
}

.cavicookiebtnreject:hover {
    filter: brightness(0.97)
}

.cavicookiebtnallow {
    background: linear-gradient(92deg, #0e7a56 0%, #a61bc2 55%, #d0d83a 100%);
    color: #fff;
    box-shadow: 0 10px 20px rgba(15, 88, 64, .18)
}

.cavicookiebtnallow:hover {
    transform: translateY(-1px)
}

@media (max-width:720px) {
    .cavicookiebar {
        flex-direction: column;
        align-items: stretch
    }

    .cavicookieactions {
        justify-content: space-between
    }
}

.auroraagegate {
    position: fixed;
    inset: 0;
    z-index: 80
}

.auroraagegate[hidden] {
    display: none
}

.auroraagegatebackdrop {
    position: absolute;
    inset: 0;
    background: rgba(13, 34, 33, 0.6);
    backdrop-filter: saturate(120%) blur(6px)
}

.auroraagegatedialog {
    position: relative;
    z-index: 1;
    width: min(96%, 560px);
    margin-inline: auto;
    margin-top: 10vh;
    border-radius: 20px;
    padding: clamp(18px, 3vw, 24px);
    background:
        radial-gradient(120% 120% at 0% 0%, #eef2ff 0%, transparent 55%),
        radial-gradient(120% 120% at 100% 0%, #e8fff8 0%, transparent 55%),
        #fff;
    border: 1px solid #e6ebf8;
    box-shadow: 0 24px 60px rgba(13, 34, 30, 0.35), inset 0 1px 0 rgba(255, 255, 255, .8);
    outline: 0
}

.auroraagegatehead {
    margin-bottom: 6px
}

.auroraagegatetitle {
    color: #0d1f22
}

.auroraagegatebody {
    color: #34644d;
    line-height: 1.6;
    margin-top: 6px
}

.auroraagegatebody a {
    color: #38b978;
    text-decoration: underline
}

.auroraagegateactions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 14px;
    flex-wrap: wrap
}

.auroraagegatebtn {
    appearance: none;
    border: 0;
    border-radius: 12px;
    cursor: pointer;
    padding: .7rem 1rem;
    font-weight: 800;
    letter-spacing: .2px
}

.auroraagegatebtnno {
    background: #fff3f3;
    border: 1px solid #ffe8d8;
    color: #c52c2c
}

.auroraagegatebtnno:hover {
    filter: brightness(.98)
}

.auroraagegatebtnyes {
    background: linear-gradient(92deg, #0e7a56 0%, #a61bc2 55%, #d0d83a 100%);
    color: #fff;
    box-shadow: 0 10px 20px rgba(15, 88, 64, .18)
}

.auroraagegatebtnyes:hover {
    transform: translateY(-1px)
}

.auroraagegatenote {
    margin-top: 8px;
    color: #669a70;
    font-size: .85rem;
    text-align: center
}

@media (max-width:520px) {
    .auroraagegateactions {
        justify-content: stretch
    }

    .auroraagegatebtn {
        flex: 1 1 auto
    }
}

body.is-agegateopen {
    overflow: hidden
}