:root{
  --grafite:#11130F;
  --areia:#F6EDD7;
  --ouro:#F2C230;
  --verde:#2E6F46;
  --barro:#9E4A2F;
  --azul:#17243A;
  --azul-p:#0d1620;
  --line:rgba(246,237,215,.18);
  --muted:rgba(246,237,215,.72);
  --display:'Archivo Black',sans-serif;
  --serif:'IBM Plex Serif',serif;
  --sans:Manrope,sans-serif;
}

*{-webkit-tap-highlight-color:transparent;box-sizing:border-box}
html,body{margin:0;padding:0;height:100%;overflow:hidden;background:var(--grafite);color:var(--areia);font-family:var(--sans);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
body{touch-action:pan-y}
a{color:inherit}
h1,h2,h3{font-family:var(--display);letter-spacing:-.04em;margin:0}

#app{position:fixed;inset:0;display:flex;flex-direction:column;background:radial-gradient(circle at 84% 12%,rgba(242,194,48,.06),transparent 40%),var(--grafite);width:100%;height:100dvh}

/* === Progress bars (Instagram-style, top) === */
.progress-wrap{position:absolute;top:0;left:0;right:0;z-index:40;padding:max(env(safe-area-inset-top,0),10px) 12px 0}
.progress-bars{display:flex;gap:3px}
.pb{flex:1;height:2.5px;background:rgba(246,237,215,.12);border-radius:2px;overflow:hidden;cursor:pointer;transition:height .15s,opacity .15s}
.pb:hover{height:4px}
.pb-fill{height:100%;width:0;background:var(--ouro);border-radius:2px;transition:width .08s linear}
.pb.seen .pb-fill{width:100%;opacity:.4}
.pb.current .pb-fill{width:0;transition:none;opacity:1}

/* === Top bar === */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;position:relative;z-index:31}
.topbar-l{display:flex;align-items:center;gap:10px;min-width:0}
.topbar-logo{width:32px;height:32px;border-radius:8px;background:rgba(246,237,215,.06);padding:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--line)}
.topbar-logo img{width:100%;height:100%;object-fit:contain}
.topbar-name{font-family:var(--display);font-size:13px;color:var(--areia);line-height:1.1;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-name small{display:block;font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ouro);margin-top:2px}
.counter{font-family:var(--display);font-size:14px;color:var(--ouro);letter-spacing:-.02em;white-space:nowrap}
.topbar-r{display:flex;align-items:center;gap:6px;flex-shrink:0}

.icon-btn{
  width:36px;height:36px;border-radius:50%;
  background:rgba(23,36,58,.5);backdrop-filter:blur(10px);
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);cursor:pointer;
  transition:all .2s ease;
}
.icon-btn:hover{background:rgba(23,36,58,.8);color:var(--areia);border-color:rgba(246,237,215,.3)}
.icon-btn:active{transform:scale(.92)}
.icon-btn.playing{background:rgba(242,194,48,.15);border-color:rgba(242,194,48,.4);color:var(--ouro)}
.icon-btn svg{width:15px;height:15px}

/* === Viewport / Stage === */
.viewport{flex:1 1 auto;position:relative;overflow:hidden;display:flex;align-items:stretch;justify-content:center;width:100%;min-height:0}
.stage{position:relative;width:100%;height:100%;flex:1;max-width:520px;margin:0 auto;overflow:hidden}
@media(max-width:600px){.stage{max-width:100%}}
@media(min-width:900px){.stage{max-width:640px;border-radius:20px}}

/* Desktop: formato horizontal apaisado */
@media(min-width:1024px) and (orientation:landscape){
  .stage{max-width:1120px}
  .content{padding:32px 40px 70px!important;display:flex;flex-direction:column;justify-content:flex-start}
  .country-header{flex-direction:row;align-items:flex-start;text-align:left;gap:24px;margin-bottom:28px}
  .country-emblems{width:auto;align-items:flex-start;gap:20px;justify-content:flex-start}
  .country-flag{width:112px;height:80px;border-radius:7px;margin-top:0;object-fit:cover}
  .country-gondwana-logo{width:160px;height:160px;margin-top:0}
  .country-header-text{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding-top:0}
  .country-name{font-size:clamp(40px,5vw,60px);line-height:.88;margin-bottom:14px}
  .country-tags{justify-content:flex-start;max-width:none;margin:0;gap:8px 10px}
  .tag{padding:6px 16px;font-size:17px;line-height:1.05}
  .tag-group{font-size:18px}
  .stats-grid{grid-template-columns:1fr 1fr 1fr 1fr;gap:10px}
  .block{padding:12px 16px;margin-bottom:14px}
  .block-text{font-size:14px}
}

.slide{
  position:absolute;inset:0;
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  transition:transform .35s cubic-bezier(.22,.61,.36,1),opacity .25s ease;
}
.slide::-webkit-scrollbar{display:none}
.slide.left-out{transform:translateX(-100%);opacity:0;pointer-events:none}
.slide.right-out{transform:translateX(100%);opacity:0;pointer-events:none}

/* Decorative texture overlay (shared with original cards) */
.slide::before{
  content:"";position:absolute;inset:-40%;opacity:.16;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle at 20% 30%,rgba(246,237,215,.22) 0 1px,transparent 1.5px),radial-gradient(circle at 70% 60%,rgba(17,19,15,.42) 0 1px,transparent 1.8px);
  background-size:23px 23px,31px 31px;
  mix-blend-mode:soft-light;
}

/* Decorative orbit circle (like original cards) */
.slide-country::after,.slide-special::after{
  content:"";position:absolute;right:-120px;top:60px;width:340px;height:340px;
  border:1.5px solid rgba(246,237,215,.1);border-radius:50%;z-index:0;pointer-events:none;
}

/* === Navigation zones === */
.nav-left,.nav-right{position:absolute;top:0;bottom:0;width:28%;z-index:10;cursor:pointer}
.nav-left{left:0}.nav-right{right:0}

.arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:20;
  width:42px;height:42px;border-radius:50%;
  background:rgba(23,36,58,.5);backdrop-filter:blur(10px);
  border:1px solid var(--line);
  display:none;align-items:center;justify-content:center;
  color:var(--muted);cursor:pointer;
  transition:all .2s ease;
}
.arrow:hover{background:rgba(23,36,58,.8);color:var(--areia)}
.arrow:active{transform:translateY(-50%) scale(.92)}
.arrow.prev{left:calc((100% - 520px) / 2 - 54px)}
.arrow.next{right:calc((100% - 520px) / 2 - 54px)}
.arrow{display:flex}
@media(max-width:599px){
  .arrow{width:44px;height:44px;background:rgba(7,11,20,.6);border-color:rgba(246,237,215,.2)}
  .arrow.prev{left:8px}
  .arrow.next{right:8px}
  .nav-left,.nav-right{display:none}
}

/* === Breadcrumb === */
.breadcrumb{padding:10px 14px;background:rgba(7,11,20,.4);border-bottom:1px solid var(--line);font:600 12px/1.4 var(--sans)}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:0;padding:0;list-style:none;color:var(--muted)}
.breadcrumb li[aria-current="page"]{color:var(--ouro)}
.breadcrumb a{color:var(--areia);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:var(--ouro)}
.breadcrumb li[aria-hidden="true"]{opacity:.5}

/* === Card content === */
.content{position:relative;z-index:3;min-height:100%;padding:52px 20px 120px;display:flex;flex-direction:column}
@media(max-width:600px){.content{padding:56px 16px 130px}}
@media(max-width:390px){.content{padding:52px 14px 120px}}

/* Brand band (3-color strip at top, like original cards) */
.brand-band{position:absolute;top:0;left:0;right:0;height:6px;display:flex;z-index:5}
.brand-band span:nth-child(1){background:var(--azul);flex:1}
.brand-band span:nth-child(2){background:var(--verde);flex:1}
.brand-band span:nth-child(3){background:var(--ouro);flex:1}

/* === Cover card === */
.slide-cover{
  background:radial-gradient(ellipse at 50% 20%,rgba(46,111,70,.22),transparent 55%),radial-gradient(ellipse at 80% 75%,rgba(242,194,48,.12),transparent 50%),linear-gradient(150deg,var(--azul),var(--grafite) 62%);
}
.slide-cover .content{align-items:center;justify-content:center;text-align:center;padding-top:60px}
.cover-tag{font:900 11px/1 var(--sans);letter-spacing:.22em;text-transform:uppercase;color:var(--ouro);margin-bottom:20px}
.cover-title{font-family:var(--display);font-size:clamp(36px,10vw,52px);line-height:.86;color:var(--areia);margin-bottom:16px;padding:0 8px}
.cover-lede{font:600 17px/1.4 var(--serif);color:var(--muted);max-width:340px;margin:0 auto}
.cover-logo{margin:28px auto 16px;width:min(288px,64vw);height:min(288px,64vw);opacity:.82;filter:drop-shadow(0 18px 48px rgba(0,0,0,.42))}
.cover-logo img{width:100%;height:100%;object-fit:contain}
.cover-stats{display:flex;gap:14px;justify-content:center;margin-top:20px;flex-wrap:wrap}
.cover-stats span{font:900 10px/1.3 var(--sans);letter-spacing:.1em;text-transform:uppercase;color:rgba(246,237,215,.4)}
.cover-stats strong{display:block;font-family:var(--display);font-size:22px;color:var(--ouro);letter-spacing:-.04em;margin-bottom:4px}

/* === Country card === */
.slide-country{
  background:radial-gradient(circle at 84% 8%,rgba(242,194,48,.12),transparent 28%),linear-gradient(150deg,var(--azul),var(--grafite) 62%);
}

.country-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:18px;text-align:center}
.country-emblems{display:flex;align-items:center;justify-content:center;gap:14px;width:100%}
.country-flag{
  width:68px;height:68px;object-fit:contain;border-radius:8px;
  border:1px solid rgba(246,237,215,.16);flex-shrink:0;
  background:#fff;box-shadow:0 10px 28px rgba(0,0,0,.22);
}
.country-header-text{flex:1;min-width:0;width:100%;display:flex;flex-direction:column;align-items:center}
.country-name{
  font-family:var(--display);font-size:clamp(26px,9vw,36px);font-weight:400;
  line-height:.9;letter-spacing:-.04em;text-transform:uppercase;
  color:var(--areia);margin-bottom:8px;text-align:center;
}
.country-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:5px 6px;max-width:300px;margin:0 auto}
.tag{
  display:inline-flex;align-items:center;
  padding:3px 8px;border-radius:999px;
  font:900 8.5px/1 var(--sans);letter-spacing:.1em;text-transform:uppercase;
}
.tag-gondwana{background:rgba(46,111,70,.25);color:#7cbf96;border:1px solid rgba(46,111,70,.3)}
.tag-other{background:rgba(158,74,47,.18);color:#d4926f;border:1px solid rgba(158,74,47,.22)}
.tag-abya{background:linear-gradient(135deg,rgba(242,194,48,.95),rgba(158,74,47,.88));color:var(--grafite);border:1px solid rgba(242,194,48,.62);font-weight:900}
.tag-region{background:rgba(246,237,215,.06);color:var(--muted);border:1px solid var(--line)}
.tag-confed{background:rgba(46,111,70,.3);color:var(--areia);border:1px solid rgba(46,111,70,.5)}
.tag-group{background:rgba(242,194,48,.12);color:var(--ouro);border:1px solid rgba(242,194,48,.3);font-family:var(--display);font-size:9px;letter-spacing:-.02em;text-transform:none}

/* Content blocks with colored left borders (like original grid-info) */
.block{
  margin-bottom:12px;padding:10px 14px;
  border:1px solid var(--line);border-left:5px solid var(--ouro);
  background:rgba(17,19,15,.5);backdrop-filter:blur(5px);
}
.block:nth-of-type(odd){border-left-color:var(--verde)}
.block:nth-of-type(3n){border-left-color:var(--barro)}
.block:nth-of-type(4n){border-left-color:var(--azul)}
.block-label{font:900 8.5px/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--ouro);margin-bottom:4px}
.block-text{font:600 13px/1.45 var(--sans);color:var(--areia);margin:0}

/* Stats grid */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.stat-cell{
  border:1px solid var(--line);border-left:4px solid var(--ouro);
  background:rgba(17,19,15,.5);backdrop-filter:blur(5px);
  padding:8px 10px;border-radius:2px;
}
.stat-cell:nth-child(2){border-left-color:var(--verde)}
.stat-cell:nth-child(3){border-left-color:var(--barro)}
.stat-cell:nth-child(4){border-left-color:var(--azul)}
.stat-cell .block-label{font-size:8px;margin-bottom:3px}
.stat-cell .stat-val{font:800 11.5px/1.3 var(--sans);color:var(--areia)}

/* Question box (signature element) */
.question-box{
  background:linear-gradient(135deg,rgba(242,194,48,.1),rgba(46,111,70,.08));
  border:1px solid rgba(242,194,48,.25);border-left:6px solid var(--ouro);
  border-radius:3px;padding:14px;margin-bottom:12px;
}
.question-text{font:600 15px/1.38 var(--serif);font-style:italic;color:var(--areia);margin:0}

/* World Cup box */
.wc-box{
  background:rgba(46,111,70,.12);border:1px solid rgba(46,111,70,.2);
  border-left:5px solid var(--verde);
  border-radius:2px;padding:10px 12px;margin-bottom:12px;
}
.wc-val{font:800 12px/1.4 var(--sans);color:#7cbf96}

/* Formation block (special emphasis, like original) */
.formation-block{
  border:1px solid rgba(242,194,48,.3)!important;
  border-left:7px solid var(--barro)!important;
  background:linear-gradient(135deg,rgba(158,74,47,.28),rgba(17,19,15,.55))!important;
}

/* Freedom / memory block */
.freedom-block{
  border:1px solid rgba(46,111,70,.28)!important;
  border-left:6px solid var(--verde)!important;
  background:rgba(46,111,70,.15)!important;
}

/* Brazil connection block */
.brazil-block{
  border:1px solid rgba(242,194,48,.22)!important;
  border-left:6px solid var(--ouro)!important;
  background:rgba(23,36,58,.5)!important;
  display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;
}
.brazil-logo{width:36px;height:36px;object-fit:contain;flex-shrink:0;opacity:.7}

/* References */
.references-box{
  margin-top:auto;margin-bottom:10px;padding:12px 14px;
  border:1px solid rgba(242,194,48,.22);border-left:5px solid var(--ouro);
  border-radius:2px;background:rgba(17,19,15,.5);backdrop-filter:blur(5px);
}
.references-box ul{margin:8px 0 0;padding:0;list-style:none;display:grid;gap:5px}
.references-box li{font:800 9.5px/1.35 var(--sans);letter-spacing:.01em;color:rgba(246,237,215,.6)}
.references-box a{color:rgba(246,237,215,.78);text-decoration:none;border-bottom:1px solid rgba(242,194,48,.26)}
.references-box a:hover{color:var(--ouro);border-bottom-color:var(--ouro)}

/* Source chip */
.source-chip{
  margin-top:auto;padding-top:10px;
  font:800 9px/1.4 var(--sans);letter-spacing:.02em;
  color:rgba(246,237,215,.35);
}
.source-chip a{color:var(--ouro);text-decoration:none}

/* Card footer */
.card-footer{
  margin-top:8px;padding-top:8px;
  border-top:1px solid rgba(246,237,215,.08);
  font:900 8px/1.2 var(--sans);letter-spacing:.12em;text-transform:uppercase;
  color:rgba(246,237,215,.25);
  display:flex;justify-content:space-between;align-items:center;
}

/* === Special/context cards === */
.slide-special{
  background:radial-gradient(ellipse at 50% 30%,rgba(46,111,70,.15),transparent 55%),linear-gradient(150deg,var(--azul),var(--grafite) 62%);
}
.special-tag{font:900 10px/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--ouro);margin-bottom:12px}
.special-title{font-family:var(--display);font-size:clamp(26px,8vw,36px);line-height:.88;letter-spacing:-.05em;text-transform:uppercase;color:var(--areia);margin-bottom:12px}
.special-lede{font:600 15px/1.42 var(--serif);color:var(--areia);margin:0 0 16px}
.special-pills{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:14px}
.special-pills span{
  font:900 10px/1 var(--sans);letter-spacing:.04em;
  padding:6px 9px;border-radius:999px;
  background:rgba(46,111,70,.14);color:#7cbf96;
  border:1px solid rgba(46,111,70,.2);
}
.special-grid{display:grid;gap:8px;margin-bottom:10px}
.special-grid section{
  padding:10px 12px;border-radius:2px;
  border:1px solid var(--line);border-left:5px solid var(--ouro);
  background:rgba(17,19,15,.5);backdrop-filter:blur(5px);
}
.special-grid section:nth-child(even){border-left-color:var(--verde)}
.special-grid section:nth-child(3n){border-left-color:var(--barro)}
.special-grid small{display:block;font:900 9px/1 var(--sans);letter-spacing:.12em;text-transform:uppercase;color:var(--ouro);margin-bottom:4px}
.special-grid p{font:700 12px/1.38 var(--sans);color:var(--areia);margin:0}

/* === Share bar === */
.share-bar{
  position:absolute;bottom:0;left:0;right:0;z-index:15;
  padding:14px 16px max(env(safe-area-inset-bottom,0),16px);
  background:linear-gradient(0deg,var(--grafite) 65%,rgba(17,19,15,.7) 85%,transparent);
  display:flex;gap:8px;justify-content:center;
}
.share-btn{
  display:flex;align-items:center;gap:5px;
  padding:10px 18px;border-radius:999px;
  background:rgba(242,194,48,.12);border:1px solid rgba(242,194,48,.25);
  color:var(--ouro);font:900 10px/1 var(--sans);letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;transition:all .15s ease;
}
.share-btn:hover{background:rgba(242,194,48,.22);transform:translateY(-1px)}
.share-btn:active{transform:translateY(0) scale(.97)}
.share-btn svg{width:13px;height:13px}

/* === Campaign dock === */
.campaign-dock{position:fixed;left:50%;bottom:max(env(safe-area-inset-bottom,0px),14px);transform:translateX(-50%);z-index:34;display:flex;gap:7px;align-items:center;justify-content:center;width:min(94vw,680px);padding:8px;border:1px solid rgba(246,237,215,.16);border-radius:999px;background:rgba(17,19,15,.82);backdrop-filter:blur(18px);box-shadow:0 18px 60px rgba(0,0,0,.35)}
.dock-link{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 12px;border:0;border-radius:999px;background:rgba(246,237,215,.08);color:var(--areia);text-decoration:none;font:900 11px/1 var(--sans);letter-spacing:.04em;white-space:nowrap;cursor:pointer;font-family:var(--sans)}
.dock-primary{background:var(--ouro);color:#1f160d}
.dock-context{background:rgba(46,111,70,.42)}
.dock-share{background:rgba(242,194,48,.16);color:var(--ouro);border:1px solid rgba(242,194,48,.28)}
@media(max-width:620px){.campaign-dock{display:grid;grid-template-columns:1fr 1fr;border-radius:24px;width:min(94vw,420px)}.dock-link{min-height:40px}.topbar-cta{height:30px;padding:0 9px}}

/* === Filter panel === */
.fp{
  position:fixed;inset:0;z-index:100;
  background:linear-gradient(150deg,rgba(23,36,58,.97),rgba(17,19,15,.98));
  backdrop-filter:blur(16px);
  transform:translateY(-100%);
  transition:transform .35s cubic-bezier(.22,.61,.36,1);
  overflow-y:auto;
  padding:max(env(safe-area-inset-top,0),50px) 18px 40px;
}
.fp.open{transform:translateY(0)}
.fp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.fp-title{font-family:var(--display);font-size:22px;letter-spacing:-.04em;text-transform:uppercase;color:var(--areia)}
.fp-close{
  width:36px;height:36px;border-radius:50%;
  background:rgba(246,237,215,.06);border:1px solid var(--line);
  color:var(--areia);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.fp-close:hover{background:rgba(246,237,215,.12)}
.fp-close:active{transform:scale(.92)}
.fp-search-wrap{position:relative;margin-bottom:8px}
.fp-search{
  width:100%;padding:15px 16px 15px 42px;border-radius:14px;
  background:rgba(17,19,15,.62);border:1px solid rgba(246,237,215,.2);
  color:var(--areia);font:800 15px/1 var(--sans);
  outline:none;
  transition:border-color .15s,box-shadow .15s,background .15s;
  background-image:linear-gradient(transparent,transparent),radial-gradient(circle at 18px 50%,rgba(242,194,48,.9) 0 3px,transparent 3.5px);
}
.fp-search::placeholder{color:rgba(246,237,215,.42)}
.fp-search:focus{border-color:rgba(242,194,48,.72);box-shadow:0 0 0 4px rgba(242,194,48,.12);background-color:rgba(17,19,15,.82)}
.fp-help{font:800 11px/1.45 var(--sans);color:rgba(246,237,215,.58);margin:0 2px 12px;max-width:720px}
.fp-active{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 14px;min-height:22px}
.fp-active span{display:inline-flex;align-items:center;gap:6px;padding:6px 9px;border-radius:999px;background:rgba(242,194,48,.12);border:1px solid rgba(242,194,48,.24);color:var(--ouro);font:900 9px/1 var(--sans);letter-spacing:.08em;text-transform:uppercase}
.fp-active .muted{background:rgba(246,237,215,.04);border-color:var(--line);color:rgba(246,237,215,.48)}
.fp-suggestions{display:none;position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:3;padding:8px;border-radius:16px;background:rgba(17,19,15,.96);border:1px solid rgba(242,194,48,.24);box-shadow:0 22px 50px rgba(0,0,0,.42);backdrop-filter:blur(16px)}
.fp-suggestions.open{display:grid;gap:5px}
.fp-suggestion{width:100%;border:0;border-radius:11px;background:rgba(246,237,215,.04);color:var(--areia);padding:10px 12px;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--sans)}
.fp-suggestion:hover,.fp-suggestion:focus-visible{background:rgba(242,194,48,.12);outline:none}
.fp-suggestion strong{font:900 13px/1 var(--sans)}
.fp-suggestion span{font:800 10px/1.2 var(--sans);color:rgba(246,237,215,.56);text-align:right}
.fp-suggestion.empty{justify-content:center;color:rgba(246,237,215,.58);font:800 12px/1.2 var(--sans)}
.fp-group{margin-bottom:18px}
.fp-gtitle{font:900 10px/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--ouro);margin-bottom:9px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fp-gtitle span{font:800 9px/1 var(--sans);letter-spacing:.08em;color:rgba(246,237,215,.42)}
.fp-chips{display:flex;flex-wrap:wrap;gap:6px}
.fp-chip{
  padding:8px 13px;border-radius:999px;
  background:rgba(246,237,215,.035);border:1px solid var(--line);
  color:var(--muted);font:900 11px/1.2 var(--sans);
  cursor:pointer;transition:all .12s;position:relative;
}
.fp-chip:hover,.fp-chip:focus-visible{background:rgba(246,237,215,.08);color:var(--areia);outline:none;border-color:rgba(246,237,215,.32)}
.fp-chip:active{transform:scale(.95)}
.fp-chip.active,.fp-chip[aria-pressed="true"]{background:linear-gradient(135deg,rgba(242,194,48,.24),rgba(46,111,70,.16));border-color:rgba(242,194,48,.62);color:var(--ouro);box-shadow:0 0 0 1px rgba(242,194,48,.16) inset}
.fp-chip.active::before,.fp-chip[aria-pressed="true"]::before{content:"✓";margin-right:6px;color:var(--ouro)}
.fp-chip[data-help]:hover::after,.fp-chip[data-help]:focus-visible::after{content:attr(data-help);position:absolute;left:0;bottom:calc(100% + 8px);z-index:4;width:min(260px,70vw);padding:10px 12px;border-radius:12px;background:rgba(17,19,15,.96);border:1px solid rgba(242,194,48,.3);box-shadow:0 18px 38px rgba(0,0,0,.34);color:var(--areia);font:800 11px/1.35 var(--sans);letter-spacing:0;text-transform:none}
.fp-results{
  margin-top:16px;padding:13px 16px;border-radius:16px;
  background:rgba(46,111,70,.12);border:1px solid rgba(46,111,70,.26);border-left:5px solid var(--verde);
  color:#8bd2a7;font:900 12px/1.3 var(--sans);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.fp-results small{display:block;margin-top:4px;color:rgba(246,237,215,.52);font:700 10px/1.3 var(--sans)}
.fp-results button{background:rgba(242,194,48,.1);border:1px solid rgba(242,194,48,.25);border-radius:999px;color:var(--ouro);font:900 11px/1 var(--sans);letter-spacing:.04em;text-transform:uppercase;cursor:pointer;padding:9px 11px}
.fp-result-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:8px;margin-top:12px}
.fp-result-item{border:1px solid rgba(246,237,215,.12);border-radius:14px;background:rgba(246,237,215,.04);color:var(--areia);padding:11px 12px;text-align:left;cursor:pointer;font-family:var(--sans);transition:all .14s ease}
.fp-result-item:hover,.fp-result-item:focus-visible{border-color:rgba(242,194,48,.45);background:rgba(242,194,48,.08);transform:translateY(-1px);outline:none}
.fp-result-item strong{display:block;font:900 13px/1.15 var(--sans);margin-bottom:4px}
.fp-result-item span,.fp-result-more{font:800 10px/1.35 var(--sans);color:rgba(246,237,215,.55)}
.fp-result-more{display:flex;align-items:center;justify-content:center;border:1px dashed rgba(246,237,215,.18);border-radius:14px;padding:12px;color:var(--ouro)}
.fp-empty{grid-column:1/-1;border:1px solid rgba(158,74,47,.4);border-left:5px solid var(--barro);border-radius:16px;background:rgba(158,74,47,.12);padding:14px 16px;color:var(--areia)}
.fp-empty strong{font-family:var(--display);letter-spacing:-.03em}.fp-empty p{margin:6px 0 0;color:var(--muted);font:700 12px/1.45 var(--sans)}

/* === Share menu (bottom sheet) === */
.sh-overlay{position:fixed;inset:0;z-index:99;background:rgba(0,0,0,.55);opacity:0;pointer-events:none;transition:opacity .25s}
.sh-overlay.open{opacity:1;pointer-events:auto}
.sh-menu{
  position:fixed;bottom:0;left:0;right:0;z-index:100;
  background:linear-gradient(150deg,var(--azul),var(--grafite) 60%);
  border-top:1px solid var(--line);
  border-radius:20px 20px 0 0;
  padding:22px 16px max(env(safe-area-inset-bottom,0),22px);
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.22,.61,.36,1);
}
.sh-menu.open{transform:translateY(0)}
.sh-menu h3{font-family:var(--display);font-size:18px;letter-spacing:-.03em;text-transform:uppercase;color:var(--areia);margin:0 0 16px;text-align:center}
.sh-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.sh-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:12px 6px;border-radius:8px;
  background:rgba(246,237,215,.04);border:1px solid var(--line);
  color:var(--areia);font:800 9px/1.2 var(--sans);letter-spacing:.03em;text-align:center;
  cursor:pointer;text-decoration:none;
  transition:all .12s;
}
.sh-item:hover{background:rgba(246,237,215,.08);transform:translateY(-2px)}
.sh-item:active{transform:translateY(0) scale(.96)}
.sh-item svg{width:22px;height:22px}
.sh-cancel{
  width:100%;padding:13px;border-radius:8px;
  background:rgba(246,237,215,.05);border:1px solid var(--line);
  color:var(--areia);font:900 13px/1 var(--sans);letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;transition:background .12s;
}
.sh-cancel:hover{background:rgba(246,237,215,.08)}

/* === Loading === */
.loading{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:var(--grafite);color:var(--areia)}
.loading.hidden{opacity:0;pointer-events:none;transition:opacity .4s}
.load-wrap{display:flex;flex-direction:column;align-items:center;gap:16px}
.load-orb{
  width:52px;height:52px;border-radius:50%;
  border:3px solid rgba(242,194,48,.15);border-top-color:var(--ouro);
  animation:spin .9s linear infinite;
}
.load-text{font-family:var(--display);font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--ouro)}
@keyframes spin{to{transform:rotate(360deg)}}

/* Leitura guiada: mostra que a ficha tem partes e continua abaixo */
.read-section{scroll-margin-top:22px}
.scroll-fade{position:fixed;left:0;right:0;z-index:31;height:72px;opacity:0;pointer-events:none;transition:opacity .2s ease}.scroll-fade.is-visible{opacity:1}
.scroll-fade-top{top:0;background:linear-gradient(to bottom,rgba(17,19,15,.82),transparent)}
.scroll-fade-bottom{bottom:0;background:linear-gradient(to top,rgba(17,19,15,.92),rgba(17,19,15,.58) 46%,transparent)}
.scroll-hint{
  position:fixed;right:max(14px,calc((100vw - 520px)/2 + 14px));bottom:18px;z-index:35;transform:translateY(10px);
  display:flex;align-items:center;gap:9px;padding:12px 13px 12px 17px;border-radius:999px;
  color:var(--grafite);background:linear-gradient(135deg,rgba(242,194,48,.98),rgba(246,237,215,.96));
  border:1px solid rgba(246,237,215,.72);box-shadow:0 14px 38px rgba(0,0,0,.42),0 0 0 1px rgba(17,19,15,.14) inset;
  font:900 10px/1 var(--sans);letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .24s ease,transform .24s ease;cursor:pointer;
}
.scroll-hint svg{width:17px;height:17px;animation:hintBounce 1.35s ease-in-out infinite}.scroll-hint.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}
@keyframes hintBounce{0%,100%{transform:translateY(-1px)}50%{transform:translateY(3px)}}

/* === Responsive: desktop frame === */
@media(min-width:520px){
  .viewport::after{
    content:"";position:absolute;inset:0;pointer-events:none;z-index:50;
    box-shadow:inset 0 0 0 1px rgba(246,237,215,.06);
  }
}
@media(min-width:900px){
  .scroll-hint{bottom:22px;padding:12px 18px;font-size:10.5px}
}
@media(max-width:520px){
  .scroll-hint{right:12px;bottom:24px;font-size:9px;padding:11px 13px 11px 15px;max-width:calc(100% - 32px)}
  .scroll-fade-bottom{height:128px}
}

/* Reduce motion */
@media(prefers-reduced-motion:reduce){
  *{transition-duration:.01ms!important;animation-duration:.01ms!important}
  .slide{transition:opacity .15s ease!important;transform:none!important}
  .slide.left-out{opacity:0;transform:none}
  .slide.right-out{opacity:0;transform:none}
}

/* Mapas en fichas especiales */
.special-map{margin:12px 0;border-radius:12px;overflow:hidden;background:rgba(246,237,215,.06);border:1px solid rgba(246,237,215,.18)}
.special-map img{display:block;width:100%;height:auto;object-fit:contain;max-height:45vh}
.special-map figcaption{padding:8px 12px;font-size:11px;line-height:1.3;color:rgba(246,237,215,.7);font-family:var(--sans);text-align:left}

/* Header de fichas especiales con logo */
.special-header-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.special-logo{width:48px;height:48px;object-fit:contain;flex-shrink:0}

/* Logo Gondwana FC en fichas de pais */
.country-gondwana-logo{width:80px;height:80px;object-fit:contain;flex-shrink:0;opacity:.85}

/* Lab credit (GondwanaLab UFRJ) */
.lab-credit{display:flex;align-items:center;gap:12px;margin:12px 0;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:rgba(17,19,15,.4);backdrop-filter:blur(5px)}
.lab-logo{width:48px;height:48px;object-fit:contain;flex-shrink:0;border-radius:8px;background:rgba(255,255,255,.92);padding:4px}
.lab-credit span{font:700 11px/1.4 var(--sans);color:var(--muted);letter-spacing:.02em}

/* Responsive: ajustar mapas y contenido segun dispositivo */
@media(max-width:480px){
  .special-map img{max-height:38vh}
  .special-map figcaption{font-size:10px}
  .country-emblems{gap:12px}
  .country-flag,.country-gondwana-logo{width:64px;height:64px}
  .special-logo{width:42px;height:42px}
}
@media(min-width:768px){
  .special-map img{max-height:52vh}
  .special-map{margin:16px 0;border-radius:16px}
}
@media(min-width:1024px){
  .special-map img{max-height:60vh}
  .country-gondwana-logo{width:88px;height:88px}
}

/* Desktop: ampliar e alinhar a identificacao de paises sem afetar mobile. */
@media(min-width:1024px) and (orientation:landscape){
  .stage{max-width:1120px}
  .country-header{flex-direction:row;align-items:flex-start;text-align:left;gap:24px;margin-bottom:28px}
  .country-emblems{width:auto;align-items:flex-start;gap:20px;justify-content:flex-start}
  .country-flag{width:112px;height:80px;border-radius:7px;margin-top:0;object-fit:cover}
  .country-gondwana-logo{width:160px;height:160px;margin-top:0}
  .country-header-text{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding-top:0}
  .country-name{font-size:clamp(40px,5vw,60px);line-height:.88;margin-bottom:14px}
  .country-tags{justify-content:flex-start;max-width:none;margin:0;gap:8px 10px}
  .tag{padding:6px 16px;font-size:17px;line-height:1.05}
  .tag-group{font-size:18px}
}

/* Indicadores antigos de leitura removidos: evita cache legado mostrando "Ficha Começo". */
.read-progress,
.readProgress,
.ficha-progress,
.fichaProgress,
.scroll-progress-label,
.progress-label,
[data-read-progress],
[data-ficha-progress]{display:none!important;visibility:hidden!important;opacity:0!important;pointer-events:none!important}

/* Ajustar altura del contenido segun dispositivo */
.content{max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1}
@media(max-width:480px){
  .content{max-height:none}
}
@media(orientation:landscape) and (max-height:500px){
  .content{max-height:none}
  .special-map img{max-height:30vh}
}

.lab-logo-text{
  display:inline-grid;
  place-items:center;
  width:48px;
  height:48px;
  border-radius:14px;
  border:1px solid rgba(245, 222, 179, .28);
  background:rgba(255,255,255,.08);
  color:#f8dfb0;
  font:800 12px/1 var(--sans);
  letter-spacing:.08em;
}

@media(max-width:620px){.campaign-dock{display:grid;grid-template-columns:1fr 1fr;border-radius:24px;width:min(94vw,420px)}.dock-link{min-height:40px}.topbar-cta{height:30px;padding:0 9px}}
