/* =========================================================
   BARCO PESQUEIRO — Design System Global
   Baseado no tema Hello Elementor + Kit Global ID:12
   ========================================================= */

/* ---- Google Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&family=Montserrat:wght@400;500;600;700;800&display=swap');

/* ---- CSS Variables — Identidade Visual Barco Pesqueiro ---- */
:root {
    --color-primary:         #8F320A;
    --color-secondary:       #FFF8EE;
    --color-text:            #5F5D5A;
    --color-accent:          #F58C13;
    --color-white:           #FFFFFF;
    --color-beige:           #D9D0C5;
    --color-brown:           #8F320A;
    --color-orange:          #F58C13;
    --color-success:         #2E9E4D;
    --color-black-50:        rgba(0, 0, 0, 0.50);
    --color-black-80:        rgba(0, 0, 0, 0.80);
    --color-black-20:        rgba(0, 0, 0, 0.20);

    --font-heading:          'Poppins', Arial, sans-serif;
    --font-body:             'Montserrat', Arial, sans-serif;
    --font-accent:           'Montserrat', Arial, sans-serif;

    --fs-h1:                 3em;
    --fs-h2:                 2.6em;
    --fs-h3:                 2em;
    --fs-h4:                 1.5em;
    --fs-body:               17px;
    --fs-small:              14px;

    --transition:            0.35s ease;
    --border-radius:         4px;
    --container-width:       1200px;
}

/* ---- Reset & Base ---- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html { scroll-behavior: smooth; }

body {
    font-family:  var(--font-body);
    font-size:    var(--fs-body);
    font-weight:  500;
    color:        var(--color-text);
    background:   var(--color-white);
    line-height:  1.7;
    overflow-x:   hidden;
}

img { max-width: 100%; height: auto; display: block; }
a   { color: inherit; text-decoration: none; transition: color var(--transition); }
ul  { list-style: none; }

/* ---- Typography ---- */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 600;
    color:       var(--color-primary);
    line-height: 1.2;
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); }

/* ---- Layout ---- */
.container {
    max-width: var(--container-width);
    margin:    0 auto;
    padding:   0 24px;
}

.section { padding: 80px 0; }
.section--dark { background: var(--color-primary); color: var(--color-secondary); }
.section--cream { background: var(--color-secondary); }
.section--beige { background: var(--color-beige); }

.section-title {
    font-family:    var(--font-heading);
    font-size:      var(--fs-h2);
    color:          var(--color-primary);
    margin-bottom:  8px;
}
.section-title--white { color: var(--color-white); }

.section-subtitle {
    font-family:    var(--font-accent);
    font-size:      13px;
    font-weight:    600;
    letter-spacing: 3px;
    text-transform: uppercase;
    color:          var(--color-accent);
    margin-bottom:  16px;
}

.section-text {
    font-size:     var(--fs-body);
    color:         var(--color-text);
    max-width:     640px;
    margin-bottom: 32px;
}

/* ---- Buttons ---- */
.btn {
    display:         inline-flex;
    align-items:     center;
    gap:             8px;
    padding:         14px 32px;
    font-family:     var(--font-accent);
    font-size:       13px;
    font-weight:     600;
    letter-spacing:  2px;
    text-transform:  uppercase;
    border:          2px solid transparent;
    border-radius:   var(--border-radius);
    cursor:          pointer;
    transition:      all var(--transition);
}
.btn-primary {
    background: var(--color-accent);
    color:      var(--color-white);
    border-color: var(--color-accent);
}
.btn-primary:hover {
    background:  transparent;
    color:       var(--color-accent);
}
.btn-outline {
    background:  transparent;
    color:       var(--color-white);
    border-color: var(--color-white);
}
.btn-outline:hover {
    background: var(--color-white);
    color:      var(--color-primary);
}
.btn-dark {
    background: var(--color-primary);
    color:      var(--color-white);
    border-color: var(--color-primary);
}
.btn-dark:hover {
    background: var(--color-accent);
    border-color: var(--color-accent);
}

/* ---- Header ---- */
.site-header {
    position:   fixed;
    top:        0;
    left:       0;
    width:      100%;
    z-index:    1000;
    background: var(--color-white);
    box-shadow: 0 2px 20px rgba(0,0,0,0.08);
    transition: all var(--transition);
}
.header-inner {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    height:          80px;
}
.site-logo img { height: auto; max-height: 72px; width: auto; }

.site-nav { display: flex; align-items: center; gap: 36px; }
.site-nav a {
    font-family:    var(--font-accent);
    font-size:      12px;
    font-weight:    600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color:          var(--color-primary);
    position:       relative;
    padding-bottom: 4px;
}
.site-nav a::after {
    content:    '';
    position:   absolute;
    bottom:     0; left: 0;
    width:      0; height: 2px;
    background: var(--color-accent);
    transition: width var(--transition);
}
.site-nav a:hover::after,
.site-nav a.active::after { width: 100%; }

.header-cart {
    position: relative;
    cursor:   pointer;
}
.cart-count {
    position:    absolute;
    top:         -8px; right: -8px;
    background:  var(--color-accent);
    color:       var(--color-white);
    font-size:   10px;
    font-weight: 700;
    width:       18px; height: 18px;
    border-radius: 50%;
    display:     flex;
    align-items: center;
    justify-content: center;
}
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; }
.hamburger span { width: 26px; height: 2px; background: var(--color-primary); transition: all var(--transition); }

/* ---- Hero Section ---- */
.hero {
    position:        relative;
    min-height:      100vh;
    display:         flex;
    align-items:     center;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    overflow:        hidden;
}
.hero-overlay {
    position:   absolute;
    inset:      0;
    background: var(--color-black-80);
}
.hero-content {
    position:  relative;
    z-index:   2;
    max-width: 700px;
}
.hero-subtitle {
    font-family:    var(--font-accent);
    font-size:      13px;
    font-weight:    600;
    letter-spacing: 4px;
    text-transform: uppercase;
    color:          var(--color-accent);
    margin-bottom:  20px;
}
.hero-title {
    font-family:   var(--font-heading);
    font-size:     clamp(2.4rem, 5vw, 4.5rem);
    font-weight:   600;
    color:         var(--color-white);
    line-height:   1.1;
    margin-bottom: 24px;
}
.hero-title span { color: var(--color-accent); }
.hero-desc {
    color:         var(--color-beige);
    font-size:     18px;
    margin-bottom: 40px;
    max-width:     540px;
}
.hero-actions { display: flex; gap: 16px; flex-wrap: wrap; }

/* ---- Parallax Sections ---- */
.parallax-section {
    background-attachment: fixed;
    background-size:       cover;
    background-position:   center;
    position:              relative;
}
.parallax-overlay {
    position:   absolute;
    inset:      0;
    background: rgba(0, 0, 0, 0.65);
}
.parallax-content {
    position: relative;
    z-index:  2;
    padding:  100px 0;
    text-align: center;
}

/* ---- Flip Cards (Serviços) ---- */
.flip-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap:                   24px;
    margin-top:            48px;
}
.flip-card {
    perspective:   1000px;
    height:        320px;
}
.flip-card-inner {
    position:         relative;
    width:            100%; height: 100%;
    transform-style:  preserve-3d;
    transition:       transform 0.6s ease;
}
.flip-card:hover .flip-card-inner { transform: rotateY(180deg); }
.flip-card-front,
.flip-card-back {
    position:           absolute;
    inset:              0;
    backface-visibility: hidden;
    border-radius:      8px;
    display:            flex;
    flex-direction:     column;
    align-items:        center;
    justify-content:    center;
    padding:            32px 24px;
    text-align:         center;
}
.flip-card-front {
    background:   var(--color-primary);
    border:       1px solid rgba(255,255,255,0.08);
}
.flip-card-front img { width: 56px; margin-bottom: 20px; }
.flip-card-front h3 { color: var(--color-white); font-size: 1.4em; }
.flip-card-back {
    background:  var(--color-accent);
    transform:   rotateY(180deg);
}
.flip-card-back p { color: var(--color-white); font-size: 15px; line-height: 1.6; }

/* ---- Counter Section ---- */
.counter-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap:                   40px;
    text-align:            center;
}
.counter-item {}
.counter-number {
    font-family:   var(--font-heading);
    font-size:     clamp(2.5rem, 5vw, 4rem);
    font-weight:   700;
    color:         var(--color-accent);
    line-height:   1;
}
.counter-label {
    font-family:    var(--font-accent);
    font-size:      12px;
    font-weight:    600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color:          var(--color-beige);
    margin-top:     8px;
}

/* ---- Menu Cards ---- */
.menu-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap:                   32px;
    margin-top:            48px;
}
.menu-card {
    background:    var(--color-white);
    border-radius: 8px;
    overflow:      hidden;
    box-shadow:    0 4px 20px rgba(0,0,0,0.08);
    transition:    transform var(--transition), box-shadow var(--transition);
}
.menu-card:hover {
    transform:  translateY(-6px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.14);
}
.menu-card img { width: 100%; height: 220px; object-fit: cover; }
.menu-card-body { padding: 24px; }
.menu-card-category {
    font-family:    var(--font-accent);
    font-size:      11px;
    font-weight:    600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color:          var(--color-accent);
    margin-bottom:  8px;
}
.menu-card-title { font-size: 1.3em; color: var(--color-primary); margin-bottom: 8px; }
.menu-card-desc  { font-size: 14px; color: var(--color-text); margin-bottom: 16px; }
.menu-card-price {
    font-family: var(--font-heading);
    font-size:   1.4em;
    color:       var(--color-brown);
    font-weight: 700;
}

/* ---- Price Cards ---- */
.price-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap:                   32px;
    margin-top:            48px;
    align-items:           start;
}
.price-card {
    background:    var(--color-white);
    border-radius: 12px;
    padding:       40px 32px;
    text-align:    center;
    box-shadow:    0 4px 30px rgba(0,0,0,0.08);
    border:        2px solid transparent;
    transition:    all var(--transition);
}
.price-card:hover,
.price-card--featured {
    border-color: var(--color-accent);
    transform:    translateY(-8px);
    box-shadow:   0 16px 50px rgba(245,140,19,0.15);
}
.price-card--featured { background: var(--color-primary); }
.price-card--featured .price-card-title,
.price-card--featured .price-amount { color: var(--color-white); }
.price-card--featured .price-card-feature { color: var(--color-beige); }

.price-card-badge {
    background:     var(--color-accent);
    color:          var(--color-white);
    font-size:      11px;
    font-weight:    600;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding:        4px 14px;
    border-radius:  20px;
    display:        inline-block;
    margin-bottom:  20px;
}
.price-card-title { font-size: 1.4em; margin-bottom: 8px; }
.price-amount {
    font-family: var(--font-heading);
    font-size:   3em;
    font-weight: 700;
    color:       var(--color-accent);
    line-height: 1;
}
.price-amount span { font-size: 0.45em; vertical-align: top; margin-top: 10px; display: inline-block; }
.price-period { font-size: 13px; color: var(--color-text); margin-bottom: 32px; }
.price-features { margin-bottom: 32px; text-align: left; }
.price-card-feature {
    padding:       10px 0;
    font-size:     15px;
    border-bottom: 1px solid var(--color-beige);
    display:       flex;
    gap:           10px;
    align-items:   center;
}
.price-card-feature::before {
    content:     '✓';
    color:       var(--color-accent);
    font-weight: 700;
    flex-shrink: 0;
}

/* ---- Booking Form ---- */
.booking-form {
    background:    var(--color-white);
    padding:       48px;
    border-radius: 12px;
    box-shadow:    0 8px 40px rgba(0,0,0,0.10);
    max-width:     760px;
    margin:        0 auto;
}
.form-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   20px;
}
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group--full { grid-column: 1 / -1; }
.form-label {
    font-family:    var(--font-accent);
    font-size:      12px;
    font-weight:    600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color:          var(--color-primary);
}
.form-input,
.form-select,
.form-textarea {
    padding:       12px 16px;
    border:        2px solid var(--color-beige);
    border-radius: var(--border-radius);
    font-family:   var(--font-body);
    font-size:     15px;
    color:         var(--color-primary);
    background:    var(--color-white);
    transition:    border-color var(--transition);
    width:         100%;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    outline:      none;
    border-color: var(--color-accent);
}
.form-textarea { resize: vertical; min-height: 120px; }
.form-error { font-size: 13px; color: var(--color-accent); margin-top: 4px; }

/* ---- Cart ---- */
.cart-table { width: 100%; border-collapse: collapse; }
.cart-table th {
    font-family:    var(--font-accent);
    font-size:      12px;
    font-weight:    600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color:          var(--color-text);
    padding:        12px 16px;
    border-bottom:  2px solid var(--color-beige);
    text-align:     left;
}
.cart-table td {
    padding:       16px;
    border-bottom: 1px solid var(--color-beige);
    vertical-align: middle;
}
.cart-product {
    display:     flex;
    align-items: center;
    gap:         16px;
}
.cart-product img { width: 70px; height: 70px; object-fit: cover; border-radius: 4px; }
.cart-total-row td {
    font-family:  var(--font-heading);
    font-size:    1.4em;
    font-weight:  700;
    color:        var(--color-primary);
    padding-top:  24px;
}
.qty-input {
    width:      60px;
    text-align: center;
    padding:    6px;
    border:     2px solid var(--color-beige);
    border-radius: 4px;
    font-size:  15px;
}

/* ---- WhatsApp Float ---- */
.whatsapp-float {
    position:  fixed;
    bottom:    30px; right: 30px;
    z-index:   999;
    width:     60px; height: 60px;
    background: #25D366;
    border-radius: 50%;
    display:   flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 24px rgba(37,211,102,0.4);
    transition: transform var(--transition);
}
.whatsapp-float:hover { transform: scale(1.1); }
.whatsapp-float svg  { width: 30px; height: 30px; fill: #fff; }

/* ---- Gallery ---- */
.gallery-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap:                   4px;
}
.gallery-item {
    overflow:   hidden;
    aspect-ratio: 1;
}
.gallery-item img {
    width:      100%; height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}
.gallery-item:hover img { transform: scale(1.06); }

/* ---- Testimonials ---- */
.testimonials-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap:                   32px;
    margin-top:            48px;
}
.testimonial-card {
    background:    var(--color-white);
    padding:       32px;
    border-radius: 8px;
    box-shadow:    0 4px 20px rgba(0,0,0,0.07);
    border-left:   4px solid var(--color-accent);
}
.testimonial-text { font-size: 16px; line-height: 1.7; margin-bottom: 20px; font-style: italic; }
.testimonial-author { display: flex; align-items: center; gap: 14px; }
.testimonial-author img { width: 50px; height: 50px; border-radius: 50%; object-fit: cover; }
.testimonial-name { font-weight: 600; color: var(--color-primary); }
.testimonial-stars { color: #f5a623; font-size: 13px; }

/* ---- Admin Panel ---- */
.admin-layout { display: flex; min-height: 100vh; }
.admin-sidebar {
    width:      260px;
    background: var(--color-primary);
    padding:    32px 0;
    flex-shrink: 0;
}
.admin-sidebar .logo { padding: 0 24px 32px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.admin-sidebar .logo img { height: 40px; }
.admin-nav { padding: 24px 0; }
.admin-nav a {
    display:    flex;
    align-items: center;
    gap:        12px;
    padding:    12px 24px;
    color:      var(--color-beige);
    font-family: var(--font-accent);
    font-size:  13px;
    font-weight: 600;
    letter-spacing: 1px;
    transition: all var(--transition);
}
.admin-nav a:hover,
.admin-nav a.active {
    background: var(--color-accent);
    color:      var(--color-white);
}
.admin-main {
    flex:       1;
    padding:    40px;
    background: #f5f5f5;
}
.admin-header {
    display:         flex;
    justify-content: space-between;
    align-items:     center;
    margin-bottom:   32px;
}
.admin-card {
    background:    var(--color-white);
    border-radius: 8px;
    padding:       32px;
    box-shadow:    0 2px 16px rgba(0,0,0,0.06);
}
.stats-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap:                   24px;
    margin-bottom:         32px;
}
.stat-card {
    background:    var(--color-white);
    border-radius: 8px;
    padding:       24px;
    box-shadow:    0 2px 16px rgba(0,0,0,0.06);
    border-top:    4px solid var(--color-accent);
}
.stat-number { font-family: var(--font-heading); font-size: 2.5em; font-weight: 700; color: var(--color-primary); }
.stat-label  { font-size: 13px; color: var(--color-text); margin-top: 4px; }

/* ---- Footer ---- */
.site-footer {
    background:    var(--color-primary);
    color:         var(--color-beige);
    padding:       80px 0 0;
}
.footer-banner {
    background-size:     cover;
    background-position: center;
    position:            relative;
    padding:             80px 0;
    text-align:          center;
    margin-bottom:       60px;
}
.footer-banner-overlay {
    position:   absolute;
    inset:      0;
    background: var(--color-black-80);
}
.footer-banner-content { position: relative; z-index: 2; }
.footer-banner h2 { color: var(--color-white); margin-bottom: 24px; }
.footer-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap:                   48px;
    padding-bottom:        60px;
    border-bottom:         1px solid rgba(255,255,255,0.1);
}
.footer-logo { margin-bottom: 20px; }
.footer-logo img { height: auto; max-height: 80px; width: auto; }
.footer-desc { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,0.6); }
.footer-heading {
    font-family:    var(--font-accent);
    font-size:      12px;
    font-weight:    700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color:          var(--color-white);
    margin-bottom:  20px;
}
.footer-links a {
    display:       block;
    font-size:     14px;
    color:         rgba(255,255,255,0.6);
    margin-bottom: 10px;
    transition:    color var(--transition);
}
.footer-links a:hover { color: var(--color-accent); }
.footer-socials { display: flex; gap: 12px; margin-top: 20px; }
.footer-socials a {
    width:         40px; height: 40px;
    border-radius: 50%;
    border:        1px solid rgba(255,255,255,0.2);
    display:       flex;
    align-items:   center;
    justify-content: center;
    color:         var(--color-white);
    font-size:     16px;
    transition:    all var(--transition);
}
.footer-socials a:hover { background: var(--color-accent); border-color: var(--color-accent); }
.footer-bottom {
    padding:         24px 0;
    text-align:      center;
    font-size:       13px;
    color:           rgba(255,255,255,0.4);
}

/* ---- Alerts / Flash ---- */
.alert {
    padding:       16px 20px;
    border-radius: 6px;
    margin-bottom: 20px;
    font-size:     15px;
}
.alert-success { background: #d4edda; color: #155724; border-left: 4px solid #28a745; }
.alert-error   { background: #f8d7da; color: #721c24; border-left: 4px solid var(--color-accent); }

/* ---- Page Banner ---- */
.page-banner {
    background-size:       cover;
    background-position:   center;
    padding:               120px 0 80px;
    position:              relative;
}
.page-banner-overlay {
    position:   absolute;
    inset:      0;
    background: var(--color-black-80);
}
.page-banner-content { position: relative; z-index: 2; }
.page-banner h1 { color: var(--color-white); }
.page-banner .breadcrumb {
    display:   flex;
    gap:       8px;
    font-size: 13px;
    color:     rgba(255,255,255,0.6);
    margin-top: 12px;
}
.breadcrumb a { color: rgba(255,255,255,0.6); }
.breadcrumb a:hover { color: var(--color-accent); }
.breadcrumb-sep { color: rgba(255,255,255,0.4); }

/* ---- Animations (AOS-like) ---- */
[data-animate] {
    opacity:    0;
    transform:  translateY(30px);
    transition: opacity 0.7s ease, transform 0.7s ease;
}
[data-animate].animated {
    opacity:   1;
    transform: translateY(0);
}
[data-animate="fade-left"] { transform: translateX(-30px); }
[data-animate="fade-left"].animated { transform: translateX(0); }
[data-animate="fade-right"] { transform: translateX(30px); }
[data-animate="fade-right"].animated { transform: translateX(0); }
[data-animate="zoom-in"] { transform: scale(0.9); }
[data-animate="zoom-in"].animated { transform: scale(1); }

/* ---- Booking Widget (página do produto) ---- */
.booking-widget .form-input,
.booking-widget .form-select,
.booking-widget .form-textarea {
    border-color: var(--color-beige);
    background:   var(--color-secondary);
    font-size:    14px;
}
.booking-widget .form-input:focus,
.booking-widget .form-select:focus,
.booking-widget .form-textarea:focus {
    border-color: var(--color-accent);
    background:   var(--color-white);
}
.booking-widget input::placeholder,
.booking-widget textarea::placeholder { color: #aaa; font-size: 14px; }

/* Produto: layout em coluna no mobile */
@media (max-width: 900px) {
    .section .container > div[style*="grid-template-columns: 1fr 420px"] {
        grid-template-columns: 1fr !important;
    }
    #reservar { position: static !important; top: auto !important; }
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
    .form-grid { grid-template-columns: 1fr; }
    .hero-title { font-size: 2.4rem; }
    .booking-form { padding: 32px 24px; }
}

@media (max-width: 768px) {
    .section { padding: 60px 0; }
    .site-nav { display: none; flex-direction: column; }
    .site-nav.open { display: flex; position: fixed; inset: 80px 0 0; background: var(--color-white); padding: 40px 24px; gap: 28px; z-index: 999; }
    .hamburger { display: flex; }
    .admin-layout { flex-direction: column; }
    .admin-sidebar { width: 100%; }
    .flip-grid { grid-template-columns: 1fr 1fr; }
    .cart-table th:nth-child(3),
    .cart-table td:nth-child(3) { display: none; }
}

@media (max-width: 480px) {
    h1 { font-size: 2rem; }
    h2 { font-size: 1.8rem; }
    .flip-grid { grid-template-columns: 1fr; }
    .hero-actions { flex-direction: column; }
    .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   GOOGLE REVIEWS
   ============================================================ */

/* Badge central */
.google-badge-wrapper {
    display: flex;
    justify-content: center;
    margin-bottom: 12px;
}

.google-badge {
    display: inline-flex;
    align-items: center;
    gap: 24px;
    background: #fff;
    border: 1.5px solid #e0e0e0;
    border-radius: 16px;
    padding: 20px 32px;
    box-shadow: 0 4px 24px rgba(0,0,0,.07);
    flex-wrap: wrap;
    justify-content: center;
}

.google-badge-logo svg { display: block; }

.google-badge-info { text-align: center; }

.google-badge-rating {
    font-size: 3rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1;
    font-family: var(--font-heading);
}

.google-badge-stars {
    font-size: 22px;
    color: #fbbc05;
    letter-spacing: 2px;
    margin: 4px 0;
}

.gs-full  { color: #fbbc05; }
.gs-half  { color: #fbbc05; opacity: .55; }
.gs-empty { color: #ddd; }

.google-badge-count {
    font-size: 12px;
    color: #777;
    font-family: var(--font-body);
}

.google-badge-cta {
    display: inline-block;
    padding: 10px 22px;
    border: 2px solid #4285F4;
    border-radius: 8px;
    color: #4285F4;
    font-weight: 700;
    font-size: 13px;
    font-family: var(--font-body);
    text-decoration: none;
    white-space: nowrap;
    transition: background .2s, color .2s;
}
.google-badge-cta:hover { background: #4285F4; color: #fff; }

/* Cards de avaliação do Google */
.google-review-card { position: relative; }

.google-review-header {
    display: flex;
    align-items: center;
    gap: 12px;
}

.google-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: linear-gradient(135deg, #4285F4, #34A853);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 17px;
    flex-shrink: 0;
}

/* Botão "Deixar avaliação no Google" */
.btn-google-review {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 32px;
    border: 2px solid #dadce0;
    border-radius: 50px;
    color: var(--color-text);
    font-weight: 600;
    font-size: 15px;
    font-family: var(--font-body);
    text-decoration: none;
    background: #fff;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    transition: box-shadow .2s, border-color .2s, transform .15s;
}
.btn-google-review:hover {
    box-shadow: 0 4px 20px rgba(66,133,244,.2);
    border-color: #4285F4;
    transform: translateY(-2px);
}

@media (max-width: 600px) {
    .google-badge { padding: 16px 20px; gap: 16px; }
    .google-badge-rating { font-size: 2.2rem; }
}

/* ============================================================
   HERO VIDEO
   ============================================================ */
.hero--video { position: relative; min-height: 100vh; display: flex; align-items: center; }
.hero-media { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-video-el {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.hero-video-fallback {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    display: none;
}
/* Mostra fallback se vídeo não carregou */
.hero-video-el:not([src]), .hero-video-el[src=""] { display: none; }
.hero-video-el:not([src]) ~ .hero-video-fallback,
.hero-video-el[src=""] ~ .hero-video-fallback { display: block; }

/* ============================================================
   DIFERENCIAIS
   ============================================================ */
.diferenciais-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 24px;
}
.diferencial-card {
    background: #fff;
    border-radius: 16px;
    padding: 32px 24px;
    text-align: center;
    box-shadow: 0 2px 16px rgba(0,0,0,.06);
    border: 1px solid #f0f0f0;
    transition: transform .2s, box-shadow .2s;
}
.diferencial-card:hover { transform: translateY(-4px); box-shadow: 0 8px 32px rgba(245,140,19,.1); }
.diferencial-icon { font-size: 44px; margin-bottom: 16px; }
.diferencial-titulo { font-size: 16px; font-weight: 700; color: var(--color-primary); margin-bottom: 8px; }
.diferencial-desc { font-size: 13px; color: var(--color-text-light); line-height: 1.6; }

/* ============================================================
   INSTAGRAM GRID
   ============================================================ */
.instagram-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 4px;
}
.instagram-item {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    display: block;
}
.instagram-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.instagram-item:hover img { transform: scale(1.06); }
.instagram-overlay {
    position: absolute; inset: 0;
    background: rgba(245,140,19,.5);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity .3s;
}
.instagram-item:hover .instagram-overlay { opacity: 1; }

.btn-instagram {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 13px 28px;
    background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
    color: #fff;
    border-radius: 50px;
    font-weight: 700;
    font-size: 14px;
    font-family: var(--font-body);
    text-decoration: none;
    transition: opacity .2s, transform .15s;
    box-shadow: 0 4px 16px rgba(220,39,67,.35);
}
.btn-instagram:hover { opacity: .88; transform: translateY(-2px); }

/* ============================================================
   WHATSAPP FLOAT — melhorado
   ============================================================ */
.whatsapp-float {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 9999;
    background: #25D366;
    color: #fff;
    border-radius: 50px;
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 20px rgba(37,211,102,.45);
    text-decoration: none;
    overflow: hidden;
    transition: width .3s ease, border-radius .3s ease, box-shadow .2s;
}
.whatsapp-float svg { width: 28px; height: 28px; fill: #fff; flex-shrink: 0; }
.whatsapp-float-label {
    max-width: 0;
    overflow: hidden;
    white-space: nowrap;
    font-size: 14px;
    font-weight: 700;
    font-family: var(--font-body);
    transition: max-width .3s ease, margin .3s ease;
    margin-left: 0;
}
.whatsapp-float:hover {
    width: auto;
    border-radius: 50px;
    padding: 0 20px;
    box-shadow: 0 6px 28px rgba(37,211,102,.6);
}
.whatsapp-float:hover .whatsapp-float-label { max-width: 120px; margin-left: 10px; }

/* ============================================================
   BTN WHATSAPP
   ============================================================ */
.btn-whatsapp {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    background: #25D366;
    color: #fff !important;
    border-radius: 8px;
    font-weight: 700;
    font-size: 14px;
    font-family: var(--font-body);
    text-decoration: none !important;
    transition: background .2s, transform .15s, box-shadow .2s;
    box-shadow: 0 2px 12px rgba(37,211,102,.3);
    border: none;
}
.btn-whatsapp:hover { background: #1ebe5c; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(37,211,102,.4); }
.btn-whatsapp svg { fill: #fff; flex-shrink: 0; }

/* ============================================================
   CAFÉ COLONIAL — Info Cards
   ============================================================ */
.cafe-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 24px;
}
.cafe-info-card {
    background: #fff;
    border-radius: 16px;
    padding: 28px 24px;
    box-shadow: 0 2px 16px rgba(0,0,0,.06);
    border: 1px solid #f0f0f0;
}
.cafe-info-icon { font-size: 36px; margin-bottom: 12px; }
.cafe-info-card h3 { font-size: 17px; font-weight: 700; color: var(--color-primary); margin-bottom: 12px; }
.cafe-info-card ul { list-style: none; padding: 0; margin: 0; }
.cafe-info-card ul li { font-size: 14px; color: var(--color-text); padding: 5px 0; border-bottom: 1px solid #f5f5f5; }
.cafe-info-card ul li:last-child { border: none; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item { border: 1.5px solid #e8e8e8; border-radius: 12px; overflow: hidden; transition: border-color .2s; }
.faq-item.open { border-color: var(--color-accent); }
.faq-question {
    width: 100%;
    background: none;
    border: none;
    padding: 18px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    font-weight: 600;
    color: var(--color-primary);
    cursor: pointer;
    font-family: var(--font-body);
    text-align: left;
}
.faq-question:hover { background: #fafafa; }
.faq-chevron { font-size: 11px; transition: transform .25s; color: var(--color-accent); flex-shrink: 0; }
.faq-item.open .faq-chevron { transform: rotate(180deg); }
.faq-answer { padding: 0 20px 18px; }
.faq-answer p { font-size: 14px; color: var(--color-text); line-height: 1.7; margin: 0; }

@media (max-width: 900px) {
    .instagram-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
    .instagram-grid { grid-template-columns: repeat(2, 1fr); }
    .diferenciais-grid { grid-template-columns: repeat(2, 1fr); }
    .whatsapp-float { bottom: 16px; right: 16px; }
}

/* ============================================================
   CAROUSEL — Diferenciais (e reutilizável)
   ============================================================ */
.carousel-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
}

.carousel-track-outer {
    overflow: hidden;
    flex: 1;
    border-radius: 16px;
}

.carousel-track {
    display: flex;
    gap: 20px;
    transition: transform .45s cubic-bezier(.25,.46,.45,.94);
    will-change: transform;
}

.carousel-slide {
    flex: 0 0 calc((100% - 60px) / 4);
    min-width: 0;
}

/* Botões prev/next */
.carousel-btn {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 2px solid var(--color-accent);
    background: #fff;
    color: var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .2s, color .2s, transform .15s, box-shadow .2s;
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
    z-index: 2;
}
.carousel-btn:hover {
    background: var(--color-accent);
    color: #fff;
    transform: scale(1.08);
    box-shadow: 0 4px 18px rgba(245,140,19,.25);
}
.carousel-btn:disabled {
    opacity: .35;
    cursor: default;
    transform: none;
}

/* Dots */
.carousel-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 24px;
}
.carousel-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #d0d0d0;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background .2s, transform .2s, width .25s;
}
.carousel-dot.active {
    background: var(--color-accent);
    width: 24px;
    border-radius: 4px;
    transform: none;
}

/* Cards dos diferenciais (usados dentro do carousel-slide) */
.diferencial-card {
    background: #fff;
    border-radius: 16px;
    padding: 36px 24px 28px;
    text-align: center;
    box-shadow: 0 2px 16px rgba(0,0,0,.06);
    border: 1.5px solid #f0f0f0;
    transition: transform .2s, box-shadow .2s, border-color .2s;
    height: 100%;
    box-sizing: border-box;
}
.diferencial-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 36px rgba(245,140,19,.12);
    border-color: rgba(245,140,19,.2);
}
.diferencial-icon {
    font-size: 48px;
    margin-bottom: 18px;
    line-height: 1;
    display: block;
}
.diferencial-titulo {
    font-size: 15px;
    font-weight: 700;
    font-family: var(--font-accent);
    color: var(--color-primary);
    margin-bottom: 10px;
    letter-spacing: -.01em;
}
.diferencial-desc {
    font-size: 13px;
    font-family: var(--font-body);
    color: var(--color-text);
    line-height: 1.65;
    margin: 0;
}

/* Responsive slides per view */
@media (max-width: 1100px) {
    .carousel-slide { flex: 0 0 calc((100% - 40px) / 3); }
}
@media (max-width: 768px) {
    .carousel-slide { flex: 0 0 calc((100% - 20px) / 2); }
    .carousel-btn { width: 36px; height: 36px; }
}
@media (max-width: 480px) {
    .carousel-slide { flex: 0 0 85%; }
    .carousel-wrapper { gap: 6px; }
}

/* ============================================================
   LANDING PAGE — HOME
   ============================================================ */
.site-header--gold {
    background: var(--color-secondary);
    box-shadow: 0 2px 16px rgba(143, 50, 10, 0.08);
}

.hero--static {
    background-size: cover;
    background-position: center;
    background-attachment: scroll;
    min-height: 92vh;
    padding-top: 80px;
}

.hero-content--landing { max-width: 760px; }

.hero-tagline {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 600;
    color: var(--color-orange);
    margin-bottom: 20px;
    line-height: 1.25;
}

.home-about__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}

.home-about__media img {
    width: 100%;
    border-radius: 8px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12);
}

.home-about__subtitle {
    font-family: var(--font-accent);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--color-brown);
    margin-bottom: 24px;
}

.facilidades-carousel { margin: 28px 0 12px; }

.facilidade-item {
    background: #fff;
    border-radius: 12px;
    padding: 24px 16px;
    text-align: center;
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.06);
    min-height: 130px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.facilidade-item__icon { font-size: 36px; line-height: 1; }

.facilidade-item__title {
    font-family: var(--font-accent);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--color-primary);
}

.home-destaques__header {
    text-align: center;
    margin-bottom: 40px;
}

.destaques-grid {
    display: grid;
    gap: 16px;
}

.destaques-grid--top {
    grid-template-columns: repeat(2, 1fr);
}

.destaques-grid--bottom {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 16px;
}

.destaque-card {
    position: relative;
    min-height: 300px;
    border-radius: 4px;
    overflow: hidden;
    background-size: cover;
    background-position: center;
}

.destaque-card--large { min-height: 340px; }

.destaque-card__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.58);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 32px 24px;
    color: var(--color-white);
}

.destaque-card__icon {
    width: 52px;
    height: 52px;
    object-fit: contain;
    margin-bottom: 16px;
    filter: brightness(0) invert(1);
}

.destaque-card__overlay h3 {
    color: var(--color-white);
    font-size: clamp(1.2rem, 2vw, 1.6rem);
    margin-bottom: 12px;
}

.destaque-card__overlay p {
    font-size: 14px;
    line-height: 1.65;
    max-width: 420px;
    margin-bottom: 20px;
    color: rgba(255, 255, 255, 0.92);
}

.destaque-card__btn {
    padding: 10px 24px;
    font-size: 11px;
}

.home-reviews__header {
    text-align: center;
    margin-bottom: 40px;
}

.home-metrics {
    position: relative;
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
}

.home-metrics__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.72);
}

.home-metrics__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 48px;
    align-items: center;
    padding: 100px 24px;
}

.home-metrics__text h2 {
    color: var(--color-white);
    font-size: clamp(2rem, 4vw, 3rem);
    margin-bottom: 20px;
}

.home-metrics__text p {
    color: rgba(255, 255, 255, 0.82);
    font-size: 17px;
    line-height: 1.75;
    margin-bottom: 28px;
    max-width: 520px;
}

.section-subtitle--light { color: rgba(255, 255, 255, 0.85); }

.home-metrics__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

.metric-card {
    background: var(--color-secondary);
    border-radius: 6px;
    padding: 36px 28px;
    text-align: center;
}

.metric-card__number {
    font-family: var(--font-heading);
    font-size: clamp(2.5rem, 4vw, 3.5rem);
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1;
    margin-bottom: 12px;
}

.metric-card h3 {
    font-size: 1.15rem;
    margin-bottom: 12px;
}

.metric-card p {
    font-size: 14px;
    line-height: 1.65;
    color: var(--color-text);
}

.footer-links--legal li {
    font-size: 13px;
    line-height: 1.7;
    color: #aaa;
}

@media (max-width: 992px) {
    .home-about__grid,
    .home-metrics__inner {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .destaques-grid--top,
    .destaques-grid--bottom,
    .home-metrics__cards {
        grid-template-columns: 1fr;
    }

    .destaque-card,
    .destaque-card--large {
        min-height: 280px;
    }
}

