/* ============ Guia Comercial — estilo público ============ */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#11181B;--forest:#1D4F47;--forest-2:#123833;--emerald:#2E776D;--emerald-2:#35ADB7;
  --gold:#C39A4B;--gold-2:#E3CB8F;--paper:#F5F1E9;--cream:#FBF8F2;--card:#FFFFFF;
  --line:#E8E1D3;--muted:#637069;--star:#E3A82C;
  --display:'Fraunces',Georgia,serif;--body:'Plus Jakarta Sans',system-ui,sans-serif;--maxw:1200px;--r:18px;
}
html,body{overflow-x:hidden}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--cream);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-wrap:break-word}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
@media(max-width:560px){.wrap{padding:0 15px}}
h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:-.02em;line-height:1.1}
.btn-reset{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(29,79,71,.96);backdrop-filter:blur(8px);color:#fff}
.nav-in{display:flex;align-items:center;gap:16px;height:66px}
.brand{display:flex;align-items:center;gap:11px;color:#fff;flex-shrink:0}
.brand .logo{height:46px;border-radius:10px;background:#fff;display:inline-flex;align-items:center;justify-content:center;padding:4px;box-sizing:border-box;box-shadow:0 6px 16px -6px #0007;flex-shrink:0}
.brand .logo img{height:100%;width:auto;display:block}
.brand .logo svg{width:20px;height:20px;color:#fff}
.brand b{font-family:var(--display);font-size:1.1rem;font-weight:600;display:block;line-height:1}
.brand span{font-size:.64rem;color:var(--gold-2);letter-spacing:.14em;text-transform:uppercase}
.nav-links{margin-left:auto;display:flex;align-items:center;gap:8px}
.nav-links a{font-size:.84rem;font-weight:700;color:rgba(255,255,255,.85);padding:8px 12px;border-radius:9px}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-cta{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#3a2c08!important;padding:9px 15px!important;border-radius:10px;display:inline-flex;align-items:center;gap:6px}
.nav-cta svg{width:15px;height:15px}
.nav-burg{display:none;color:#fff;width:40px;height:40px;align-items:center;justify-content:center;border-radius:9px}
@media(max-width:820px){
  .nav-links{position:fixed;inset:66px 0 auto 0;flex-direction:column;align-items:stretch;background:var(--forest);padding:10px 16px 16px;gap:4px;display:none;border-top:1px solid rgba(255,255,255,.1)}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px}
  .nav-burg{display:flex}
}

/* ---- hero ---- */
.hero{position:relative;background:radial-gradient(120% 100% at 50% -10%,#2E776D 0,#1D4F47 55%,#123833 100%);color:#fff;padding:56px 0 0;overflow:hidden}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.4}
.hero::before{width:380px;height:380px;background:#35ADB7;top:-120px;right:-80px;animation:float 9s ease-in-out infinite}
.hero::after{width:300px;height:300px;background:#C39A4B;bottom:-120px;left:-60px;opacity:.22;animation:float 11s ease-in-out infinite reverse}
@keyframes float{50%{transform:translate(30px,-24px) scale(1.08)}}
.hero-in{position:relative;z-index:2;max-width:900px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2);background:rgba(255,255,255,.06);border:1px solid rgba(227,203,143,.28);padding:8px 15px;border-radius:30px;font-weight:700}
.eyebrow svg{width:13px;height:13px}
.hero h1{font-size:clamp(2.4rem,6.5vw,4.6rem);margin:22px 0 0;font-weight:600}
.hero h1 .u{color:var(--gold-2)}
.hero p.sub{font-size:clamp(1rem,2.2vw,1.25rem);color:rgba(255,255,255,.82);max-width:620px;margin:18px 0 0;font-weight:300}
.hero p.sub b{font-weight:600;color:#fff}
.searchbox{margin-top:30px;display:flex;align-items:center;gap:8px;background:#fff;border-radius:16px;padding:7px 7px 7px 16px;max-width:600px;box-shadow:0 30px 60px -28px rgba(0,0,0,.55)}
.searchbox svg{width:20px;height:20px;color:var(--muted);flex-shrink:0}
.searchbox input{flex:1;border:none;outline:none;font-family:var(--body);font-size:1rem;color:var(--ink);background:none;min-width:0}
.searchbox button{background:linear-gradient(135deg,var(--forest),var(--emerald));color:#fff;border:none;font-family:var(--body);font-weight:700;padding:12px 20px;border-radius:11px;cursor:pointer;white-space:nowrap}
.stats{display:flex;gap:30px;margin-top:30px;flex-wrap:wrap}
.stat .num{font-family:var(--display);font-size:clamp(1.6rem,4vw,2.3rem);font-weight:600;color:#fff}
.stat .lab{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.wave{display:block;margin-top:34px}
.wave svg{display:block;width:100%;height:54px}

/* ---- section ---- */
.section{padding:44px 0}
.kick{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:800;color:var(--emerald)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(1.6rem,3.6vw,2.3rem);margin-top:6px}
.sec-head p{color:var(--muted);margin-top:4px;font-size:.95rem}
.count-info{font-size:.84rem;color:var(--muted);font-weight:600;white-space:nowrap}

/* ---- hub categorias ---- */
.hub{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,200px),1fr));gap:14px}
.seg{display:flex;flex-direction:column;align-items:flex-start;gap:8px;text-align:left;padding:20px;border-radius:16px;border:1px solid var(--line);background:#fff;cursor:pointer;font-family:var(--body);transition:.25s;position:relative;overflow:hidden;width:100%}
.seg:hover{transform:translateY(-3px);box-shadow:0 18px 40px -22px rgba(29,79,71,.5);border-color:var(--emerald)}
.seg .seg-ic{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--paper),#fff);border:1px solid var(--line);display:grid;place-items:center;color:var(--emerald)}
.seg .seg-ic svg{width:24px;height:24px}
.seg b{font-size:1.02rem;color:var(--ink)}
.seg .seg-n{font-size:.78rem;color:var(--muted)}
.seg.soon{opacity:.6;cursor:default}
.seg.soon:hover{transform:none;box-shadow:none;border-color:var(--line)}
.seg-soon{font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);background:rgba(195,154,75,.12);padding:3px 9px;border-radius:20px}
.seg.active{border-color:var(--gold);box-shadow:0 14px 36px -16px rgba(195,154,75,.6),inset 0 0 0 1px var(--gold)}
.seg.active .seg-ic{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff;border-color:transparent}

/* ---- filtros ---- */
.filterbar{position:sticky;top:66px;z-index:40;background:var(--cream);border-bottom:1px solid var(--line);padding:14px 0}
.chips-row{display:flex;gap:9px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.chips-row::-webkit-scrollbar{display:none}
.fchip{flex-shrink:0;border:1px solid var(--line);background:#fff;color:var(--ink);font-family:var(--body);font-weight:700;font-size:.84rem;padding:8px 14px;border-radius:11px;cursor:pointer;transition:.2s;white-space:nowrap}
.fchip i{font-style:normal;color:var(--muted);font-size:.74rem;margin-left:3px}
.fchip:hover{border-color:var(--emerald);transform:translateY(-1px)}
.fchip.active{background:linear-gradient(135deg,var(--forest),var(--emerald));color:#fff;border-color:transparent}
.fchip.active i{color:var(--gold-2)}
.controls-row{display:flex;gap:10px;align-items:center;margin-top:12px;flex-wrap:wrap}
.ctrl{position:relative;display:flex;align-items:center;min-width:0}
.ctrl-ic{position:absolute;left:12px;color:var(--muted);pointer-events:none;display:flex}
.ctrl-ic svg{width:16px;height:16px}
.ctrl-sel,.inp{font-family:var(--body);font-weight:600;font-size:.86rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 14px;cursor:pointer;outline:none;height:44px;max-width:100%}
.ctrl-sel.pad{padding-left:34px}
.ctrl-sel:focus,.inp:focus{border-color:var(--emerald)}
.tog-btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#fff;color:var(--ink);font-family:var(--body);font-weight:700;font-size:.84rem;padding:0 14px;height:44px;border-radius:12px;cursor:pointer;transition:.2s;white-space:nowrap}
.tog-btn svg{width:16px;height:16px;color:var(--muted)}
.tog-btn:hover{border-color:var(--emerald);transform:translateY(-1px)}
.tog-btn.on{background:linear-gradient(135deg,var(--forest),var(--emerald));color:#fff;border-color:transparent}
.tog-btn.on svg{color:var(--gold-2)}

/* ---- grid de cards ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;position:relative;box-shadow:0 6px 18px -12px rgba(29,79,71,.22)}
.card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -26px rgba(29,79,71,.5)}
.card.feat{border-color:rgba(195,154,75,.5);box-shadow:0 18px 44px -22px rgba(195,154,75,.55)}
.cover{position:relative;aspect-ratio:16/10;background:linear-gradient(135deg,var(--forest),var(--emerald-2));overflow:hidden}
.cover img{width:100%;height:100%;object-fit:cover;transition:.4s}
.cover .fallback{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--display);font-size:3rem;color:rgba(255,255,255,.85)}
.cover::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,30,26,.5),transparent 42%)}
.cat-pill{position:absolute;top:12px;left:12px;z-index:3;font-size:.66rem;font-weight:700;letter-spacing:.02em;color:#fff;background:rgba(29,79,71,.78);padding:5px 11px;border-radius:20px;backdrop-filter:blur(4px)}
.rate-badge{position:absolute;bottom:12px;left:12px;z-index:3;display:inline-flex;align-items:center;gap:4px;background:rgba(255,255,255,.95);color:var(--ink);font-weight:800;font-size:.82rem;padding:4px 9px;border-radius:20px}
.rate-badge svg{width:13px;height:13px;color:var(--star)}
.phbadge{position:absolute;top:12px;right:12px;z-index:3;display:inline-flex;align-items:center;gap:4px;background:rgba(29,79,71,.78);color:#fff;font-size:.72rem;font-weight:700;padding:4px 8px;border-radius:20px;backdrop-filter:blur(4px)}
.phbadge svg{width:12px;height:12px}
.tags{position:absolute;top:12px;left:12px;z-index:4;display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.tags ~ .cat-pill{top:auto;bottom:50px}
.tag{display:inline-flex;align-items:center;gap:5px;font-size:.64rem;font-weight:800;letter-spacing:.02em;padding:4px 9px;border-radius:20px;text-transform:uppercase}
.tag.d{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#3a2c08}
.tag.v{background:#fff;color:var(--emerald)}
.tag svg{width:12px;height:12px}
.card-body{padding:16px 17px 4px;flex:1}
.card-name{font-size:1.06rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}
.card-name a:hover{color:var(--emerald)}
.meta-row{display:flex;align-items:center;gap:9px;margin-top:8px}
.stars{--s:15px;position:relative;width:calc(var(--s)*5);height:var(--s);flex-shrink:0;
  background:linear-gradient(90deg,var(--star) var(--p,0%),#d9d3c6 var(--p,0%));
  -webkit-mask:repeat-x left center/var(--s) var(--s);mask:repeat-x left center/var(--s) var(--s);
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m12 3.2 2.6 5.6 6 .6-4.5 4 1.3 6L12 16.9 6.6 19.5l1.3-6-4.5-4 6-.6z'/%3E%3C/svg%3E");
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m12 3.2 2.6 5.6 6 .6-4.5 4 1.3 6L12 16.9 6.6 19.5l1.3-6-4.5-4 6-.6z'/%3E%3C/svg%3E")}
.rev{font-size:.8rem;color:var(--muted)}
.chips{display:flex;gap:8px;margin-top:13px;flex-wrap:wrap}
.ch{width:31px;height:31px;border-radius:9px;display:grid;place-items:center;border:1px solid var(--line);background:var(--paper);transition:.2s;cursor:pointer}
.ch svg{width:16px;height:16px}
.ch:hover{transform:translateY(-2px)}
.ch.wa{color:#1FA855}.ch.tel{color:#2E776D}.ch.web{color:#2E776D}.ch.mail{color:#C0603B}.ch.ig{color:#B23A78}
.addr{display:flex;gap:7px;align-items:flex-start;color:var(--muted);font-size:.84rem;margin:13px 0 0;line-height:1.4}
.card .addr span{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.addr svg{width:15px;height:15px;flex-shrink:0;margin-top:2px;color:var(--emerald)}
.card-foot{display:flex;align-items:center;gap:10px;padding:14px 17px 17px}
.btn-go{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;text-decoration:none;background:linear-gradient(135deg,var(--forest),var(--emerald));color:#fff;font-weight:700;font-size:.84rem;padding:11px;border-radius:11px}
.btn-go svg{width:15px;height:15px}
.btn-detail{display:inline-flex;align-items:center;gap:2px;font-size:.82rem;font-weight:700;color:var(--forest);white-space:nowrap}
.btn-detail svg{width:15px;height:15px}

.empty{text-align:center;padding:60px 0;color:var(--muted)}
.empty svg{width:46px;height:46px;color:var(--line);margin-bottom:10px}

/* ---- paginação ---- */
.pager{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:40px;flex-wrap:wrap}
.pg-btn{min-width:42px;height:42px;padding:0 12px;border:1px solid var(--line);background:#fff;border-radius:11px;font-family:var(--body);font-weight:700;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.pg-btn:hover{border-color:var(--emerald)}
.pg-btn.on{background:linear-gradient(135deg,var(--forest),var(--emerald));color:#fff;border-color:transparent}
.pg-btn[aria-disabled=true]{opacity:.4;pointer-events:none}
.pg-btn svg{width:16px;height:16px}
.pg-prev svg{transform:rotate(180deg)}
.pg-dots{color:var(--muted);padding:0 4px}

/* ---- banda bairros ---- */
.band{background:linear-gradient(135deg,var(--forest),var(--forest-2));color:#fff}
.bcloud-wrap{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}
.bcloud{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.05);color:rgba(255,255,255,.9);font-family:var(--body);font-size:.82rem;font-weight:600;padding:8px 13px;border-radius:20px;cursor:pointer;transition:.2s;text-decoration:none}
.bcloud:hover{background:var(--gold);color:#3a2c08;border-color:transparent}

/* ---- footer ---- */
footer.ft{background:var(--forest-2);color:rgba(255,255,255,.7);padding:46px 0 26px;font-size:.88rem}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
@media(max-width:720px){.ft-grid{grid-template-columns:1fr}}
.ft h4{color:#fff;font-family:var(--body);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.ft a{color:rgba(255,255,255,.7);display:block;padding:4px 0}
.ft a:hover{color:var(--gold-2)}
.ft-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:30px;padding-top:18px;font-size:.78rem;color:rgba(255,255,255,.45);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* ---- buttons / forms gerais ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--body);font-weight:700;font-size:.92rem;padding:13px 22px;border-radius:12px;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--forest);transition:.2s;text-decoration:none}
.btn svg{width:18px;height:18px}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px -16px rgba(0,0,0,.4)}
.btn.primary{background:linear-gradient(135deg,var(--forest),var(--emerald));color:#fff;border-color:transparent}
.btn.gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#3a2c08;border-color:transparent}
.btn.wa{background:#1FA855;color:#fff;border-color:transparent}
.btn.block{width:100%}
.field{margin-bottom:16px}
.field label{display:block;font-weight:700;font-size:.86rem;margin-bottom:6px;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;font-family:var(--body);font-size:.95rem;border:1px solid var(--line);border-radius:11px;padding:12px 14px;outline:none;background:#fff}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--emerald)}
.field textarea{min-height:110px;resize:vertical}
.hint{font-size:.8rem;color:var(--muted);margin-top:5px}
.authbox{max-width:440px;margin:50px auto;background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px}
.authbox h1{font-size:1.6rem;margin-bottom:6px}
.authbox p.s{color:var(--muted);margin-bottom:20px;font-size:.92rem}
.flash{padding:13px 16px;border-radius:11px;margin:14px 0;font-weight:600;font-size:.92rem}
.flash-ok{background:#E7F4EC;color:#1f6b46;border:1px solid #b6e0c6}
.flash-err{background:#FBEAEA;color:#a52121;border:1px solid #f0c4c4}
.flash-info{background:#FBEFD8;color:#5a4a1e;border:1px solid #E3CB8F}

/* ---- detalhe ---- */
.detail{padding:26px 0 50px}
.crumb{font-size:.82rem;color:var(--muted);margin-bottom:16px}
.crumb a{color:var(--emerald)}
.detail-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:start}
.detail-grid>.d-left,.detail-grid>.d-side{min-width:0}
.gallery{border-radius:18px;overflow:hidden;background:linear-gradient(135deg,var(--forest),var(--emerald-2));aspect-ratio:16/10;position:relative;max-width:100%}
.gallery .main{width:100%;height:100%;object-fit:cover}
.gallery .fb{width:100%;height:100%;display:grid;place-items:center;font-family:var(--display);font-size:4rem;color:rgba(255,255,255,.85)}
.thumbs{display:flex;gap:8px;margin-top:10px;overflow-x:auto;scrollbar-width:none;max-width:100%}
.thumbs::-webkit-scrollbar{display:none}
.thumbs img{width:84px;height:60px;object-fit:cover;border-radius:9px;cursor:pointer;border:2px solid transparent;flex-shrink:0;opacity:.7;transition:.2s}
.thumbs img:hover,.thumbs img.on{opacity:1;border-color:var(--gold)}

/* DESKTOP: 2 colunas independentes, foto com altura limitada */
@media(min-width:881px){
  .detail-grid{grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:30px}
  .gallery{max-height:430px}
  .d-side{position:sticky;top:84px}
  .d-gallery{margin-bottom:18px}
}
/* MOBILE/TABLET: 1 coluna, ordem otimizada (foto → contato → endereço → avaliações → sugerir → horários → mensagem) */
@media(max-width:880px){
  .d-left,.d-side{display:contents}
  .d-left .panel,.d-side .panel,.d-gallery{min-width:0;margin-bottom:0}
  .d-left .cta-vendas{margin-bottom:0}
  .d-left .cta-own{margin-bottom:0}
  .d-gallery{order:1}
  .p-info{order:2}
  .p-about{order:3;margin-top:0!important}
  .p-addr{order:4}
  .p-cta{order:5;margin-bottom:0}
  .p-reviews{order:6}
  .p-suggest{order:7}
  .p-hours{order:8}
  .p-msg{order:9}
}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;margin-bottom:16px}
.d-title{font-size:clamp(1.5rem,4vw,2.1rem);margin:10px 0 8px}
.d-rate{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:.92rem;margin-bottom:4px}
.d-rate b{color:var(--ink);font-size:1.05rem}
.ratings2{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0}
.ratebox{flex:1;min-width:120px;border:1px solid var(--line);border-radius:13px;padding:12px;text-align:center}
.ratebox .big{font-family:var(--display);font-size:1.6rem;color:var(--forest)}
.ratebox .lab{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.contacts{display:flex;flex-direction:column;gap:9px}
.review{border-top:1px solid var(--line);padding:16px 0}
.review:first-of-type{border-top:none}
.review .rv-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.review .rv-av{width:36px;height:36px;border-radius:50%;background:var(--paper);display:grid;place-items:center;font-weight:800;color:var(--emerald);font-size:.85rem}
.star-input{display:flex;gap:4px;direction:rtl;justify-content:flex-start}
.star-input input{display:none}
.star-input label{font-size:1.7rem;color:#d9d3c6;cursor:pointer;transition:.15s}
.star-input input:checked ~ label,.star-input label:hover,.star-input label:hover ~ label{color:var(--star)}
.mapbox{border-radius:14px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/11;background:var(--paper);margin-top:6px}
.mapbox iframe{width:100%;height:100%;border:0}
.hours-tab{width:100%;border-collapse:collapse;font-size:.9rem}
.hours-tab td{padding:7px 0;border-bottom:1px solid var(--line)}
.hours-tab td:last-child{text-align:right;color:var(--muted)}
.hours-tab tr.today td{font-weight:800;color:var(--forest)}
.section-title{font-size:1.3rem;margin:6px 0 14px}
.tabbar{display:flex;gap:8px;border-bottom:1px solid var(--line);margin-bottom:16px;overflow-x:auto}
.tabbar a{padding:10px 4px;font-weight:700;color:var(--muted);border-bottom:2px solid transparent;white-space:nowrap}
.tabbar a.on{color:var(--forest);border-color:var(--gold)}

/* ---- formulário de sugestão estruturada ---- */
.sug-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sug-grid .full{grid-column:1/-1}
@media(max-width:560px){.sug-grid{grid-template-columns:1fr}}
.hrs-toggle{display:flex;align-items:center;gap:8px;margin:14px 0 6px;cursor:pointer;user-select:none}
.hrs-edit{display:grid;gap:7px}
.hrs-edit .row{display:grid;grid-template-columns:84px 1fr 1fr auto;gap:8px;align-items:center}
.hrs-edit .row .d{font-size:.86rem;color:#46524c;font-weight:600}
.hrs-edit input[type=time]{padding:7px 8px;border:1px solid var(--line);border-radius:8px;font-size:.85rem;background:#fff;width:100%}
.hrs-edit .cl{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--muted);white-space:nowrap}
@media(max-width:480px){.hrs-edit .row{grid-template-columns:64px 1fr 1fr;grid-auto-rows:auto}.hrs-edit .cl{grid-column:1/-1;justify-content:flex-start}}
.login-cta{display:flex;align-items:center;flex-wrap:wrap;gap:6px}

/* subcategorias — segunda linha de chips */
.chips-row.subs{margin-top:4px}
.chips-row.subs .fchip{font-size:.82rem;padding:6px 12px}

/* ===== banner Vendas & Reservas (Fale com o Guia) ===== */
.cta-vendas{background:#123833;border:1px solid #1f5147;border-radius:16px;padding:20px;display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;color:#fff;margin-bottom:16px}
.cta-vendas h3{color:#fff;font-size:1.2rem;margin:0 0 7px;display:flex;align-items:center;gap:9px}
.cta-vendas h3 svg{width:18px;height:18px;color:#E3CB8F}
.cta-vendas p{color:#cfe0d9;font-size:.92rem;line-height:1.55;margin:0 0 12px;max-width:62ch}
.cta-feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}
.cta-feats li{color:#d7e4de;font-size:.9rem;display:flex;gap:9px;align-items:flex-start}
.cta-feats li::before{content:"✓";color:#7ED9A8;font-weight:800;flex-shrink:0}
.cta-side{display:flex;flex-direction:column;gap:11px;min-width:190px}
.cta-prices{display:flex;gap:8px}
.cta-price{flex:1;background:#FBF8F2;border-radius:10px;padding:9px 12px;text-align:center}
.cta-price b{display:block;font-family:var(--display);font-size:1.05rem;color:#1D4F47}
.cta-price span{font-size:.7rem;color:var(--muted)}
.cta-wa{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#1FA855;color:#fff;border-radius:11px;padding:12px 16px;font-weight:700;font-size:.95rem}
.cta-wa svg{width:18px;height:18px}
.cta-wa:hover{background:#178c47}
@media(max-width:720px){.cta-vendas{grid-template-columns:1fr;gap:14px;padding:16px}.cta-side{min-width:0}}

/* ===== card "É o dono?" na página do anúncio ===== */
.cta-own{background:var(--cream);border:2px dashed var(--gold-2);border-radius:16px;padding:18px 20px;margin-bottom:16px}
.cta-own-head{display:flex;gap:13px;align-items:flex-start}
.cta-own-ic{width:46px;height:46px;border-radius:12px;background:#F4E9CE;color:var(--gold);display:grid;place-items:center;flex-shrink:0}
.cta-own-ic svg{width:24px;height:24px}
.cta-own h3{font-family:var(--display);font-size:1.18rem;color:var(--ink);margin:0 0 3px}
.cta-own-sub{color:var(--muted);font-size:.92rem;margin:0;line-height:1.5}
.cta-own-sub b{color:#B58B36;font-weight:700}
.cta-own-feats{list-style:none;margin:13px 0;padding:0;display:flex;flex-direction:column;gap:6px}
.cta-own-feats li{display:flex;gap:9px;align-items:center;color:#2c352f;font-size:.92rem}
.cta-own-feats li svg{width:16px;height:16px;color:var(--emerald);flex-shrink:0}
.cta-own-foot{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:6px}
.cta-own-prices{display:flex;gap:8px}
.cta-own-price{background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 12px;text-align:center}
.cta-own-price b{display:block;font-family:var(--display);font-size:1.05rem;color:var(--forest)}
.cta-own-price span{font-size:.7rem;color:var(--muted)}
.cta-own-actions{margin-left:auto;display:flex;gap:9px;flex-wrap:wrap}
.cta-own-wa{display:inline-flex;align-items:center;gap:8px;background:#1FA855;color:#fff;border-radius:11px;padding:11px 16px;font-weight:700;font-size:.93rem}
.cta-own-wa svg{width:18px;height:18px}
.cta-own-wa:hover{background:#178c47}
@media(max-width:560px){.cta-own-foot{flex-direction:column;align-items:stretch}.cta-own-actions{margin-left:0}.cta-own-wa{justify-content:center}}

/* ===== cards de subcategoria (home, ao escolher categoria) ===== */
.subhub{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,170px),1fr));gap:12px}
.subcard{display:flex;flex-direction:column;align-items:flex-start;gap:7px;padding:16px;border-radius:14px;border:1px solid var(--line);background:#fff;transition:.22s;position:relative;overflow:hidden}
.subcard:hover{transform:translateY(-3px);box-shadow:0 16px 34px -22px rgba(29,79,71,.5);border-color:var(--emerald)}
.subcard.active{border-color:var(--emerald);background:linear-gradient(180deg,#fff,#f3f8f6);box-shadow:inset 0 0 0 1px var(--emerald)}
.subcard-ic{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--paper),#fff);border:1px solid var(--line);display:grid;place-items:center;color:var(--emerald)}
.subcard-ic svg{width:22px;height:22px}
.subcard b{font-size:.96rem;color:var(--ink);line-height:1.2}
.subcard-n{font-size:.74rem;color:var(--muted)}

/* card do proprietário — 3 ações em <details> */
.cta-own-prices{display:flex;gap:10px;margin:6px 0 12px;flex-wrap:wrap}
.own-act,.own-del{margin-top:10px}
.own-act>summary,.own-del>summary{cursor:pointer;list-style:none}
.own-act>summary::-webkit-details-marker,.own-del>summary::-webkit-details-marker{display:none}
.own-act-main>summary,.own-act>summary.btn.block{width:100%;box-sizing:border-box;justify-content:center}
.own-form{margin-top:12px}
.own-sub{font-weight:700;color:var(--ink);margin:14px 0 8px;font-size:.9rem}
.own-del>summary{color:var(--muted);font-size:.82rem;text-decoration:underline;text-align:center;padding:8px 0}
.own-del>summary:hover{color:#b4452f}
