/* ============================================================
   Associação de Moradores dos Redondos
   Archetype: two-soul broadsheet / editorial diptych
   Sensory hook: the handwritten "quadro da semana" + warm table
   Palette (brand): #fefefe #000 #f69a5e #aaa59d #cbd0dc #f9ea73
   + the living reds & blues of the house (chairs/tatamis/cloths)
   ============================================================ */

:root{
  --paper:#fefefe;
  --ink:#16140f;
  --ink-soft:#4a463d;
  --salmon:#f69a5e;
  --yellow:#f9ea73;
  --grey:#aaa59d;
  --blue:#2f4b86;        /* the tatami / tablecloth blue, deepened for text */
  --blue-soft:#cbd0dc;
  --red:#b5232b;         /* the chair / tatami red, deepened */
  --line:#1a1813;
  --chalk-bg:#1d2435;    /* deep blue-slate board */
  --chalk:#f3efe6;
  --maxw:1280px;
  --rail-w:84px;
  font-synthesis:none;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:"Archivo",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;}
h1,h2,h3{margin:0;line-height:1.02;}

/* paper grain so #fefefe never reads as cold corporate white */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(circle at 18% 12%, rgba(246,154,94,.10), transparent 42%),
    radial-gradient(circle at 88% 78%, rgba(203,208,220,.18), transparent 50%),
    var(--paper);
}

/* ---------- typography helpers ---------- */
.sec-title{
  font-family:"Archivo Black",Impact,sans-serif;
  font-weight:900;
  font-size:clamp(2rem,4.4vw,3.6rem);
  letter-spacing:-.02em;
  text-transform:uppercase;
}
.sec-lead{
  max-width:46ch;color:var(--ink-soft);
  font-size:1.06rem;margin:.9rem 0 0;
}
.tag{
  display:inline-block;font-weight:800;text-transform:uppercase;
  letter-spacing:.14em;font-size:.72rem;
  padding:.4em .8em;border:2px solid var(--ink);border-radius:2px;
  margin-bottom:1rem;
}
.tag--blue{background:var(--blue);color:#fff;border-color:var(--blue);}
.tag--red{background:var(--red);color:#fff;border-color:var(--red);}
.tag--chalk{background:var(--yellow);color:var(--ink);border-color:var(--ink);}

/* ============================================================
   SELO (emblem stamp)
   ============================================================ */
.selo{display:inline-block;width:118px;height:118px;}
.selo__svg{width:100%;height:100%;overflow:visible;}
.selo__ring,.selo__ringInner{fill:none;stroke:var(--red);stroke-width:2.4;}
.selo__ringInner{stroke:var(--blue);stroke-width:1.6;}
.selo__text{
  font-family:"Archivo",sans-serif;font-weight:800;
  font-size:7.1px;letter-spacing:.5px;fill:var(--ink);
}
.selo__amr{
  font-family:"Archivo Black",sans-serif;font-size:22px;
  fill:var(--ink);text-anchor:middle;letter-spacing:1px;
}
.selo__sub{
  font-family:"Archivo",sans-serif;font-weight:800;font-size:8px;
  fill:var(--blue);text-anchor:middle;letter-spacing:2.5px;
}

/* ============================================================
   RAIL (side navigation)
   ============================================================ */
.rail{
  position:fixed;top:0;left:0;bottom:0;width:var(--rail-w);z-index:50;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:18px 0;
  background:var(--ink);color:var(--paper);
  border-right:3px solid var(--red);
}
.rail__mark{
  font-family:"Archivo Black",sans-serif;text-decoration:none;color:var(--yellow);
  writing-mode:vertical-rl;transform:rotate(180deg);
  letter-spacing:.18em;font-size:.95rem;
}
.rail__links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.05rem;}
.rail__links a{
  writing-mode:vertical-rl;text-decoration:none;
  font-weight:700;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.62);transition:color .2s, transform .2s;
}
.rail__links a:hover,.rail__links a:focus-visible{color:var(--yellow);transform:translateY(-2px);}
.rail__year{
  font-family:"Archivo Black",sans-serif;color:var(--blue-soft);
  writing-mode:vertical-rl;font-size:.8rem;letter-spacing:.2em;
}

main{margin-left:var(--rail-w);}

/* ============================================================
   MASTHEAD
   ============================================================ */
.masthead{
  display:grid;grid-template-columns:1.05fr 1fr;min-height:100svh;
  border-bottom:4px solid var(--ink);
}
.masthead__photo{
  background:#9aa0ac url("../img/fachada.jpg") center/cover no-repeat;
  position:relative;border-right:4px solid var(--ink);
}
.masthead__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.12), rgba(47,75,134,.18));
}
.masthead__paper{
  padding:clamp(1.6rem,3.4vw,3.4rem);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
}
.masthead__kicker{
  margin:0 0 1.1rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;font-size:.74rem;color:var(--ink-soft);
  border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);
  padding:.55rem 0;
}
.masthead__title{
  font-family:"Archivo Black",Impact,sans-serif;
  text-transform:uppercase;letter-spacing:-.025em;
  font-size:clamp(2.5rem,6vw,5rem);
}
.masthead__l1{display:block;}
.masthead__l2{display:block;color:var(--red);}
.masthead__seal-slot{margin:1.2rem 0 .4rem;}
.masthead__seal-slot .selo{width:104px;height:104px;}
.masthead__lead{
  font-size:clamp(1.05rem,1.5vw,1.28rem);max-width:42ch;
  color:var(--ink);margin:.4rem 0 1.8rem;line-height:1.45;
}
.masthead__doors{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:560px;}
.door{
  text-decoration:none;color:#fff;padding:1.1rem 1.2rem;border-radius:3px;
  display:flex;flex-direction:column;gap:.3rem;
  transition:transform .25s ease, box-shadow .25s ease;
}
.door--blue{background:var(--blue);}
.door--red{background:var(--red);}
.door__tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;opacity:.85;}
.door__name{font-family:"Archivo Black",sans-serif;font-size:1.5rem;}
.door:hover,.door:focus-visible{transform:translateY(-4px);box-shadow:8px 8px 0 var(--ink);}

/* ============================================================
   RIBBON / motto marquee
   ============================================================ */
.ribbon{
  background:var(--ink);color:var(--paper);overflow:hidden;
  border-top:3px solid var(--yellow);border-bottom:3px solid var(--yellow);
  padding:.7rem 0;
}
.ribbon--alt{background:var(--red);border-color:var(--paper);}
.ribbon__track{
  display:inline-flex;align-items:center;gap:1.6rem;white-space:nowrap;
  font-family:"Archivo Black",sans-serif;text-transform:uppercase;
  font-size:1.15rem;letter-spacing:.04em;
  will-change:transform;animation:marquee 26s linear infinite;
}
.ribbon__dot{color:var(--yellow);font-size:.7em;}
.ribbon--alt .ribbon__dot{color:var(--ink);}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ============================================================
   DUAS ALMAS (diptych)
   ============================================================ */
.almas{
  position:relative;display:grid;grid-template-columns:1fr 1fr;
}
.almas__spine{
  position:absolute;top:0;bottom:0;left:50%;width:4px;
  background:var(--ink);transform:translateX(-50%);z-index:2;
}
.almas__spine::before,.almas__spine::after{
  content:"";position:absolute;left:50%;transform:translateX(-50%);
  width:18px;height:18px;background:var(--yellow);border:3px solid var(--ink);
  border-radius:50%;
}
.almas__spine::before{top:-9px;}
.almas__spine::after{bottom:-9px;}
.alma{padding:clamp(2rem,4.5vw,4.5rem);}
.alma--blue{background:var(--blue);color:#eef1f8;}
.alma--red{background:var(--red);color:#fdeee9;}
.alma__eyebrow{text-transform:uppercase;letter-spacing:.18em;font-weight:800;font-size:.75rem;opacity:.85;margin:0 0 .8rem;}
.alma__h{font-family:"Archivo Black",sans-serif;font-size:clamp(1.9rem,3.6vw,3rem);text-transform:uppercase;letter-spacing:-.02em;}
.alma__p{margin:1.1rem 0 1.6rem;max-width:38ch;font-size:1.08rem;line-height:1.5;}
.alma__go{
  display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;
  font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;
  border-bottom:2px solid currentColor;padding-bottom:.2rem;
}
.alma__go i{font-style:normal;transition:transform .2s;}
.alma__go:hover i{transform:translateX(5px);}

/* ============================================================
   COLETIVIDADE / MODALIDADES
   ============================================================ */
.coletiv{padding:clamp(3rem,6vw,6rem) clamp(1.4rem,5vw,5rem);max-width:var(--maxw);}
.coletiv__head{margin-bottom:2.4rem;}
.sec-title{color:var(--ink);}
.coletiv .sec-title{max-width:14ch;}

.modal-list{
  list-style:none;margin:0 0 3rem;padding:0;
  border-top:3px solid var(--ink);
}
.modal-list li{
  display:flex;align-items:baseline;gap:1.2rem;
  border-bottom:1px solid rgba(26,24,19,.22);
  padding:.7rem .2rem;
  transition:background .2s, padding-left .2s;
}
.modal-list li:hover{background:var(--blue-soft);padding-left:1rem;}
.modal-list__n{font-family:"Archivo Black",sans-serif;color:var(--blue);font-size:.9rem;min-width:2.4ch;}
.modal-list__name{font-family:"Archivo Black",sans-serif;text-transform:uppercase;font-size:clamp(1.3rem,2.6vw,2.1rem);letter-spacing:-.01em;}

.coletiv__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  grid-auto-rows:200px;
}
.ph{position:relative;margin:0;overflow:hidden;border:3px solid var(--ink);background:#ddd;}
.ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.ph:hover img{transform:scale(1.06);}
.ph--tall{grid-row:span 2;}
.ph--wide{grid-column:span 2;}
.ph figcaption{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.82));
  color:#fff;font-size:.82rem;font-weight:600;padding:1.4rem .8rem .7rem;
}
.instal{
  list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:2.2rem 0 0;padding:0;
}
.instal li{
  border:2px solid var(--ink);border-radius:999px;padding:.5rem 1.1rem;
  font-weight:700;font-size:.85rem;
}

/* ============================================================
   QUADRO DA SEMANA (sensory hook)
   ============================================================ */
.quadro{
  background:var(--chalk-bg);color:var(--chalk);
  padding:clamp(3rem,6vw,6rem) clamp(1.4rem,5vw,5rem);
  position:relative;
  border-top:4px solid var(--ink);border-bottom:4px solid var(--ink);
}
.quadro::before{
  /* chalk dust / faint frame, like a real board */
  content:"";position:absolute;inset:18px;border:2px solid rgba(243,239,230,.16);
  pointer-events:none;border-radius:4px;
}
.quadro__intro{position:relative;max-width:54ch;margin-bottom:2.4rem;}
.quadro__title{
  font-family:"Caveat",cursive;font-weight:700;
  font-size:clamp(3rem,7vw,5.4rem);line-height:.95;color:var(--chalk);
}
.quadro__lead{color:rgba(243,239,230,.78);margin-top:.4rem;font-size:1.08rem;}

.board{
  position:relative;display:grid;grid-template-columns:repeat(7,1fr);gap:0;
  border:2px solid rgba(243,239,230,.3);
}
.board__col{
  display:flex;flex-direction:column;gap:.5rem;
  padding:1.4rem 1rem 1.8rem;
  border-right:1px dashed rgba(243,239,230,.22);
  min-height:230px;
  transition:background .4s ease;
}
.board__col:last-child{border-right:none;}
.board__day{
  font-family:"Caveat",cursive;font-size:1.7rem;font-weight:700;
  color:var(--salmon);border-bottom:1px solid rgba(243,239,230,.25);padding-bottom:.3rem;
}
.board__dish{
  font-family:"Caveat",cursive;font-size:1.5rem;line-height:1.05;color:var(--chalk);
}
.board__dish--rest{color:rgba(243,239,230,.55);}
.board__note{font-size:.78rem;color:rgba(243,239,230,.6);margin-top:auto;font-style:italic;}

.board__col.is-today{background:rgba(246,154,94,.16);}
.board__col.is-today .board__day{color:var(--yellow);}
.board__col.is-today::after{
  content:"hoje";position:absolute;margin-top:-.2rem;
  font-family:"Archivo Black",sans-serif;font-size:.6rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);background:var(--yellow);
  padding:.15rem .45rem;border-radius:2px;transform:translateY(-2.4rem);
}
.board__live{position:relative;margin:1.4rem 0 0;color:rgba(243,239,230,.8);font-family:"Caveat",cursive;font-size:1.4rem;}

/* ============================================================
   A MESA / EMENTA
   ============================================================ */
.mesa{
  display:grid;grid-template-columns:1fr 1fr;align-items:stretch;
}
.mesa__star{position:relative;margin:0;overflow:hidden;min-height:520px;background:#3a1f17;}
.mesa__star img{width:100%;height:100%;object-fit:cover;}
.mesa__starcap{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(180deg,transparent,rgba(40,12,6,.92));
  padding:4rem 1.6rem 1.6rem;color:#fff;display:flex;flex-direction:column;gap:.3rem;
}
.mesa__starkick{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--yellow);font-weight:800;}
.mesa__starname{font-family:"Archivo Black",sans-serif;font-size:clamp(2rem,4vw,3rem);text-transform:uppercase;}
.mesa__startxt{max-width:38ch;font-size:.98rem;color:#f3e6df;}
.mesa__menu{background:var(--red);color:#fdeee9;padding:clamp(2rem,4vw,4rem);}
.mesa__menu .sec-title{color:#fff;}
.mesa__menu .tag--red{background:#fff;color:var(--red);border-color:#fff;}
.menu-block{margin-top:1.8rem;}
.menu-block h3{
  font-family:"Archivo Black",sans-serif;text-transform:uppercase;font-size:1rem;
  letter-spacing:.06em;color:var(--yellow);
  border-bottom:2px solid rgba(255,255,255,.4);padding-bottom:.4rem;margin-bottom:.5rem;
}
.menu-list{list-style:none;margin:0;padding:0;}
.menu-list li{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;padding:.4rem 0;border-bottom:1px dotted rgba(255,255,255,.28);}
.menu-list li span{font-weight:600;font-size:1.05rem;}
.menu-list li em{font-style:normal;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;opacity:.78;white-space:nowrap;}
.mesa__foot{margin-top:1.8rem;font-size:.95rem;line-height:1.5;color:#fbe4dc;}
.mesa__foot strong{color:#fff;}

/* ============================================================
   COMUNIDADE / MURAL
   ============================================================ */
.comun{padding:clamp(3rem,6vw,6rem) clamp(1.4rem,5vw,5rem);max-width:var(--maxw);}
.comun__head{margin-bottom:2.4rem;}
.mural{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:190px;gap:14px;}
.mural__it{position:relative;margin:0;overflow:hidden;border:3px solid var(--ink);background:#ddd;}
.mural__it img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.mural__it:hover img{transform:scale(1.05);}
.mural__it--big{grid-column:span 2;grid-row:span 2;}
.mural__it--wide{grid-column:span 2;}
.mural__it figcaption{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.82));
  color:#fff;font-size:.82rem;font-weight:600;padding:1.4rem .8rem .7rem;
}

.vozes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:3rem 0;}
.voz{
  margin:0;padding:1.6rem;border:3px solid var(--ink);background:#fff;
  position:relative;
}
.voz::before{content:"“";position:absolute;top:-.4rem;left:.6rem;font-family:"Archivo Black",sans-serif;font-size:3.5rem;color:var(--salmon);}
.voz p{margin:.6rem 0 1rem;font-size:1rem;line-height:1.45;}
.voz cite{font-style:normal;font-weight:800;font-size:.82rem;color:var(--blue);letter-spacing:.02em;}

.quem{display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:center;margin-top:1rem;}
.quem__ph{margin:0;border:3px solid var(--ink);overflow:hidden;}
.quem__ph img{width:100%;height:100%;object-fit:cover;}
.quem__txt h3{font-family:"Archivo Black",sans-serif;text-transform:uppercase;font-size:1.6rem;color:var(--ink);}
.quem__txt p{max-width:46ch;color:var(--ink-soft);margin:.7rem 0 1.4rem;}
.quem__people{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:14px;}
.quem__people li{border-left:4px solid var(--red);padding:.2rem 0 .2rem .8rem;}
.quem__people strong{display:block;font-size:1.05rem;}
.quem__people span{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);}

/* ============================================================
   VISITAR / FOOTER
   ============================================================ */
.visitar{
  background:var(--ink);color:var(--paper);
  padding:clamp(2.6rem,5vw,4.5rem) clamp(1.4rem,5vw,5rem) 3rem;
  border-top:4px solid var(--red);
}
.visitar__seal-slot{display:flex;justify-content:center;margin-bottom:2rem;}
.visitar__seal-slot .selo__amr{fill:var(--paper);}
.visitar__seal-slot .selo__text{fill:var(--blue-soft);}
.visitar__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;max-width:var(--maxw);margin:0 auto;}
.vcard h3{font-family:"Archivo Black",sans-serif;text-transform:uppercase;font-size:1.05rem;color:var(--yellow);margin-bottom:1rem;letter-spacing:.04em;}
.hours{width:100%;border-collapse:collapse;font-size:.95rem;}
.hours th{text-align:left;font-weight:600;padding:.32rem 0;color:#fff;}
.hours td{text-align:right;padding:.32rem 0;color:var(--blue-soft);}
.hours tr{border-bottom:1px solid rgba(255,255,255,.12);}
.hours tr.is-today th,.hours tr.is-today td{color:var(--yellow);font-weight:800;}
.vcard__hint{font-size:.8rem;color:var(--grey);margin-top:1rem;line-height:1.4;}
.contact{list-style:none;margin:0;padding:0;}
.contact li{display:flex;justify-content:space-between;gap:1rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.12);}
.contact li span{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--grey);}
.contact a{color:#fff;text-decoration:none;font-weight:600;}
.contact a:hover{color:var(--yellow);}
.social{display:flex;gap:12px;margin-top:1.2rem;}
.social a{border:2px solid var(--paper);border-radius:999px;padding:.4rem 1rem;text-decoration:none;font-weight:700;font-size:.82rem;}
.social a:hover{background:var(--paper);color:var(--ink);}
address{font-style:normal;line-height:1.7;font-size:1rem;}
.maplink{display:inline-block;margin-top:1rem;color:var(--yellow);text-decoration:none;font-weight:800;}
.maplink:hover{text-decoration:underline;}
.visitar__motto{
  text-align:center;font-family:"Caveat",cursive;font-size:clamp(1.5rem,3vw,2.3rem);
  color:var(--salmon);max-width:30ch;margin:3rem auto 0;line-height:1.15;
}
.visitar__legal{text-align:center;color:var(--grey);font-size:.78rem;margin:1rem auto 0;max-width:60ch;}

/* ============================================================
   FOCUS / a11y
   ============================================================ */
a:focus-visible,.door:focus-visible{outline:3px solid var(--yellow);outline-offset:3px;}
.quadro a:focus-visible{outline-color:var(--salmon);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .masthead{grid-template-columns:1fr;}
  .masthead__photo{min-height:42svh;border-right:none;border-bottom:4px solid var(--ink);}
  .coletiv__grid{grid-template-columns:repeat(2,1fr);}
  .mesa{grid-template-columns:1fr;}
  .mesa__star{min-height:380px;}
  .mural{grid-template-columns:repeat(2,1fr);}
  .vozes{grid-template-columns:1fr;}
  .quem{grid-template-columns:1fr;}
  .visitar__grid{grid-template-columns:1fr;}
  .board{grid-template-columns:1fr;}
  .board__col{border-right:none;border-bottom:1px dashed rgba(243,239,230,.22);min-height:auto;flex-direction:row;flex-wrap:wrap;align-items:baseline;gap:.8rem;}
  .board__col .board__note{margin:0;}
  .board__col.is-today::after{transform:translateY(0);position:static;margin-left:auto;}
}
@media (max-width:600px){
  :root{--rail-w:0px;}
  .rail{
    position:sticky;top:0;left:0;right:0;bottom:auto;width:100%;height:auto;
    flex-direction:row;justify-content:space-between;padding:.6rem 1rem;
    border-right:none;border-bottom:3px solid var(--red);
  }
  .rail__mark{writing-mode:horizontal-tb;transform:none;}
  .rail__links{flex-direction:row;gap:.7rem;overflow-x:auto;}
  .rail__links a{writing-mode:horizontal-tb;font-size:.66rem;}
  .rail__year{display:none;}
  .almas{grid-template-columns:1fr;}
  .almas__spine{display:none;}
  .masthead__doors{grid-template-columns:1fr;}
  .coletiv__grid{grid-template-columns:1fr;grid-auto-rows:220px;}
  .ph--wide,.ph--tall{grid-column:auto;grid-row:auto;}
  .mural{grid-template-columns:1fr;}
  .mural__it--big,.mural__it--wide{grid-column:auto;grid-row:auto;}
}

/* ============================================================
   REDUCED MOTION — everything visible, no animation
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .ribbon__track{animation:none;}
  .ph img,.mural__it img{transition:none;}
  *{scroll-behavior:auto !important;}
}
