/* ===========================================================================
   Altifero Nexus — Editorial · SRIJ Portugal
   Design system: "Atlântico / Azulejo"  (emerald + gold + ivory + cobalt)
   Prefix: .an-   ·  Fonts: Fraunces (display) + Manrope (body)
   =========================================================================== */

/* ---- Fonts ---------------------------------------------------------------- */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('../../fonts/fraunces-v38-latin-600.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('../../fonts/fraunces-v38-latin-700.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:900;font-display:swap;src:url('../../fonts/fraunces-v38-latin-900.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:600;font-display:swap;src:url('../../fonts/fraunces-v38-latin-600italic.woff2') format('woff2');}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('../../fonts/manrope-v20-latin-500.woff2') format('woff2');}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('../../fonts/manrope-v20-latin-600.woff2') format('woff2');}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('../../fonts/manrope-v20-latin-700.woff2') format('woff2');}
@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('../../fonts/manrope-v20-latin-800.woff2') format('woff2');}

/* ---- Tokens --------------------------------------------------------------- */
:root{
  /* base */
  --an-bg:        #F4EEE2;
  --an-bg-2:      #ECE3D2;
  --an-bg-3:      #E2D6C0;
  --an-surface:   #FCF9F2;
  --an-surface-2: #F7F1E5;
  --an-line:      #DCD0BA;
  --an-line-soft: #E8DECB;

  /* ink / text */
  --an-ink:       #0E1A15;
  --an-ink-2:     #14241D;
  --an-text:      #1C2B24;
  --an-text-soft: #4A5A50;
  --an-text-mut:  #79877D;
  --an-inv:       #F4EEE2;
  --an-inv-soft:  #C7D6CC;

  /* brand accents */
  --an-em:        #0F7A57;   /* emerald primary  */
  --an-em-deep:   #0A5A40;
  --an-em-bright: #14A87A;
  --an-em-glow:   rgba(20,168,122,.22);
  --an-gold:      #C29A2C;   /* gold secondary   */
  --an-gold-soft: #E0C374;
  --an-gold-deep: #9B7A1E;
  --an-cobalt:    #235C86;   /* azulejo cobalt   */
  --an-cobalt-soft:#3C7AAB;

  /* feedback */
  --an-good:      #0F7A57;
  --an-warn:      #B5621A;
  --an-bad:       #A53227;

  /* gradients / atmosphere */
  --an-ink-grad:  linear-gradient(157deg,#0C1812 0%,#102A1F 52%,#0A1E16 100%);
  --an-em-grad:   linear-gradient(135deg,#14A87A,#0A5A40);
  --an-gold-grad: linear-gradient(135deg,#E6CC83,#C29A2C);
  --an-mesh:      radial-gradient(60% 70% at 78% 18%, rgba(20,168,122,.22), transparent 60%),
                  radial-gradient(50% 60% at 12% 90%, rgba(194,154,44,.16), transparent 60%);

  /* shadows / glow */
  --an-sh-sm:  0 1px 2px rgba(14,26,21,.05), 0 2px 8px rgba(14,26,21,.05);
  --an-sh:     0 .5em 1.6em rgba(14,26,21,.09);
  --an-sh-lg:  0 1.2em 3em rgba(14,26,21,.16);
  --an-sh-em:  0 .8em 2em rgba(15,122,87,.20);
  --an-ring:   0 0 0 4px rgba(15,122,87,.18);

  /* radii */
  --an-r-xl: 1.7rem;
  --an-r-lg: 1.15rem;
  --an-r:    .8rem;
  --an-r-sm: .5rem;
  --an-r-pill: 999px;

  /* type */
  --an-ff-d: 'Fraunces', Georgia, 'Times New Roman', serif;
  --an-ff-b: 'Manrope', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --an-fz-h1: clamp(2.5rem, 5.6vw, 4.4rem);
  --an-fz-h2: clamp(1.95rem, 3.8vw, 3rem);
  --an-fz-h3: clamp(1.4rem, 2.4vw, 1.8rem);
  --an-fz-h4: clamp(1.15rem, 1.7vw, 1.35rem);
  --an-fz-lg: 1.14rem;
  --an-fz-sm: .92rem;
  --an-fz-xs: .8rem;

  /* motion */
  --an-ease: cubic-bezier(.4,0,.2,1);
  --an-ease-out: cubic-bezier(.16,1,.3,1);
  --an-dur: .3s;

  /* layout */
  --an-wrap: 1200px;
  --an-wrap-narrow: 920px;
  --an-wrap-wide: 1340px;
  --an-head-h: 4.6rem;
}

/* ---- Reset ---------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none !important}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-padding-top:calc(var(--an-head-h) + 1rem)}
body{
  margin:0;min-height:100vh;
  font-family:var(--an-ff-b);font-weight:500;font-size:1rem;line-height:1.62;
  color:var(--an-text);background:var(--an-bg);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%}
h1,h2,h3,h4{margin:0;font-family:var(--an-ff-d);font-weight:700;line-height:1.1;color:var(--an-ink);letter-spacing:-.01em}
h1 em,h2 em,h3 em{font-style:italic;font-weight:600;color:var(--an-em)}
p{margin:0 0 1rem}
a{color:var(--an-em);text-decoration:none;transition:color var(--an-dur) var(--an-ease)}
a:hover{color:var(--an-em-deep)}
ul,ol{margin:0;padding:0;list-style:none}
button{font-family:inherit;font-size:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
strong{font-weight:700;color:var(--an-ink-2)}
:focus-visible{outline:none;box-shadow:var(--an-ring);border-radius:var(--an-r-sm)}
::selection{background:var(--an-em);color:#fff}

/* ---- Icon helper (svg via mask -> currentColor) ---------------------------
   Per-icon mask-image classes (.i-name). URLs live in THIS stylesheet so they
   resolve relative to /assets/css/ consistently across all browsers — avoids
   the url()-in-custom-property resolution bug that turned icons into squares. */
.an-ico{display:inline-block;width:1.15em;height:1.15em;flex:none;background-color:currentColor;
  -webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;vertical-align:-.18em}
.an-ico--sm{width:1em;height:1em}
.an-ico--lg{width:1.5em;height:1.5em}

.i-alert-triangle{-webkit-mask-image:url(../icons/alert-triangle.svg);mask-image:url(../icons/alert-triangle.svg)}
.i-arrow-right{-webkit-mask-image:url(../icons/arrow-right.svg);mask-image:url(../icons/arrow-right.svg)}
.i-badge-check{-webkit-mask-image:url(../icons/badge-check.svg);mask-image:url(../icons/badge-check.svg)}
.i-ban{-webkit-mask-image:url(../icons/ban.svg);mask-image:url(../icons/ban.svg)}
.i-banknote{-webkit-mask-image:url(../icons/banknote.svg);mask-image:url(../icons/banknote.svg)}
.i-calendar{-webkit-mask-image:url(../icons/calendar.svg);mask-image:url(../icons/calendar.svg)}
.i-check{-webkit-mask-image:url(../icons/check.svg);mask-image:url(../icons/check.svg)}
.i-chevron-down{-webkit-mask-image:url(../icons/chevron-down.svg);mask-image:url(../icons/chevron-down.svg)}
.i-chevron-right{-webkit-mask-image:url(../icons/chevron-right.svg);mask-image:url(../icons/chevron-right.svg)}
.i-circle-check{-webkit-mask-image:url(../icons/circle-check.svg);mask-image:url(../icons/circle-check.svg)}
.i-clock{-webkit-mask-image:url(../icons/clock.svg);mask-image:url(../icons/clock.svg)}
.i-cookie{-webkit-mask-image:url(../icons/cookie.svg);mask-image:url(../icons/cookie.svg)}
.i-credit-card{-webkit-mask-image:url(../icons/credit-card.svg);mask-image:url(../icons/credit-card.svg)}
.i-external-link{-webkit-mask-image:url(../icons/external-link.svg);mask-image:url(../icons/external-link.svg)}
.i-eye{-webkit-mask-image:url(../icons/eye.svg);mask-image:url(../icons/eye.svg)}
.i-file-text{-webkit-mask-image:url(../icons/file-text.svg);mask-image:url(../icons/file-text.svg)}
.i-gauge{-webkit-mask-image:url(../icons/gauge.svg);mask-image:url(../icons/gauge.svg)}
.i-gift{-webkit-mask-image:url(../icons/gift.svg);mask-image:url(../icons/gift.svg)}
.i-globe{-webkit-mask-image:url(../icons/globe.svg);mask-image:url(../icons/globe.svg)}
.i-headphones{-webkit-mask-image:url(../icons/headphones.svg);mask-image:url(../icons/headphones.svg)}
.i-heart{-webkit-mask-image:url(../icons/heart.svg);mask-image:url(../icons/heart.svg)}
.i-info{-webkit-mask-image:url(../icons/info.svg);mask-image:url(../icons/info.svg)}
.i-list{-webkit-mask-image:url(../icons/list.svg);mask-image:url(../icons/list.svg)}
.i-lock{-webkit-mask-image:url(../icons/lock.svg);mask-image:url(../icons/lock.svg)}
.i-mail{-webkit-mask-image:url(../icons/mail.svg);mask-image:url(../icons/mail.svg)}
.i-map-pin{-webkit-mask-image:url(../icons/map-pin.svg);mask-image:url(../icons/map-pin.svg)}
.i-message-square{-webkit-mask-image:url(../icons/message-square.svg);mask-image:url(../icons/message-square.svg)}
.i-percent{-webkit-mask-image:url(../icons/percent.svg);mask-image:url(../icons/percent.svg)}
.i-phone{-webkit-mask-image:url(../icons/phone.svg);mask-image:url(../icons/phone.svg)}
.i-refresh-cw{-webkit-mask-image:url(../icons/refresh-cw.svg);mask-image:url(../icons/refresh-cw.svg)}
.i-scale{-webkit-mask-image:url(../icons/scale.svg);mask-image:url(../icons/scale.svg)}
.i-search{-webkit-mask-image:url(../icons/search.svg);mask-image:url(../icons/search.svg)}
.i-send{-webkit-mask-image:url(../icons/send.svg);mask-image:url(../icons/send.svg)}
.i-shield-check{-webkit-mask-image:url(../icons/shield-check.svg);mask-image:url(../icons/shield-check.svg)}
.i-sliders{-webkit-mask-image:url(../icons/sliders.svg);mask-image:url(../icons/sliders.svg)}
.i-smartphone{-webkit-mask-image:url(../icons/smartphone.svg);mask-image:url(../icons/smartphone.svg)}
.i-sparkles{-webkit-mask-image:url(../icons/sparkles.svg);mask-image:url(../icons/sparkles.svg)}
.i-star{-webkit-mask-image:url(../icons/star.svg);mask-image:url(../icons/star.svg)}
.i-trending-up{-webkit-mask-image:url(../icons/trending-up.svg);mask-image:url(../icons/trending-up.svg)}
.i-trophy{-webkit-mask-image:url(../icons/trophy.svg);mask-image:url(../icons/trophy.svg)}
.i-user-check{-webkit-mask-image:url(../icons/user-check.svg);mask-image:url(../icons/user-check.svg)}
.i-x{-webkit-mask-image:url(../icons/x.svg);mask-image:url(../icons/x.svg)}
.i-zap{-webkit-mask-image:url(../icons/zap.svg);mask-image:url(../icons/zap.svg)}

/* ---- Layout --------------------------------------------------------------- */
.an-wrap{width:100%;max-width:var(--an-wrap);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.an-wrap--narrow{max-width:var(--an-wrap-narrow)}
.an-wrap--wide{max-width:var(--an-wrap-wide)}
.an-section{padding-block:clamp(3.5rem,7vw,6rem)}
.an-section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.an-section--ink{position:relative;background:var(--an-ink-grad);color:var(--an-inv-soft);overflow:hidden;isolation:isolate}
.an-section--ink::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--an-mesh)}
.an-section--photo{position:relative;isolation:isolate}
.an-section--photo>.an-secphoto{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;opacity:.16}
.an-section--photo::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(157deg,rgba(12,24,18,.92),rgba(10,30,22,.82))}
.an-section--ink h1,.an-section--ink h2,.an-section--ink h3,.an-section--ink h4{color:var(--an-inv)}
.an-section--ink strong{color:#fff}
.an-section--cream{background:var(--an-surface-2)}

/* azulejo tile motif (decorative seamless pattern) */
.an-azulejo{
  background-image:
    radial-gradient(circle at 0 0, transparent 67%, var(--an-cobalt) 68% 71%, transparent 72%),
    radial-gradient(circle at 100% 0, transparent 67%, var(--an-cobalt) 68% 71%, transparent 72%),
    radial-gradient(circle at 0 100%, transparent 67%, var(--an-cobalt) 68% 71%, transparent 72%),
    radial-gradient(circle at 100% 100%, transparent 67%, var(--an-cobalt) 68% 71%, transparent 72%),
    radial-gradient(circle at 50% 50%, var(--an-cobalt) 0 6%, transparent 7%);
  background-size:44px 44px;background-position:0 0;opacity:.06;
}

/* ---- Buttons -------------------------------------------------------------- */
.an-btn{
  display:inline-flex;align-items:center;gap:.55em;
  padding:.85em 1.5em;border-radius:var(--an-r-pill);
  font-family:var(--an-ff-b);font-weight:700;font-size:.98rem;letter-spacing:.005em;
  background:var(--an-em);color:#fff;
  border:2px solid var(--an-em);
  box-shadow:var(--an-sh-em);
  transition:transform var(--an-dur) var(--an-ease-out),box-shadow var(--an-dur) var(--an-ease),background var(--an-dur) var(--an-ease);
  cursor:pointer;text-align:center;
}
.an-btn:hover{background:var(--an-em-deep);border-color:var(--an-em-deep);color:#fff;transform:translateY(-2px);box-shadow:var(--an-sh-lg)}
.an-btn .an-ico{transition:transform var(--an-dur) var(--an-ease-out)}
.an-btn:hover .an-ico{transform:translateX(3px)}
.an-btn--gold{background:var(--an-gold);border-color:var(--an-gold);color:var(--an-ink);box-shadow:0 .7em 1.8em rgba(194,154,44,.28)}
.an-btn--gold:hover{background:var(--an-gold-deep);border-color:var(--an-gold-deep);color:#fff}
.an-btn--ghost{background:transparent;color:var(--an-em-deep);border-color:var(--an-line)}
.an-btn--ghost:hover{background:var(--an-surface);border-color:var(--an-em);color:var(--an-em-deep);box-shadow:var(--an-sh)}
.an-btn--ink{background:var(--an-ink);border-color:var(--an-ink);color:#fff;box-shadow:none}
.an-btn--ink:hover{background:#000;border-color:#000}
.an-btn--sm{padding:.6em 1.05em;font-size:.86rem}
.an-btn--lg{padding:1em 1.9em;font-size:1.05rem}
.an-btn--block{display:flex;width:100%;justify-content:center}

/* ---- Chips / eyebrows ----------------------------------------------------- */
.an-chip{
  display:inline-flex;align-items:center;gap:.5em;
  padding:.4em .9em;border-radius:var(--an-r-pill);
  font-size:.76rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  background:rgba(15,122,87,.1);color:var(--an-em-deep);border:1px solid rgba(15,122,87,.2)
}
.an-chip--gold{background:rgba(194,154,44,.14);color:var(--an-gold-deep);border-color:rgba(194,154,44,.3)}
.an-chip--ink{background:rgba(255,255,255,.08);color:var(--an-inv);border-color:rgba(255,255,255,.18)}
.an-eyebrow{font-size:.78rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--an-em)}

/* ---- Section header ------------------------------------------------------- */
.an-sec{margin-bottom:clamp(2rem,4vw,3rem);max-width:760px}
.an-sec--center{margin-inline:auto;text-align:center}
.an-sec__top{display:flex;align-items:center;gap:.8rem;margin-bottom:1.1rem}
.an-sec--center .an-sec__top{justify-content:center}
.an-sec__rule{height:2px;width:48px;background:linear-gradient(90deg,var(--an-em),var(--an-gold));border-radius:2px}
.an-sec__title{font-size:var(--an-fz-h2);margin-bottom:.6rem}
.an-sec__lead{font-size:var(--an-fz-lg);color:var(--an-text-soft);max-width:62ch}
.an-sec--center .an-sec__lead{margin-inline:auto}

/* =====  Preloader  ===== */
.an-pre{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:var(--an-ink);transition:opacity .5s ease,visibility .5s ease}
.an-pre.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.an-pre__mark{width:64px;height:64px;animation:an-float 2.4s var(--an-ease) infinite}
.an-pre__ring{position:absolute;width:108px;height:108px;border-radius:50%;
  border:2px solid rgba(224,195,116,.18);border-top-color:var(--an-gold);animation:an-spin 1s linear infinite}
@keyframes an-spin{to{transform:rotate(360deg)}}
@keyframes an-float{50%{transform:translateY(-7px)}}
html.an-loading{overflow:hidden}
@media(prefers-reduced-motion:reduce){.an-pre__ring,.an-pre__mark{animation-duration:3s}}

/* =====  Header  ===== */
.an-header{position:sticky;top:0;z-index:900;background:var(--an-bg);
  border-bottom:1px solid transparent;transition:box-shadow var(--an-dur),border-color var(--an-dur),background var(--an-dur)}
.an-header.is-scrolled{box-shadow:var(--an-sh-sm);border-color:var(--an-line);background:rgba(244,238,226,.92);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.an-topbar{background:var(--an-ink);color:var(--an-inv-soft);font-size:.78rem;font-weight:600}
.an-topbar__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:2.3rem;padding-block:.35rem}
.an-topbar__cell{display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap}
.an-topbar__18{display:inline-grid;place-items:center;min-width:1.7rem;height:1.4rem;padding-inline:.3rem;
  border-radius:.35rem;background:var(--an-gold);color:var(--an-ink);font-weight:800;font-size:.72rem}
.an-topbar__18 sup{font-size:.6em}
.an-topbar__link{display:inline-flex;align-items:center;gap:.4rem;color:var(--an-gold-soft);font-weight:700}
.an-topbar__link:hover{color:#fff}
.an-topbar__srij{height:1rem;width:auto;opacity:.85}
.an-nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:var(--an-head-h)}
.an-logo{display:inline-flex;align-items:center;gap:.7rem}
.an-logo__mark{width:42px;height:42px;flex:none}
.an-logo__text{display:flex;flex-direction:column;line-height:1.05}
.an-logo__word{font-family:var(--an-ff-d);font-weight:900;font-size:1.32rem;color:var(--an-ink);letter-spacing:-.02em}
.an-logo__sub{font-size:.66rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--an-em)}
.an-nav__list{display:flex;align-items:center;gap:.3rem}
.an-nav__link{position:relative;display:inline-block;padding:.55rem .85rem;border-radius:var(--an-r-sm);
  font-weight:700;font-size:.95rem;color:var(--an-text)}
.an-nav__link::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.32rem;height:2px;
  background:var(--an-em);transform:scaleX(0);transform-origin:left;transition:transform var(--an-dur) var(--an-ease-out);border-radius:2px}
.an-nav__link:hover{color:var(--an-em-deep)}
.an-nav__link:hover::after,.an-nav__link.is-active::after{transform:scaleX(1)}
.an-nav__link.is-active{color:var(--an-em-deep)}
.an-nav__actions{display:flex;align-items:center;gap:.6rem}
.an-burger{display:none;width:2.6rem;height:2.6rem;border-radius:var(--an-r-sm);border:1px solid var(--an-line);
  background:var(--an-surface);position:relative}
.an-burger__lines,.an-burger__lines::before,.an-burger__lines::after{position:absolute;left:50%;height:2px;width:1.2rem;
  background:var(--an-ink);border-radius:2px;transition:transform var(--an-dur),opacity var(--an-dur)}
.an-burger__lines{top:50%;transform:translate(-50%,-50%)}
.an-burger__lines::before{content:"";transform:translate(-50%,-6px)}
.an-burger__lines::after{content:"";transform:translate(-50%,6px)}

/* drawer */
.an-scrim{position:fixed;inset:0;z-index:950;background:rgba(14,26,21,.5);opacity:0;visibility:hidden;
  transition:opacity var(--an-dur),visibility var(--an-dur);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.an-scrim.is-open{opacity:1;visibility:visible}
.an-drawer{position:fixed;top:0;right:0;z-index:960;height:100%;width:min(340px,86vw);
  background:var(--an-surface);box-shadow:var(--an-sh-lg);padding:1.4rem;display:flex;flex-direction:column;gap:.4rem;
  transform:translateX(102%);transition:transform var(--an-dur) var(--an-ease-out);overflow-y:auto}
.an-drawer.is-open{transform:translateX(0)}
.an-drawer__close{align-self:flex-end;width:2.6rem;height:2.6rem;border-radius:var(--an-r-sm);
  border:1px solid var(--an-line);background:var(--an-bg);display:grid;place-items:center;font-size:1.2rem;color:var(--an-ink)}
.an-drawer__list{display:flex;flex-direction:column;margin:.6rem 0 1rem}
.an-drawer__link{display:flex;align-items:center;justify-content:space-between;padding:.85rem .6rem;
  border-bottom:1px solid var(--an-line-soft);font-weight:700;font-size:1.05rem;color:var(--an-text)}
.an-drawer__link:hover{color:var(--an-em-deep)}

/* =====  Hero  ===== */
.an-hero{position:relative;overflow:hidden;background:var(--an-ink-grad);color:var(--an-inv-soft);isolation:isolate}
.an-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--an-gold-grad);opacity:.8;z-index:1}
.an-hero__bg{position:absolute;inset:0;z-index:-3;object-fit:cover;width:100%;height:100%;opacity:.3}
.an-hero__veil{position:absolute;inset:0;z-index:-2;
  background:linear-gradient(105deg,rgba(10,24,18,.95) 26%,rgba(10,26,21,.66) 60%,rgba(10,40,30,.42))}
.an-hero__veil::after{content:"";position:absolute;inset:0;background:var(--an-mesh)}
.an-hero__tiles{position:absolute;inset:0;z-index:-1;mix-blend-mode:soft-light;opacity:.5}
.an-hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center;
  padding-block:clamp(3.5rem,8vw,6.5rem)}
.an-hero__chip{margin-bottom:1.4rem}
.an-hero__title{font-size:var(--an-fz-h1);color:#fff;margin-bottom:1.2rem}
.an-hero__title em{color:var(--an-gold-soft)}
.an-hero__lead{font-size:var(--an-fz-lg);color:var(--an-inv-soft);max-width:54ch;margin-bottom:1.8rem}
.an-hero__actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:2rem}
.an-hero__trust{display:flex;flex-wrap:wrap;gap:1.4rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12)}
.an-hero__trust-item{display:flex;align-items:center;gap:.6rem;font-size:.86rem;color:var(--an-inv-soft)}
.an-hero__trust-item .an-ico{color:var(--an-gold-soft)}
.an-hero__trust-item strong{color:#fff;font-weight:800}

/* hero side: top pick card */
.an-pick{background:var(--an-surface);color:var(--an-text);border-radius:var(--an-r-xl);padding:1.6rem;
  box-shadow:var(--an-sh-lg);position:relative;border:1px solid var(--an-line)}
.an-pick__ribbon{position:absolute;top:-.85rem;left:1.6rem;display:inline-flex;align-items:center;gap:.4rem;
  padding:.4em .9em;border-radius:var(--an-r-pill);background:var(--an-gold);color:var(--an-ink);
  font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;box-shadow:var(--an-sh)}
.an-pick__head{display:flex;align-items:center;gap:.9rem;margin:.6rem 0 1rem}
.an-pick__badge{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;flex:none;
  font-family:var(--an-ff-d);font-weight:900;font-size:1.3rem;color:#fff;
  background:linear-gradient(150deg,var(--an-em-bright),var(--an-em-deep));box-shadow:var(--an-sh-em)}
.an-pick__name{font-family:var(--an-ff-d);font-weight:800;font-size:1.3rem;color:var(--an-ink);line-height:1.1}
.an-pick__lic{font-size:.74rem;font-weight:700;color:var(--an-text-mut);letter-spacing:.04em}
.an-pick__score{margin-left:auto;text-align:center}
.an-pick__score-num{font-family:var(--an-ff-d);font-weight:900;font-size:1.7rem;color:var(--an-em-deep);line-height:1}
.an-pick__score-lbl{font-size:.64rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--an-text-mut)}
.an-pick__rows{display:grid;gap:.55rem;margin:.4rem 0 1.2rem}
.an-pick__row{display:flex;align-items:center;gap:.6rem;font-size:.9rem;font-weight:600;color:var(--an-text-soft)}
.an-pick__row .an-ico{color:var(--an-em)}
.an-pick__disc{margin-top:.9rem;font-size:.72rem;color:var(--an-text-mut);text-align:center}

/* stars */
.an-stars{display:inline-flex;gap:1px;color:var(--an-gold)}
.an-stars .an-ico{width:1em;height:1em}
.an-stars--mut{color:var(--an-line)}

/* =====  Logo strip  ===== */
.an-strip{padding-block:1.8rem;border-bottom:1px solid var(--an-line)}
.an-strip__label{text-align:center;font-size:.74rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  color:var(--an-text-mut);margin-bottom:1.1rem}
.an-strip__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1.2rem 2.4rem}
.an-strip__item{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:var(--an-text-soft);font-size:.9rem}
.an-strip__item .an-ico{color:var(--an-em);font-size:1.2rem}

/* =====  Ranking (aggregator core)  ===== */
.an-rank{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.an-rankcard{position:relative;display:flex;flex-direction:column;gap:1.1rem;
  background:var(--an-surface);border:1px solid var(--an-line);border-radius:var(--an-r-lg);
  padding:1.7rem 1.6rem 1.4rem;box-shadow:var(--an-sh-sm);transition:transform var(--an-dur) var(--an-ease-out),box-shadow var(--an-dur),border-color var(--an-dur)}
.an-rankcard:hover{transform:translateY(-4px);box-shadow:var(--an-sh-lg);border-color:rgba(15,122,87,.4)}
.an-rankcard--top{border-color:var(--an-gold);box-shadow:0 .6em 2em rgba(194,154,44,.18)}
.an-rankcard--top::before{content:"";position:absolute;inset:0;border-radius:var(--an-r-lg);padding:1px;
  background:linear-gradient(140deg,var(--an-gold),transparent 55%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.an-rankcard__rankno{position:absolute;top:1.1rem;right:1.1rem;display:grid;place-items:center;width:2.4rem;height:2.4rem;border-radius:50%;
  font-family:var(--an-ff-d);font-weight:900;font-size:1.05rem;color:var(--an-em-deep);
  background:rgba(15,122,87,.1);border:1px solid rgba(15,122,87,.22)}
.an-rankcard--top .an-rankcard__rankno{color:var(--an-ink);background:var(--an-gold);border-color:var(--an-gold)}
.an-rankcard__brand{display:flex;align-items:center;gap:1rem;min-width:0;padding-right:2.4rem}
.an-rankcard__badge{width:56px;height:56px;border-radius:14px;flex:none;display:grid;place-items:center;
  font-family:var(--an-ff-d);font-weight:900;font-size:1.3rem;color:#fff;box-shadow:var(--an-sh-sm)}
.an-rankcard__name{font-family:var(--an-ff-d);font-weight:800;font-size:1.22rem;color:var(--an-ink);line-height:1.1}
.an-rankcard__tag{display:flex;align-items:center;gap:.4rem;margin-top:.25rem;font-size:.72rem;font-weight:700;
  color:var(--an-text-mut);letter-spacing:.02em}
.an-rankcard__tag .an-ico{color:var(--an-em);font-size:.9rem}
.an-rankcard__feats{display:flex;flex-direction:column;gap:.55rem;flex:1 1 auto;
  padding-top:1rem;border-top:1px dashed var(--an-line)}
.an-rankcard__feat{display:flex;align-items:center;gap:.5rem;font-size:.84rem;font-weight:600;color:var(--an-text-soft)}
.an-rankcard__feat .an-ico{color:var(--an-em);font-size:.95rem;flex:none}
.an-rankcard__right{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding-top:1rem;border-top:1px dashed var(--an-line)}
.an-rankcard__scorebox{display:flex;align-items:baseline;gap:.5rem;line-height:1}
.an-rankcard__score{font-family:var(--an-ff-d);font-weight:900;font-size:1.9rem;color:var(--an-em-deep)}
.an-rankcard__score-lbl{font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--an-text-mut)}
.an-rankcard__right .an-btn{flex:none}
.an-rankcard__verdict{font-size:.74rem;font-weight:700;color:var(--an-text-mut)}

/* responsive ranking */
@media(max-width:560px){
  .an-rank{grid-template-columns:1fr}
  .an-rankcard__right{flex-wrap:wrap}
}

/* ranking filter bar */
.an-filter{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2rem}
.an-filter__btn{padding:.55em 1.1em;border-radius:var(--an-r-pill);border:1px solid var(--an-line);
  background:var(--an-surface);font-weight:700;font-size:.88rem;color:var(--an-text-soft);transition:all var(--an-dur) var(--an-ease)}
.an-filter__btn:hover{border-color:var(--an-em);color:var(--an-em-deep)}
.an-filter__btn.is-active{background:var(--an-em);border-color:var(--an-em);color:#fff;box-shadow:var(--an-sh-em)}

/* =====  Cards grid (features / methodology)  ===== */
.an-grid{display:grid;gap:1.3rem}
.an-grid--2{grid-template-columns:repeat(2,1fr)}
.an-grid--3{grid-template-columns:repeat(3,1fr)}
.an-grid--4{grid-template-columns:repeat(4,1fr)}
.an-card{position:relative;overflow:hidden;background:var(--an-surface);border:1px solid var(--an-line);border-radius:var(--an-r-lg);
  padding:1.6rem;box-shadow:var(--an-sh-sm);transition:transform var(--an-dur) var(--an-ease-out),box-shadow var(--an-dur),border-color var(--an-dur)}
.an-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--an-em-grad);
  transform:scaleX(0);transform-origin:left;transition:transform .45s var(--an-ease-out)}
.an-card:hover{transform:translateY(-4px);box-shadow:var(--an-sh);border-color:rgba(15,122,87,.3)}
.an-card:hover::before{transform:scaleX(1)}
.an-card__icon{width:3rem;height:3rem;border-radius:13px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:linear-gradient(150deg,rgba(20,168,122,.16),rgba(15,122,87,.08));color:var(--an-em-deep);font-size:1.4rem;
  border:1px solid rgba(15,122,87,.18)}
.an-card__icon--gold{background:linear-gradient(150deg,rgba(224,195,116,.28),rgba(194,154,44,.1));color:var(--an-gold-deep);border-color:rgba(194,154,44,.25)}
.an-card__title{font-size:var(--an-fz-h4);margin-bottom:.55rem}
.an-card__text{font-size:.95rem;color:var(--an-text-soft);margin:0}
.an-card__num{font-family:var(--an-ff-d);font-weight:900;font-size:1.1rem;color:var(--an-gold-deep);margin-bottom:.6rem}

/* =====  Stats band  ===== */
.an-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.an-stat__num{font-family:var(--an-ff-d);font-weight:900;font-size:clamp(2.2rem,4vw,3rem);color:var(--an-gold-soft);line-height:1}
.an-stat__lbl{margin-top:.5rem;font-size:.88rem;color:var(--an-inv-soft);font-weight:600}

/* =====  Comparison table  ===== */
.an-tablewrap{overflow-x:auto;border-radius:var(--an-r-lg);border:1px solid var(--an-line);box-shadow:var(--an-sh-sm);background:var(--an-surface)}
.an-table{width:100%;border-collapse:collapse;min-width:680px;font-size:.92rem}
.an-table th,.an-table td{padding:.95rem 1.1rem;text-align:left;border-bottom:1px solid var(--an-line-soft)}
.an-table thead th{background:var(--an-ink);color:var(--an-inv);font-weight:700;font-family:var(--an-ff-b);
  font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;border-bottom:0}
.an-table tbody tr:last-child td{border-bottom:0}
.an-table tbody tr:hover{background:var(--an-surface-2)}
.an-table__brand{display:flex;align-items:center;gap:.7rem;font-weight:800;color:var(--an-ink);font-family:var(--an-ff-d)}
.an-table__mini{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none;color:#fff;
  font-family:var(--an-ff-d);font-weight:900;font-size:.85rem}
.an-table__score{font-family:var(--an-ff-d);font-weight:900;color:var(--an-em-deep);font-size:1.05rem}

/* =====  Steps (guide)  ===== */
.an-steps{display:grid;gap:1.3rem;counter-reset:step}
.an-step{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:start;
  background:var(--an-surface);border:1px solid var(--an-line);border-radius:var(--an-r-lg);padding:1.5rem;box-shadow:var(--an-sh-sm)}
.an-step__no{counter-increment:step;width:2.8rem;height:2.8rem;border-radius:50%;flex:none;display:grid;place-items:center;
  font-family:var(--an-ff-d);font-weight:900;font-size:1.2rem;color:#fff;background:linear-gradient(150deg,var(--an-em-bright),var(--an-em-deep))}
.an-step__no::before{content:counter(step,decimal-leading-zero)}
.an-step__title{font-size:var(--an-fz-h4);margin-bottom:.4rem}
.an-step__text{font-size:.95rem;color:var(--an-text-soft);margin:0}

/* =====  Method tabs  ===== */
.an-method{display:grid;grid-template-columns:.8fr 1.2fr;gap:1.5rem;background:var(--an-surface);
  border:1px solid var(--an-line);border-radius:var(--an-r-xl);padding:1.6rem;box-shadow:var(--an-sh-sm)}
.an-method__tabs{display:flex;flex-direction:column;gap:.5rem}
.an-method__tab{display:flex;align-items:center;gap:.8rem;padding:1rem 1.1rem;border-radius:var(--an-r);
  border:1px solid transparent;font-weight:700;color:var(--an-text-soft);text-align:left;transition:all var(--an-dur) var(--an-ease)}
.an-method__tab .an-ico{font-size:1.2rem;color:var(--an-text-mut)}
.an-method__tab:hover{background:var(--an-surface-2)}
.an-method__tab.is-active{background:var(--an-ink);color:#fff;box-shadow:var(--an-sh)}
.an-method__tab.is-active .an-ico{color:var(--an-gold-soft)}
.an-method__tab-w{font-size:.7rem;font-weight:800;color:var(--an-gold-deep);margin-left:auto}
.an-method__tab.is-active .an-method__tab-w{color:var(--an-gold-soft)}
.an-method__panels{position:relative}
.an-method__panel{display:none;animation:an-fade .4s var(--an-ease)}
.an-method__panel.is-active{display:block}
.an-method__panel h3{font-size:var(--an-fz-h3);margin-bottom:.7rem}
.an-method__panel p{color:var(--an-text-soft)}
@keyframes an-fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* =====  FAQ  ===== */
.an-faq{display:grid;gap:.8rem}
.an-faq__item{background:var(--an-surface);border:1px solid var(--an-line);border-radius:var(--an-r);overflow:hidden;transition:border-color var(--an-dur),box-shadow var(--an-dur)}
.an-faq__item.is-open{border-color:rgba(15,122,87,.4);box-shadow:var(--an-sh-sm)}
.an-faq__head{display:flex;align-items:center;gap:1rem;width:100%;padding:1.15rem 1.3rem;text-align:left;
  font-family:var(--an-ff-d);font-weight:700;font-size:1.08rem;color:var(--an-ink)}
.an-faq__head .an-ico{margin-left:auto;color:var(--an-em);transition:transform var(--an-dur) var(--an-ease)}
.an-faq__item.is-open .an-faq__head .an-ico{transform:rotate(180deg)}
.an-faq__q-no{font-family:var(--an-ff-d);font-weight:900;color:var(--an-gold-deep);font-size:.95rem}
.an-faq__body{max-height:0;overflow:hidden;transition:max-height .4s var(--an-ease)}
.an-faq__body-inner{padding:0 1.3rem 1.3rem;color:var(--an-text-soft);font-size:.95rem}
.an-faq__item.is-open .an-faq__body{max-height:520px}

/* =====  CTA / newsletter (subscribe form)  ===== */
.an-cta{position:relative;overflow:hidden;background:var(--an-ink);color:var(--an-inv-soft);border-radius:var(--an-r-xl);
  padding:clamp(2rem,5vw,3.6rem);isolation:isolate}
.an-cta__tiles{position:absolute;inset:0;z-index:-1}
.an-cta__inner{display:grid;grid-template-columns:1fr .9fr;gap:clamp(1.8rem,4vw,3rem);align-items:center}
.an-cta__title{font-size:var(--an-fz-h2);color:#fff;margin-bottom:.9rem}
.an-cta__title em{color:var(--an-gold-soft)}
.an-cta__text{color:var(--an-inv-soft);margin-bottom:1.2rem}
.an-cta__perks{display:flex;flex-direction:column;gap:.6rem}
.an-cta__perk{display:flex;align-items:center;gap:.6rem;font-size:.9rem;color:var(--an-inv-soft)}
.an-cta__perk .an-ico{color:var(--an-gold-soft)}

/* form */
.an-form{background:var(--an-surface);color:var(--an-text);border-radius:var(--an-r-lg);padding:1.6rem;box-shadow:var(--an-sh-lg)}
.an-form__grp{margin-bottom:.95rem}
.an-form__grp label{display:block;font-size:.78rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--an-text-mut);margin-bottom:.4rem}
.an-form__grp input[type=text],.an-form__grp input[type=tel],.an-form__grp input[type=email],.an-form__grp textarea,.an-form__grp select{
  width:100%;padding:.78rem .9rem;border-radius:var(--an-r-sm);border:1px solid var(--an-line);background:var(--an-bg);
  color:var(--an-text);font-weight:600;transition:border-color var(--an-dur),box-shadow var(--an-dur)}
.an-form__grp input:focus,.an-form__grp textarea:focus,.an-form__grp select:focus{outline:none;border-color:var(--an-em);box-shadow:var(--an-ring)}
.an-form__grp textarea{min-height:120px;resize:vertical}
.an-form__consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.8rem;color:var(--an-text-soft);font-weight:600}
.an-form__consent input{margin-top:.2rem;width:1.05rem;height:1.05rem;accent-color:var(--an-em);flex:none}
.an-form__consent a{font-weight:700}
.an-form__success{display:none;margin-top:1rem;padding:.9rem 1rem;border-radius:var(--an-r-sm);
  background:rgba(15,122,87,.1);border:1px solid rgba(15,122,87,.3);color:var(--an-em-deep);font-weight:700;font-size:.9rem;text-align:center}
.an-form__success.show{display:block;animation:an-fade .4s var(--an-ease)}

/* =====  Self-test quiz  ===== */
.an-quiz{background:var(--an-surface);border:1px solid var(--an-line);border-radius:var(--an-r-xl);padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--an-sh-sm)}
.an-quiz__q{padding:1.1rem 0;border-bottom:1px solid var(--an-line-soft)}
.an-quiz__q:first-child{padding-top:0}
.an-quiz__q-text{display:flex;gap:.7rem;font-weight:700;color:var(--an-ink);margin-bottom:.9rem}
.an-quiz__q-no{font-family:var(--an-ff-d);font-weight:900;color:var(--an-gold-deep)}
.an-quiz__opts{display:flex;gap:.7rem;flex-wrap:wrap}
.an-quiz__opt{padding:.55em 1.3em;border-radius:var(--an-r-pill);border:1px solid var(--an-line);background:var(--an-bg);
  font-weight:700;font-size:.9rem;color:var(--an-text-soft);transition:all var(--an-dur) var(--an-ease)}
.an-quiz__opt:hover{border-color:var(--an-em)}
.an-quiz__opt.is-active{background:var(--an-em);border-color:var(--an-em);color:#fff}
.an-quiz__actions{display:flex;gap:.7rem;margin-top:1.4rem;flex-wrap:wrap}
.an-quiz__btn[disabled]{opacity:.45;cursor:not-allowed}
.an-quiz__result{margin-top:1.4rem;padding:1.4rem;border-radius:var(--an-r-lg);border:1px solid var(--an-line)}
.an-quiz__result.is-low{background:rgba(15,122,87,.08);border-color:rgba(15,122,87,.3)}
.an-quiz__result.is-moderate{background:rgba(181,98,26,.08);border-color:rgba(181,98,26,.3)}
.an-quiz__result.is-high{background:rgba(165,50,39,.08);border-color:rgba(165,50,39,.3)}
.an-quiz__result-lbl{font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--an-text-mut)}
.an-quiz__result-title{font-size:var(--an-fz-h4);margin:.3rem 0 .5rem}
.an-quiz__result-text{font-size:.92rem;color:var(--an-text-soft);margin:0}

/* =====  Callouts  ===== */
.an-callout{display:flex;gap:1rem;padding:1.2rem 1.4rem;border-radius:var(--an-r-lg);align-items:flex-start;
  background:var(--an-surface-2);border:1px solid var(--an-line);border-left:4px solid var(--an-em)}
.an-callout .an-ico{font-size:1.4rem;color:var(--an-em);flex:none;margin-top:.1rem}
.an-callout--warn{border-left-color:var(--an-warn)}
.an-callout--warn .an-ico{color:var(--an-warn)}
.an-callout p{margin:0;font-size:.94rem;color:var(--an-text-soft)}
.an-callout strong{color:var(--an-ink)}

/* =====  Media split  ===== */
.an-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,3.5rem);align-items:center}
.an-split--rev .an-split__media{order:2}
.an-split__media{border-radius:var(--an-r-xl);overflow:hidden;box-shadow:var(--an-sh-lg);position:relative;aspect-ratio:4/3}
.an-split__media img{width:100%;height:100%;object-fit:cover}
.an-split__badge{position:absolute;bottom:1rem;left:1rem;display:flex;align-items:center;gap:.6rem;
  padding:.6rem 1rem;border-radius:var(--an-r-pill);background:rgba(252,249,242,.95);box-shadow:var(--an-sh);
  font-weight:800;font-size:.84rem;color:var(--an-ink)}
.an-split__badge .an-ico{color:var(--an-em)}
.an-prose>*+*{margin-top:1rem}
.an-prose h3{font-size:var(--an-fz-h3);margin-top:1.6rem}
.an-prose ul{display:grid;gap:.6rem;margin:.4rem 0}
.an-prose ul li{display:flex;gap:.6rem;align-items:flex-start;color:var(--an-text-soft)}
.an-prose ul li .an-ico{color:var(--an-em);flex:none;margin-top:.15rem}

/* =====  Footer  ===== */
.an-footer{background:var(--an-ink);color:var(--an-inv-soft)}
.an-footer__disc{background:#0a1410;border-bottom:1px solid rgba(255,255,255,.08)}
.an-footer__disc-inner{display:flex;align-items:center;gap:1.2rem;padding-block:1.2rem}
.an-footer__stamp{display:grid;place-items:center;width:3rem;height:3rem;border-radius:50%;flex:none;
  background:var(--an-gold);color:var(--an-ink);font-weight:900;font-size:.9rem}
.an-footer__stamp sup{font-size:.6em}
.an-footer__disc-text{font-size:.84rem;color:var(--an-inv-soft);margin:0}
.an-footer__disc-text strong{color:#fff}
.an-footer__disc-cta{margin-left:auto;white-space:nowrap}
.an-footer__main{padding-block:clamp(2.5rem,5vw,3.5rem)}
.an-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.an-footer__brand-desc{font-size:.88rem;color:var(--an-inv-soft);margin:1rem 0;max-width:34ch}
.an-footer__mail{display:inline-flex;align-items:center;gap:.5rem;color:var(--an-gold-soft);font-weight:700;font-size:.9rem}
.an-footer__mail:hover{color:#fff}
.an-footer__col-title{color:#fff;font-family:var(--an-ff-b);font-size:.78rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1rem}
.an-footer__list{display:flex;flex-direction:column;gap:.6rem}
.an-footer__list a{color:var(--an-inv-soft);font-size:.9rem;font-weight:600}
.an-footer__list a:hover{color:var(--an-gold-soft)}
.an-footer__regs{border-top:1px solid rgba(255,255,255,.08)}
.an-footer__regs-inner{padding-block:1.6rem}
.an-footer__regs-label{text-align:center;font-size:.72rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--an-inv-soft);opacity:.7;margin-bottom:1.1rem}
.an-footer__regs-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem}
.an-footer__reg{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .9rem;border-radius:var(--an-r-pill);
  border:1px solid rgba(255,255,255,.14);font-size:.78rem;font-weight:700;color:var(--an-inv-soft)}
.an-footer__reg .an-ico{color:var(--an-gold-soft);font-size:.95rem}
.an-footer__bottom{border-top:1px solid rgba(255,255,255,.08)}
.an-footer__bottom-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding-block:1.3rem;font-size:.8rem;color:var(--an-inv-soft)}
.an-footer__quick{display:flex;gap:1.2rem}
.an-footer__quick a{color:var(--an-gold-soft);font-weight:700}

/* =====  Age gate  ===== */
.an-age{position:fixed;inset:0;z-index:9998;display:grid;place-items:center;padding:1.2rem;
  background:rgba(8,16,12,.86);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;transition:opacity var(--an-dur)}
.an-age.is-visible{opacity:1}
.an-age__panel{width:100%;max-width:440px;background:var(--an-surface);border-radius:var(--an-r-xl);overflow:hidden;
  box-shadow:var(--an-sh-lg);transform:translateY(14px);transition:transform var(--an-dur) var(--an-ease-out)}
.an-age.is-visible .an-age__panel{transform:none}
.an-age__head{position:relative;display:flex;align-items:center;gap:.9rem;padding:1.4rem 1.6rem;background:var(--an-ink);color:#fff;overflow:hidden}
.an-age__stamp{display:grid;place-items:center;width:3rem;height:3rem;border-radius:50%;flex:none;background:var(--an-gold);color:var(--an-ink);font-weight:900}
.an-age__stamp sup{font-size:.6em}
.an-age__lead{font-size:.86rem;font-weight:700;color:var(--an-inv-soft)}
.an-age__body{padding:1.6rem}
.an-age__title{font-size:var(--an-fz-h3);margin-bottom:.7rem}
.an-age__text{font-size:.92rem;color:var(--an-text-soft);margin-bottom:1.4rem}
.an-age__actions{display:flex;flex-direction:column;gap:.7rem}
.an-age__no{text-align:center;font-size:.86rem;font-weight:700;color:var(--an-text-mut)}
.an-age__no:hover{color:var(--an-bad)}
.an-age__legal{display:block;margin-top:1rem;text-align:center;font-size:.72rem;color:var(--an-text-mut)}

/* =====  Cookie  ===== */
.an-cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:940;max-width:560px;margin-inline:auto;
  display:flex;flex-wrap:wrap;align-items:center;gap:1rem;padding:1.1rem 1.3rem;background:var(--an-surface);
  border:1px solid var(--an-line);border-radius:var(--an-r-lg);box-shadow:var(--an-sh-lg);
  transform:translateY(140%);opacity:0;transition:transform var(--an-dur) var(--an-ease-out),opacity var(--an-dur)}
.an-cookie.is-visible{transform:none;opacity:1}
.an-cookie__icon{font-size:1.5rem;color:var(--an-gold-deep);flex:none}
.an-cookie__text{flex:1 1 240px;font-size:.84rem;color:var(--an-text-soft);margin:0}
.an-cookie__text strong{color:var(--an-ink)}
.an-cookie__actions{display:flex;gap:.5rem;margin-left:auto}
.an-cookie__btn{padding:.55em 1.1em;border-radius:var(--an-r-pill);font-weight:700;font-size:.84rem;
  border:1px solid var(--an-line);background:var(--an-bg);color:var(--an-text-soft)}
.an-cookie__btn--primary{background:var(--an-em);border-color:var(--an-em);color:#fff}

/* =====  Breadcrumb / page hero  ===== */
.an-phero{position:relative;background:var(--an-ink-grad);color:var(--an-inv-soft);overflow:hidden;isolation:isolate}
.an-phero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--an-gold-grad);opacity:.8}
.an-phero__bg{position:absolute;inset:0;z-index:-3;width:100%;height:100%;object-fit:cover;opacity:.26}
.an-phero__veil{position:absolute;inset:0;z-index:-2;background:linear-gradient(110deg,rgba(10,24,18,.94) 30%,rgba(10,30,22,.7))}
.an-phero__veil::after{content:"";position:absolute;inset:0;background:var(--an-mesh)}
.an-phero__tiles{position:absolute;inset:0;z-index:-1;opacity:.5;mix-blend-mode:soft-light}
.an-phero__inner{padding-block:clamp(2.6rem,6vw,4.2rem)}
.an-crumb{display:flex;gap:.5rem;font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--an-inv-soft);margin-bottom:1.2rem}
.an-crumb a{color:var(--an-gold-soft)}
.an-crumb span{opacity:.5}
.an-phero__title{font-size:var(--an-fz-h1);color:#fff;margin-bottom:1rem;max-width:18ch}
.an-phero__title em{color:var(--an-gold-soft)}
.an-phero__lead{font-size:var(--an-fz-lg);color:var(--an-inv-soft);max-width:60ch}
.an-phero__meta{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:1.6rem}
.an-phero__meta li{display:flex;align-items:center;gap:.5rem;font-size:.84rem;font-weight:600}
.an-phero__meta .an-ico{color:var(--an-gold-soft)}

/* =====  Legal pages  ===== */
.an-legal{display:grid;gap:1.6rem;counter-reset:lg}
.an-legal__sec{background:var(--an-surface);border:1px solid var(--an-line);border-radius:var(--an-r-lg);padding:1.7rem;box-shadow:var(--an-sh-sm)}
.an-legal__head{display:flex;gap:1rem;align-items:baseline;margin-bottom:.8rem}
.an-legal__no{counter-increment:lg;font-family:var(--an-ff-d);font-weight:900;font-size:1.3rem;color:var(--an-gold-deep)}
.an-legal__no::before{content:counter(lg,decimal-leading-zero)}
.an-legal__eyebrow{font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--an-em)}
.an-legal__title{font-size:var(--an-fz-h3)}
.an-legal__sec p{color:var(--an-text-soft)}
.an-legal__sec ul,.an-legal__sec ol{display:grid;gap:.55rem;margin:.6rem 0;padding-left:0}
.an-legal__sec ul li,.an-legal__sec ol li{display:flex;gap:.6rem;color:var(--an-text-soft)}
.an-legal__sec ul li .an-ico{color:var(--an-em);flex:none;margin-top:.18rem}
.an-legal__sec ol{counter-reset:ol;list-style:none}
.an-legal__sec ol li{counter-increment:ol}
.an-legal__sec ol li::before{content:counter(ol)".";font-weight:800;color:var(--an-em);flex:none}

/* related cards */
.an-related{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.an-related__card{display:flex;flex-direction:column;gap:.4rem;padding:1.4rem;background:var(--an-surface);
  border:1px solid var(--an-line);border-radius:var(--an-r-lg);box-shadow:var(--an-sh-sm);transition:transform var(--an-dur) var(--an-ease-out),box-shadow var(--an-dur)}
.an-related__card:hover{transform:translateY(-4px);box-shadow:var(--an-sh)}
.an-related__eyebrow{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--an-gold-deep)}
.an-related__title{font-size:var(--an-fz-h4)}
.an-related__arrow{display:inline-flex;align-items:center;gap:.4rem;margin-top:.4rem;font-weight:700;font-size:.86rem;color:var(--an-em)}

/* =====  Reveal animation (progressive enhancement)  =====
   Content is VISIBLE by default; hiding applies only once JS adds .an-js to
   <html>, so a JS failure or a non-scrolling viewer never sees blank sections.
   main.js also force-reveals everything via a safety timer. */
.an-js [data-an-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--an-ease-out),transform .7s var(--an-ease-out)}
.an-js [data-an-reveal].is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.an-js [data-an-reveal]{opacity:1;transform:none;transition:none}}

/* =====  Utilities  ===== */
.an-center{text-align:center}
.an-mt-2{margin-top:2rem}.an-mt-3{margin-top:3rem}
.an-divider{height:1px;background:var(--an-line);border:0;margin-block:clamp(2rem,4vw,3rem)}

/* =====  Polish: title accent, dividers, sheen, stagger  ===== */
.an-sec__title em{position:relative;white-space:nowrap}
.an-sec__title em::after{content:"";position:absolute;left:0;right:0;bottom:-.08em;height:.14em;border-radius:2px;
  background:var(--an-gold-grad);opacity:.6}

/* azulejo tile divider */
.an-tiledash{display:flex;align-items:center;justify-content:center;gap:.5rem;padding-block:.4rem}
.an-tiledash span{width:9px;height:9px;background:var(--an-em);transform:rotate(45deg);border-radius:2px;opacity:.5}
.an-tiledash span:nth-child(2){background:var(--an-gold);opacity:.8}
.an-tiledash span:nth-child(3){background:var(--an-cobalt);opacity:.5}

/* media sheen + corner frame */
.an-split__media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(160deg,rgba(255,255,255,.12),transparent 38%);mix-blend-mode:overlay}
.an-split__media{position:relative;border:1px solid var(--an-line)}

/* button sheen */
.an-btn{position:relative;overflow:hidden}
.an-btn::after{content:"";position:absolute;top:0;left:-60%;width:45%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.28),transparent);
  transform:skewX(-18deg);transition:left .55s var(--an-ease-out)}
.an-btn:hover::after{left:130%}
.an-btn--ghost::after,.an-btn--gold::after{opacity:.5}

/* reveal stagger inside grids */
.an-grid [data-an-reveal]:nth-child(2){transition-delay:.07s}
.an-grid [data-an-reveal]:nth-child(3){transition-delay:.14s}
.an-grid [data-an-reveal]:nth-child(4){transition-delay:.21s}

/* "why legal" / feature highlight band */
.an-why{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,3.5rem);align-items:center}
.an-why__media{position:relative;border-radius:var(--an-r-xl);overflow:hidden;box-shadow:var(--an-sh-lg);aspect-ratio:5/4}
.an-why__media img{width:100%;height:100%;object-fit:cover}
.an-why__media-tag{position:absolute;left:1rem;bottom:1rem;display:flex;align-items:center;gap:.55rem;
  padding:.6rem 1rem;border-radius:var(--an-r-pill);background:rgba(12,24,18,.78);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  color:#fff;font-weight:700;font-size:.84rem}
.an-why__media-tag .an-ico{color:var(--an-gold-soft)}
.an-why__list{display:grid;gap:1rem;margin-top:1.4rem}
.an-why__item{display:flex;gap:.9rem;align-items:flex-start}
.an-why__item-ico{width:2.5rem;height:2.5rem;border-radius:11px;flex:none;display:grid;place-items:center;
  background:linear-gradient(150deg,rgba(20,168,122,.16),rgba(15,122,87,.06));color:var(--an-em-deep);
  border:1px solid rgba(15,122,87,.18);font-size:1.15rem}
.an-why__item h3{font-size:1.08rem;margin-bottom:.2rem}
.an-why__item p{font-size:.92rem;color:var(--an-text-soft);margin:0}

/* responsive for why */
@media(max-width:820px){.an-why{grid-template-columns:1fr}.an-why__media{order:-1}}

/* =====  Responsive  ===== */
@media(max-width:1000px){
  .an-hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .an-method{grid-template-columns:1fr}
  .an-cta__inner{grid-template-columns:1fr}
  .an-footer__grid{grid-template-columns:1fr 1fr;gap:1.6rem 2rem}
  .an-footer__brand{grid-column:1/-1}
}
@media(max-width:820px){
  .an-nav__list,.an-nav__actions .an-btn{display:none}
  .an-burger{display:block}
  .an-topbar__cell--hide{display:none}
  .an-grid--3,.an-grid--4{grid-template-columns:repeat(2,1fr)}
  .an-stats{grid-template-columns:repeat(2,1fr);gap:1.8rem}
  .an-split{grid-template-columns:1fr}
  .an-split--rev .an-split__media{order:0}
  .an-related{grid-template-columns:1fr}
  .an-footer__disc-inner{flex-wrap:wrap}.an-footer__disc-cta{margin-left:0}
}
@media(max-width:560px){
  .an-grid--2,.an-grid--3,.an-grid--4{grid-template-columns:1fr}
  .an-footer__grid{grid-template-columns:1fr}
  .an-footer__bottom-inner{flex-direction:column;text-align:center}
  .an-cookie__actions{margin-left:0;width:100%}.an-cookie__btn{flex:1}
}
