/* =========================================================
   Confeitaria Santa Coina — Vitrine / bento montra
   Palette (extra.brand):
   Branco Requeijão #eaf8f5 · Dourado das Coininhas #d1a760
   Pedra de Moinho #645452 · Castanho de Forno #16110c
   Areia de Amêndoa #e1cda5 · Caramelo Queimado #5c250d
   ========================================================= */

:root{
  --requeijao:#eaf8f5;
  --dourado:#d1a760;
  --pedra:#645452;
  --forno:#16110c;
  --amendoa:#e1cda5;
  --caramelo:#5c250d;

  --paper:#f4efe4;          /* bleached-pine paper warmth */
  --paper-2:#ece3d2;
  --ink:#231a12;
  --gold-deep:#a87f3e;

  --shadow: 0 18px 40px -20px rgba(35,26,18,.45);
  --shadow-lift: 0 30px 60px -24px rgba(35,26,18,.55);
  --r:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Mulish",system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(120% 80% at 50% -10%, #fffdf8 0%, var(--requeijao) 55%, #dbeee9 100%);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}

::selection{background:var(--dourado);color:#fff}
:focus-visible{outline:3px solid var(--caramelo);outline-offset:3px;border-radius:6px}

.script-title{
  font-family:"Parisienne",cursive;
  font-weight:400;
  color:var(--caramelo);
  line-height:1;
  font-size:clamp(2.4rem,5.5vw,4.2rem);
  margin:.1em 0 .35em;
}

/* bleached-pine wood texture used on card/section surfaces */
.wood-grain{
  background-color:var(--paper);
  background-image:
    repeating-linear-gradient(91deg,
      rgba(168,127,62,.05) 0 2px,
      rgba(168,127,62,0) 2px 9px),
    repeating-linear-gradient(91deg,
      rgba(92,37,13,.04) 0 1px,
      rgba(92,37,13,0) 1px 26px);
}

/* ===================== TOPBAR ===================== */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:.55rem clamp(1rem,4vw,3rem);
  background:rgba(244,239,228,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(168,127,62,.28);
}
.topbar__brand{display:flex;flex-direction:column;text-decoration:none;line-height:1}
.topbar__script{font-family:"Parisienne",cursive;font-size:1.9rem;color:var(--caramelo)}
.topbar__sub{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--pedra);margin-top:.1rem}
.topbar__nav{display:flex;gap:clamp(.7rem,2vw,1.8rem)}
.topbar__nav a{
  text-decoration:none;font-weight:700;font-size:.82rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--forno);padding:.3rem 0;position:relative;
}
.topbar__nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--dourado);
  transition:width .3s ease;
}
.topbar__nav a:hover::after,.topbar__nav a:focus-visible::after{width:100%}

/* ===================== HERO VITRINE (bento) ===================== */
.vitrine{
  display:grid;gap:clamp(.6rem,1.4vw,1rem);
  padding:clamp(1rem,3vw,2.2rem) clamp(1rem,4vw,3rem) clamp(2rem,4vw,3rem);
  max-width:1280px;margin:0 auto;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:auto auto;
  grid-template-areas:
    "jewel jewel jewel medal"
    "jewel jewel jewel stat"
    "wide  wide  wide  stat";
}
@media(max-width:860px){
  .vitrine{
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "jewel jewel"
      "medal stat"
      "wide  wide";
  }
}
@media(max-width:560px){
  .vitrine{grid-template-columns:1fr;
    grid-template-areas:"jewel" "medal" "wide" "stat";}
}

.tray{
  position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(168,127,62,.3);
  isolation:isolate;
}
.tray--jewel{grid-area:jewel;min-height:clamp(360px,52vh,560px)}
.tray--medal{grid-area:medal}
.tray--wide{grid-area:wide;min-height:200px}
.tray--stat{grid-area:stat}

.tray__photo{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:0}

/* the glass front of every tray + the moving specular gloss = the sensory hook */
.tray__glass{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(135deg,
     rgba(255,255,255,.30) 0%,
     rgba(255,255,255,0) 22%,
     rgba(255,255,255,0) 60%,
     rgba(255,255,255,.10) 100%);
}
/* sweeping highlight bar */
.tray__glass::after{
  content:"";position:absolute;top:-30%;left:-60%;width:45%;height:160%;
  transform:rotate(18deg);
  background:linear-gradient(90deg,
     rgba(255,255,255,0) 0%,
     rgba(255,255,255,.55) 50%,
     rgba(255,255,255,0) 100%);
  filter:blur(2px);
}
.tray--jewel .tray__glass::after{animation:sweep 6.5s ease-in-out infinite}
@keyframes sweep{
  0%   {left:-60%}
  55%  {left:130%}
  100% {left:130%}
}

.tray__veil{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,
    rgba(22,17,12,.05) 0%,
    rgba(22,17,12,.20) 45%,
    rgba(22,17,12,.78) 100%);
}
.tray__plate{
  position:absolute;z-index:3;inset:auto 0 0 0;
  padding:clamp(1.3rem,3.5vw,2.6rem);color:#fff;
  max-width:40ch;
}
.tray__eyebrow{
  font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--amendoa);margin:0 0 .3rem;font-weight:700;
}
.tray__wordmark{
  font-family:"Parisienne",cursive;font-weight:400;
  font-size:clamp(3rem,9vw,6.2rem);line-height:.85;margin:0;
  color:#fff;text-shadow:0 6px 26px rgba(0,0,0,.5);
}
.tray__lede{
  font-size:clamp(.95rem,1.4vw,1.08rem);margin:.7rem 0 1.1rem;
  color:#f6efe2;max-width:34ch;
}
.tray__lede em{color:var(--dourado);font-style:italic}

.btn{
  display:inline-block;text-decoration:none;font-weight:800;
  letter-spacing:.05em;font-size:.82rem;text-transform:uppercase;
  padding:.72rem 1.5rem;border-radius:999px;
  background:var(--dourado);color:#1c1208;
  border:1px solid #f2dca8;
  box-shadow:0 8px 20px -8px rgba(0,0,0,.6);
  transition:transform .25s ease,background .25s ease;
}
.btn:hover{transform:translateY(-2px);background:#e0bd78}

/* medal tray */
.tray--medal{
  background:var(--paper);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.7rem;padding:1.4rem 1.2rem;text-align:center;min-height:170px;
}
.seal{position:relative;width:96px;height:96px;display:grid;place-items:center;color:var(--gold-deep)}
.seal__ring{width:100%;height:100%}
.seal__num{
  position:absolute;font-family:"Parisienne",cursive;font-size:2.6rem;color:var(--caramelo);
}
.tray--medal .tray__label{
  margin:0;font-size:.84rem;color:var(--pedra);font-weight:600;line-height:1.4;max-width:26ch;
}

/* corner label on wide tray */
.tray__corner{
  position:absolute;z-index:3;left:0;bottom:0;
  background:var(--paper);color:var(--caramelo);
  font-weight:800;letter-spacing:.04em;text-transform:uppercase;font-size:.72rem;
  padding:.5rem .9rem;border-top-right-radius:12px;
  border:1px solid rgba(168,127,62,.4);border-left:0;border-bottom:0;
}

/* stat tray */
.tray--stat{
  background:linear-gradient(160deg,var(--caramelo),#3a1607);
  color:#fff;display:flex;flex-direction:column;justify-content:center;
  padding:1.4rem 1.3rem;gap:.3rem;min-height:170px;
}
.stat__big{font-family:"Cormorant Garamond",serif;font-size:3.4rem;font-weight:600;margin:0;line-height:1}
.stat__big span{color:var(--dourado);font-size:2rem}
.stat__small{margin:0;color:#f0e2cb;font-size:.9rem}

/* ===================== CASE / DOCES ===================== */
.case{
  max-width:1240px;margin:0 auto;
  padding:clamp(2.5rem,6vw,5rem) clamp(1rem,4vw,3rem);
}
.case__head{text-align:center;max-width:60ch;margin:0 auto clamp(1.6rem,3vw,2.6rem)}
.case__intro{color:var(--pedra);font-size:1.05rem;margin:0 auto;max-width:52ch}

.ornament{display:inline-block;width:58px;height:58px;color:var(--dourado);margin-bottom:.2rem}
.ornament svg{width:100%;height:100%}

.case__grid{
  display:grid;gap:clamp(.8rem,1.6vw,1.3rem);
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:1fr;
}
.doce{
  grid-column:span 2;
  display:flex;flex-direction:column;
  border-radius:var(--r);overflow:hidden;
  background:var(--paper);
  border:1px solid rgba(168,127,62,.3);
  box-shadow:var(--shadow);
  transition:transform .3s ease,box-shadow .3s ease;
}
.doce--hero{grid-column:span 3;grid-row:span 2}
.doce--wide{grid-column:span 3}
@media(max-width:900px){
  .case__grid{grid-template-columns:repeat(2,1fr)}
  .doce,.doce--hero,.doce--wide{grid-column:span 1;grid-row:auto}
}
@media(max-width:560px){
  .case__grid{grid-template-columns:1fr}
  .doce,.doce--hero,.doce--wide{grid-column:1}
}

.doce__media{position:relative;overflow:hidden;flex:1 1 auto;min-height:190px}
.doce--hero .doce__media{min-height:320px}
.doce__media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;
  transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.doce:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.doce:hover .doce__media img{transform:scale(1.06)}
/* glass gloss slides across on hover/focus — opening the montra */
.doce .tray__glass::after{transition:none}
.doce:hover .tray__glass::after,
.doce:focus-within .tray__glass::after{animation:sweep 1.1s ease-out}

.doce__body{padding:1.1rem 1.2rem 1.3rem;background:var(--paper)}
.doce--hero .doce__body{padding:1.4rem 1.5rem 1.6rem}

.plaquinha{
  display:inline-block;font-weight:800;letter-spacing:.02em;
  color:#3c2a14;background:linear-gradient(180deg,#e7d4ad,#d8bf8d);
  border:1px solid #c4a061;border-radius:7px;
  padding:.32rem .7rem;font-size:.92rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 2px 4px rgba(0,0,0,.12);
  margin-bottom:.55rem;
}
.doce--hero .plaquinha{font-size:1.05rem}
.badge{
  display:inline-block;margin:0 0 .55rem .4rem;
  font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:800;
  color:var(--pedra);border:1px solid var(--pedra);border-radius:999px;padding:.18rem .6rem;
}
.badge--gold{color:var(--caramelo);border-color:var(--dourado);background:rgba(209,167,96,.16)}
.doce__body p{margin:.2rem 0 0;color:#4a3d31;font-size:.96rem}

/* ===================== CASA ===================== */
.casa{
  position:relative;
  display:grid;gap:clamp(1.5rem,4vw,3.5rem);
  grid-template-columns:1.05fr 1fr;align-items:center;
  max-width:1180px;margin:0 auto;
  padding:clamp(2.5rem,6vw,5rem) clamp(1rem,4vw,3rem);
}
@media(max-width:840px){.casa{grid-template-columns:1fr}}
.casa__medal{margin:0;position:relative}
.casa__medal img{
  width:100%;border-radius:50%/48%;border-radius:var(--r);
  box-shadow:var(--shadow-lift);border:6px solid #fff;
  outline:1px solid rgba(168,127,62,.4);
}
.casa__medal figcaption{
  text-align:center;font-style:italic;color:var(--pedra);font-size:.85rem;margin-top:.7rem;
}
.casa__text{position:relative}
.ornament--left{margin-bottom:.4rem}
.casa__lead{font-size:1.15rem;color:var(--forno);font-weight:600}
.casa__text p{color:#4a3d31}
.casa__facts{
  list-style:none;padding:0;margin:1.4rem 0 0;
  display:flex;flex-wrap:wrap;gap:.7rem;
}
.casa__facts li{
  background:var(--paper);border:1px solid rgba(168,127,62,.35);border-radius:12px;
  padding:.6rem .9rem;font-size:.85rem;color:var(--pedra);line-height:1.25;
}
.casa__facts strong{display:block;color:var(--caramelo);font-family:"Cormorant Garamond",serif;
  font-size:1.25rem;font-weight:600}

/* ===================== VOZES ===================== */
.vozes{
  background:
    linear-gradient(180deg,rgba(92,37,13,.06),rgba(92,37,13,.10));
  border-top:1px solid rgba(168,127,62,.3);
  border-bottom:1px solid rgba(168,127,62,.3);
  padding:clamp(2.5rem,6vw,5rem) clamp(1rem,4vw,3rem);
}
.vozes__head{text-align:center;margin-bottom:clamp(1.4rem,3vw,2.4rem)}
.vozes__grid{
  max-width:1100px;margin:0 auto;
  display:grid;gap:clamp(.9rem,2vw,1.4rem);
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}
.cartela{
  position:relative;margin:0;background:var(--paper);
  border:1px solid rgba(168,127,62,.35);border-radius:var(--r);
  padding:2.4rem 1.4rem 1.3rem;box-shadow:var(--shadow);
}
.cartela::before{
  content:"\201C";position:absolute;top:-.1em;left:.35em;
  font-family:"Cormorant Garamond",serif;font-size:4.2rem;color:var(--dourado);line-height:1;
}
.cartela p{margin:0 0 .8rem;color:#4a3d31;font-size:.98rem}
.cartela cite{font-style:normal;font-weight:800;font-size:.78rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--caramelo)}

/* ===================== VISITAR ===================== */
.visitar{
  display:grid;grid-template-columns:1.1fr 1fr;
  max-width:1240px;margin:0 auto;gap:clamp(1.2rem,3vw,2.2rem);
  padding:clamp(2.5rem,6vw,5rem) clamp(1rem,4vw,3rem);align-items:stretch;
}
@media(max-width:860px){.visitar{grid-template-columns:1fr}}
.visitar__panel{
  background:var(--paper);border:1px solid rgba(168,127,62,.35);
  border-radius:var(--r);padding:clamp(1.4rem,3vw,2.4rem);box-shadow:var(--shadow);
}
.visitar__note{color:var(--pedra)}
.visitar__note strong{color:var(--caramelo)}
.visitar__cols{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:1.3rem;margin-top:1.4rem;
}
.info h3{font-family:"Cormorant Garamond",serif;font-size:1.3rem;color:var(--caramelo);
  margin:0 0 .4rem;font-weight:600}
.info p{margin:.2rem 0;color:#4a3d31;font-size:.95rem}
.info a{color:var(--caramelo);text-decoration:none;font-weight:700}
.info a:hover{text-decoration:underline}
.info__muted{color:var(--pedra);font-size:.85rem !important;font-style:italic}
.hours{list-style:none;margin:0;padding:0}
.hours li{display:flex;justify-content:space-between;gap:1rem;
  padding:.22rem 0;border-bottom:1px dotted rgba(100,84,82,.3);font-size:.9rem;color:#4a3d31}
.hours li span:first-child{color:var(--pedra)}
.hours--off{color:var(--caramelo);opacity:.85}
.hours--off span:last-child{font-style:italic}
.socials{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:.6rem}

.visitar__map{position:relative;border-radius:var(--r);overflow:hidden;
  border:1px solid rgba(168,127,62,.35);box-shadow:var(--shadow);min-height:340px}
.visitar__map iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:sepia(.18) saturate(1.05)}
.map__link{
  position:absolute;right:.7rem;bottom:.7rem;background:var(--paper);
  padding:.45rem .85rem;border-radius:999px;text-decoration:none;font-weight:800;
  font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;color:var(--caramelo);
  border:1px solid rgba(168,127,62,.5);box-shadow:var(--shadow);
}

/* ===================== FOOT ===================== */
.foot{
  text-align:center;padding:clamp(2rem,5vw,3.5rem) 1rem;
  background:linear-gradient(180deg,#2a1c10,var(--forno));color:#e9dcc6;
}
.foot__script{font-family:"Parisienne",cursive;font-size:2.6rem;color:var(--dourado);display:block}
.foot p{margin:.35rem 0;font-size:.9rem}
.foot__fine{color:#b3a78d;font-size:.78rem}

/* ===================== REDUCED MOTION ===================== */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important;transition:none !important}
  .tray--jewel .tray__glass::after{display:none}
}
