@font-face {
  font-family: "Labrit";
  src: url("/assets/fonts/Labrit.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root{
  --ink: #fde4d4;
  --paper: rgba(245, 225, 170, 0.92);
  --paper-edge: rgba(90, 60, 20, 0.50);
  --wood: rgba(20, 14, 10, 0.85);
  --gold: #d6b15c;
  --danger: #d04a4a;
}

/**/
.font-celtic {
  font-family: "Labrit", serif;
  letter-spacing: 0.5px;
}

.font-ui {
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; }
body{ color:#eee; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial; }

.orc-bg{
  background: url("/assets/img/bg-image.jpg") center/cover no-repeat fixed;
}

/* ==============================
   BACKGROUNDS POR PÁGINA
   ============================== */
   
.orc-bg.page-entrar{
  background: url("/assets/img/background-entrar.jpg") center/cover no-repeat fixed;
}

.orc-bg.page-tabletop{
  background: url("/assets/img/background-tabletop.jpg") center/cover no-repeat fixed;
}

.orc-bg.page-acervo{
  background: url("/assets/img/background-acervo.jpg") center/cover no-repeat fixed;
}

.orc-bg.page-galeria{
  background: url("/assets/img/background-galeria.jpg") center/cover no-repeat fixed;
}

.orc-bg.page-projetos{
  background: url("/assets/img/bg-projetos.jpg") center/cover no-repeat fixed;
}

.orc-bg.page-sobre{
  background: url("/assets/img/background-sobre.jpg") center/cover no-repeat fixed;
}

/* overlay escuro pra leitura */
.orc-bg::before{
  content:"";
  position: fixed;
  inset:0;
  background: rgba(0,0,0,0.55);
  pointer-events:none;
  z-index:0;
}

.topbar{
  position: relative;
  z-index: 1;
  padding: 14px 18px;
  background: linear-gradient(to bottom, rgba(0,0,0,0.75), rgba(0,0,0,0.25));
  border-bottom: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(2px);
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
  max-width: 1200px;
  margin: 0 auto;
}

.brand__logo{
  width: 86px;
  height: 86px;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,0.55));
}

.brand__title{
  font-size: 26px;
  letter-spacing: 0.6px;
  color: var(--gold);
  text-shadow: 0 2px 12px rgba(0,0,0,0.8);
  font-weight: 800;
}

.brand__subtitle{
  opacity: 0.9;
  font-size: 13px;
}

.layout{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 18px;
  max-width: 1200px;
  margin: 18px auto;
  padding: 0 18px 22px;
}

.sidebar{
  background: var(--wood);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.45);
}

.sidebar__banner{
  display: flex;
  justify-content: center; /* centraliza o conteúdo no meio */
  align-items: center;
  text-align: center;
}

.sidebar__banner-title{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;              /* espaço entre ícones e texto */
  width: 100%;            /* ocupa a largura do banner */
  text-align: center;
}

.menu{
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.menu__item{
  display:block;
  text-decoration:none;
  color:#f2e7d1;
  padding: 11px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  transition: transform .08s ease, background .08s ease;
}

.menu__item:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,0.10);
}

.menu__item--home{
  border-color: rgba(214,177,92,0.35);
  background: rgba(214,177,92,0.10);
  color: #fff3d6;
}
.menu__item--home:hover{
  background: rgba(214,177,92,0.16);
}

.menu__sep{
  height: 1px;
  background: rgba(255,255,255,0.10);
  margin: 8px 0;
}

.menu__item--danger{
  color: #ffe3e3;
  border-color: rgba(208,74,74,0.35);
  background: rgba(208,74,74,0.10);
}
.menu__item--danger:hover{
  background: rgba(208,74,74,0.16);
}

.content{
  min-height: 60vh;
}

.paper{
  color: var(--ink);
  background: rgba(245, 225, 170, 0.582);
  border-radius: 18px;
  padding: 22px;
  border: 1px solid var(--paper-edge);
  box-shadow: 0 22px 50px rgba(0,0,0,0.45);
}

.paper h1{
  margin: 0 0 10px;
  font-size: 28px;
  color: #fde4d4;
  letter-spacing: 0.4px;
}

.paper p{
  margin: 0 0 16px;
  line-height: 1.55;
}

.cards{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}

.card{
  display:block;
  text-decoration:none;
  color: var(--ink);
  padding: 16px;
  border-radius: 14px;
  background: rgba(255,255,255,0.35);
  border: 1px solid rgba(90,60,20,0.25);
  box-shadow: 0 10px 20px rgba(0,0,0,0.15);
}

.card h2{
  margin: 0 0 6px;
  font-size: 18px;
  color: #2b1b10;
}

.card p{
  margin: 0;
  opacity: 0.85;
}

.footer{
  margin-top: 14px;
  text-align: center;
  opacity: 0.8;
  color: rgba(255,255,255,0.85);
  text-shadow: 0 10px 18px rgba(0,0,0,0.55);
}

/* mobile */
@media (max-width: 900px){
  .layout{ grid-template-columns: 1fr; }
  .brand__logo{ width: 64px; height: 64px; }
  .cards{ grid-template-columns: 1fr; }
  .brand__link{ display:inline-flex; }
}

/* ===== SOBRE: Moldura fixa + texto rolando dentro ===== */

.about-frame{
  position: relative;
  width: min(980px, 92vw);
  height: min(740px, 78vh);     /* altura da “janela” do Sobre */
  margin: 0 auto;

  /* espaço interno para o texto não encostar na moldura */
  padding: 90px 160px;
}

/* Moldura na frente (sempre por cima) */
.about-frame::before{
  content: "";
  position: absolute;
  inset: 0;
  background: url("/assets/img/moldura_woodbones001a.png") center/contain no-repeat;
  z-index: 3;
  pointer-events: none;
}

/* Área que rola o texto */
.about-frame__scroll{
  position: relative;
  z-index: 2;
  height: 90%;
  overflow: auto;

  padding: 32px 120px;
  border-radius: 14px;

  background: rgba(0,0,0,0.28);
  color: var(--ink);
  line-height: 1.65;
  text-shadow: 0 2px 8px rgba(0,0,0,.65);
}

/* títulos dentro da moldura */
.about-frame__scroll h1{
  margin: 0 0 12px;
  font-size: 2.2rem;
  color: #f6e4b5;
}

.about-frame__scroll h2{
  margin: 18px 0 8px;
  font-size: 1.35rem;
  color: #f6e4b5;
}

/* scrollbar discreta */
.about-frame__scroll::-webkit-scrollbar{ width: 10px; } /* Largura da barra de */
.about-frame__scroll::-webkit-scrollbar-thumb{
  background: rgba(214,177,92,.35);
  border-radius: 10px;
}
.about-frame__scroll::-webkit-scrollbar-track{
  background: rgba(0,0,0,.15);
}

/* responsivo */
@media (max-width: 900px){ /* Largura da area onde fica o texto */
  .about-frame{ padding: 70px 30px; }
}
@media (max-width: 520px){
  .about-frame{ padding: 58px 18px; height: min(680px, 78vh); }
  .about-frame__scroll{ padding: 16px; }
}
