/* =====================================================================
   Brazilian Direct — Species product page (shared, responsive, on-brand)
   Namespaced under .sp-page. Uses brand tokens from site.css :root.
   Cohesive across every species; mobile-first; no horizontal overflow.
   ===================================================================== */

/* Break out of the legacy fixed-width content shell + hide legacy chrome */
.sp-host #title,
.sp-host #contentOuter > ul#breadcrumbs { display: none; }
.sp-host #contentOuter,
.sp-host #contentInnerWide {
  width: 100% !important; max-width: 100% !important;
  float: none !important; padding: 0 !important; margin: 0 !important;
}
.sp-host #contentInnerWide p { margin-bottom: 0; }

/* Tokens on .sp-host (body) so BOTH .sp-page and the body-level ribbon inherit them */
.sp-host{
  --ink:#2b2114; --ink-muted:#6f6048; --ink-soft:#9a8c72;
  --cream:#f5f0eb; --paper:#fbf9f5; --tint:#efe8df;
  --rust:#7f3627; --rust-700:#6a2c20; --sage:#7d8047; --sage-light:#c7ca89;
  --gold:#b88a3e; --walnut-900:#231a0d; --walnut-800:#2c1f10;
  --line:#e3dbce; --line-strong:#d4c8b4;
  --serif:'Fraunces',Georgia,serif; --read:'Source Serif 4',Georgia,serif;
  --sans:'Mulish',-apple-system,Helvetica,Arial,sans-serif;
}
.sp-page{
  font-family:var(--sans); color:var(--ink); background:var(--cream);
  line-height:1.6; font-size:16px;
}
.sp-page *{box-sizing:border-box}
.sp-page img{max-width:100%;display:block}
.sp-wrap{max-width:1240px;margin:0 auto;padding:0 24px}
.sp-page h1,.sp-page h2,.sp-page h3{font-family:var(--serif);color:var(--walnut-900);letter-spacing:-.01em;font-weight:600;line-height:1.1}

/* ---- Breadcrumb ---- */
.sp-crumbs{font:600 13px/1 var(--sans);color:var(--ink-soft);display:flex;gap:7px;flex-wrap:wrap;align-items:center;padding:20px 0 0}
.sp-crumbs a{color:var(--ink-muted);text-decoration:none}.sp-crumbs a:hover{color:var(--rust)}
.sp-crumbs .cur{color:var(--rust)}

/* ---- Hero ---- */
/* Desktop: text + CTA stacked on the left, photo spans both rows on the right.
   Mobile: text → photo → CTA (photo sits right under the summary). */
.sp-hero{display:grid;grid-template-columns:1fr 1.04fr;grid-template-areas:"text media" "cta media";column-gap:48px;align-items:start;padding:24px 0 60px}
.sp-hero-text{grid-area:text}
.sp-media{grid-area:media;align-self:stretch}
.sp-hero-cta{grid-area:cta;margin-top:28px}
.sp-eyebrow{font:700 12px var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--rust)}
.sp-hero h1{font-size:44px;line-height:1.05;margin:14px 0 8px}
.sp-latin{font:400 italic 20px var(--read);color:var(--ink-muted);margin:0}
.sp-desc{font:400 17px/1.7 var(--read);color:var(--ink);max-width:52ch;margin:18px 0 0}
.sp-janka{display:flex;align-items:center;gap:16px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:16px 20px;margin:0 0 20px}
.sp-janka .n{font:700 40px var(--serif);color:var(--rust);line-height:.9}
.sp-janka b{display:block;font:700 14px var(--sans);color:var(--walnut-900)}
.sp-janka span{font:400 13px var(--sans);color:var(--ink-muted)}
.sp-hero-acts{display:flex;flex-wrap:wrap;gap:11px}
.sp-media{position:relative;border-radius:14px;overflow:hidden;box-shadow:0 22px 50px -28px rgba(43,33,20,.5);background:var(--tint);min-height:380px}
.sp-media img{width:100%;height:100%;object-fit:cover}
.sp-media .badge{position:absolute;left:14px;bottom:14px;background:rgba(35,26,13,.86);color:#f3ead9;font:600 11px var(--sans);letter-spacing:.04em;padding:7px 12px;border-radius:7px}

/* Mobile species-page header replicates the 20-year desktop chrome:
   a cream logo band, then a full-width walnut nav bar beneath it (mirrors #nav).
   The dated tan REQUEST SAMPLES image button is dropped (redundant with the hero
   CTA + scroll ribbon). Logo sits ENTIRELY on cream — its black script reads clean;
   the Menu bar sits ENTIRELY on walnut with white type, exactly like the desktop nav
   links. The colour split falls BETWEEN logo and nav, never through the logo. */
.sp-host .header-actions{display:none}
@media(max-width:989px){
  .sp-host .header-container{
    position:relative;
    /* Exact desktop layering: bg-top.png is the same tan→cream vertical gradient
       that sits behind the desktop logo. Base #e5ddd0 = the gradient's settle colour
       so it flows seamlessly below the 71px strip on the taller mobile band. */
    background:#e5ddd0 url('/images/layout/bg-top.png') repeat-x;
    padding:0;
    border-bottom:0;
  }
  .sp-host .header-container .wrapper{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    padding:0;
    gap:0;
  }
  .sp-host .logo-section{
    order:1;
    float:none;
    width:100%;
    text-align:center;
    padding:16px 16px 13px;
  }
  .sp-host #logo{max-width:190px;height:auto}
  /* Menu = the walnut nav bar, same colours/behaviour as desktop #nav */
  .sp-host .mobile-menu-toggle{
    order:2;
    display:block;
    position:static;
    width:100%;
    margin:0;
    border:0;
    border-radius:0;
    background:var(--walnut-800);
    color:#fff;
    font:600 14px/1 var(--sans);
    letter-spacing:.14em;
    text-transform:uppercase;
    text-align:center;
    padding:16px;
  }
  .sp-host .mobile-menu-toggle:hover,
  .sp-host .mobile-menu-toggle.active{background:#5f513f;color:#fff}
}

/* ---- Buttons ---- */
.sp-btn{display:inline-flex;align-items:center;justify-content:center;font:700 15px var(--sans);padding:14px 24px;border-radius:9px;text-decoration:none;transition:.15s;min-height:48px}
.sp-btn-quote{background:var(--rust);color:#fff}.sp-btn-quote:hover{background:var(--rust-700)}
.sp-btn-dark{background:var(--walnut-800);color:#fff}.sp-btn-dark:hover{background:var(--walnut-900)}
.sp-btn-outline{background:transparent;color:var(--walnut-800);border:1.5px solid var(--line-strong)}.sp-btn-outline:hover{border-color:var(--rust);color:var(--rust)}
/* beat the global `#contentInnerWide a {color:accent}` rule (id specificity) for buttons */
#contentInnerWide a.sp-btn-quote,#contentInnerWide a.sp-btn-dark{color:#fff}
#contentInnerWide a.sp-btn-outline{color:var(--walnut-800)}
#contentInnerWide a.sp-btn-outline:hover{color:var(--rust)}

/* ---- Trust bar ---- */
.sp-trust{background:var(--walnut-900);color:#ece2d1}
.sp-trust-in{max-width:1240px;margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.sp-trust-items{display:flex;gap:26px;flex-wrap:wrap;font:600 13px var(--sans)}
.sp-trust-items span{display:inline-flex;align-items:center;gap:8px}
.sp-trust-items svg{width:17px;height:17px;color:var(--sage-light)}
.sp-trust-reviews{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.sp-trusted{font:600 13px var(--sans);color:#cdbfa8}
.sp-pill{display:inline-flex;align-items:center;gap:6px;font:600 12px var(--sans);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);padding:5px 10px;border-radius:7px}
.sp-pill .st{color:var(--gold)}

/* ---- Main layout: content + sticky quote ---- */
.sp-layout{display:grid;grid-template-columns:1fr 380px;gap:40px;align-items:start;padding:48px 0 64px}
.sp-main{min-width:0}

/* in-page section nav — secondary pill buttons (anchored, tappable, SEO-friendly).
   Static (not sticky) to avoid colliding with the fixed quote ribbon. */
.sp-nav{display:flex;gap:8px;flex-wrap:wrap;padding:4px 0 16px}
.sp-nav a,#contentInnerWide .sp-nav a{font:700 13px var(--sans);background:var(--tint);border:1px solid var(--line-strong);color:var(--walnut-800);text-decoration:none;padding:9px 16px;border-radius:999px;transition:background .15s,color .15s,border-color .15s}
.sp-nav a:hover,#contentInnerWide .sp-nav a:hover{background:var(--rust);border-color:var(--rust);color:#fff}

.sp-sec{padding:30px 0;border-top:1px solid var(--line);scroll-margin-top:64px}
.sp-sec:first-of-type{border-top:0}
.sp-sec h2{font-size:26px;margin:0 0 6px}
.sp-sec .sub{font:400 15px var(--read);color:var(--ink-muted);margin:0 0 22px}
.sp-sec p{font:400 16px/1.7 var(--read);color:var(--ink);margin:0 0 14px}
.sp-sec ul{margin:0 0 16px 0;padding-left:20px}
.sp-sec li{font:400 15px/1.6 var(--read);color:var(--ink);margin-bottom:6px}
.sp-sec a{color:var(--rust)}

/* Formats — static responsive cards (no iframe overflow) */
.sp-formats-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.sp-houzz{display:flex;align-items:center;gap:12px;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:12px 14px;text-decoration:none;color:var(--walnut-900);max-width:280px}
.sp-houzz img{width:56px;height:56px;border-radius:8px}
.sp-houzz .lab{font:700 13px var(--sans);line-height:1.25}
.sp-houzz .loc{font:600 12px var(--sans);color:var(--rust)}
.sp-fmt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.sp-fcard{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:18px;display:flex;flex-direction:column;gap:3px}
.sp-fcard .tag{align-self:flex-start;font:700 10px var(--sans);letter-spacing:.09em;text-transform:uppercase;color:var(--sage);background:#eef0df;padding:4px 9px;border-radius:6px;margin-bottom:7px}
.sp-fcard .sz{font:700 19px var(--serif);color:var(--walnut-900)}
.sp-fcard .ln{font:400 13px var(--sans);color:var(--ink-muted)}
.sp-fcard .meta{font:400 12px var(--sans);color:var(--ink-soft);margin-top:2px}
.sp-fcard .req{margin-top:13px;font:700 13px var(--sans);color:var(--rust);text-decoration:none;display:inline-flex;gap:6px}
.sp-fcard .req::after{content:"→"}

/* Specifications grid + sizes */
.sp-specs{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-bottom:8px}
.sp-spec{background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:14px 16px}
.sp-spec dt{font:700 11px var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.sp-spec dd{font:600 15px var(--serif);color:var(--walnut-900);margin:5px 0 0}
.sp-sizes-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:12px;margin:18px 0}
.sp-sizes{width:100%;border-collapse:collapse;font:400 14px var(--sans);min-width:0}
.sp-sizes th{text-align:left;font:700 11px var(--sans);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);background:var(--tint);padding:11px 14px}
.sp-sizes td{padding:11px 14px;border-top:1px solid var(--line);color:var(--ink)}

/* Species facts + color swatches */
.sp-facts{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:6px 20px;margin-bottom:18px}
.sp-facts dl{margin:0}
.sp-facts dt{font:700 11px var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding-top:14px}
.sp-facts dd{font:400 16px var(--read);color:var(--walnut-900);margin:3px 0 0;padding-bottom:14px;border-bottom:1px solid var(--line)}
.sp-facts dd:last-child{border-bottom:0}
.sp-swatches{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:18px 0}
.sp-swatch{height:120px;border-radius:12px;display:flex;align-items:flex-end;padding:12px;color:#fff;font:700 13px var(--sans);text-shadow:0 1px 6px rgba(0,0,0,.4)}

/* Gallery */
.sp-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}
.sp-gallery a{border-radius:11px;overflow:hidden;aspect-ratio:4/3;background:var(--tint)}
.sp-gallery img{width:100%;height:100%;object-fit:cover;transition:transform .25s}
.sp-gallery a:hover img{transform:scale(1.04)}

/* Accessories */
.sp-acc{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.sp-acc a{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:16px;text-decoration:none}
.sp-acc strong{display:block;font:700 14px var(--sans);color:var(--walnut-900);margin-bottom:3px}
.sp-acc span{font:400 13px var(--sans);color:var(--ink-muted)}

/* Sticky quote column */
.sp-quote{position:sticky;top:14px}
.sp-quote-card{background:var(--paper);border:1px solid var(--line-strong);border-radius:16px;overflow:hidden;box-shadow:0 24px 50px -36px rgba(43,33,20,.4)}
.sp-quote-head{background:var(--walnut-900);color:#fff;padding:18px 20px}
.sp-quote-head h3{color:#fff;font-size:19px;margin:0}
.sp-quote-head p{font:400 13px var(--sans);color:#cdbfa8;margin:4px 0 0}
.sp-quote-card iframe{width:100%;border:0;display:block;min-height:520px}

/* Persistent quote ribbon (revealed on scroll) */
.sp-ribbon{position:fixed;left:0;right:0;top:0;z-index:80;background:var(--walnut-900);color:#f1e8d8;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 18px;border-bottom:2px solid var(--rust);transform:translateY(-100%);transition:transform .2s ease}
.sp-ribbon.show{transform:translateY(0)}
.sp-ribbon .id{display:flex;align-items:center;gap:12px;font:600 13px var(--sans);min-width:0}
.sp-ribbon .id b{font:700 15px var(--serif)}
.sp-ribbon .id .chip{font:600 11px var(--sans);letter-spacing:.06em;text-transform:uppercase;color:var(--sage-light);white-space:nowrap}
@media(max-width:560px){.sp-ribbon .id .chip{display:none}}
.sp-ribbon .q{background:var(--rust);color:#fff;font:700 13px var(--sans);padding:9px 16px;border-radius:7px;text-decoration:none;white-space:nowrap}
@media(prefers-reduced-motion:reduce){.sp-ribbon{transition:none}}

/* Final CTA */
.sp-cta{background:var(--walnut-900);color:#f3ebdc;margin-top:10px}
.sp-cta-in{max-width:1240px;margin:0 auto;padding:50px 24px;display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap}
.sp-cta h2,#contentInnerWide .sp-cta h2{color:#fff;font-size:30px;max-width:440px}
.sp-cta p{font:400 15px var(--read);color:#cdbfa8;margin-top:6px}
.sp-cta-acts{display:flex;gap:12px;flex-wrap:wrap}

/* ---- Responsive ---- */
@media(max-width:980px){
  .sp-hero{grid-template-columns:1fr;grid-template-areas:"text" "media" "cta";column-gap:0;padding:16px 0 44px}
  .sp-hero h1{font-size:33px;margin:12px 0 8px}
  .sp-media{min-height:0;aspect-ratio:16/10;margin:22px 0 2px}
  .sp-hero-cta{margin-top:12px}
  .sp-layout{grid-template-columns:1fr;gap:30px}
  .sp-quote{position:static}
  .sp-trust-in{justify-content:flex-start}
}
@media(max-width:680px){
  .sp-wrap{padding:0 16px}
  .sp-hero h1{font-size:32px}
  .sp-hero-acts .sp-btn{flex:1 1 100%}
  /* sizes table → stacked rows */
  .sp-sizes-wrap{border:0}
  .sp-sizes,.sp-sizes tbody,.sp-sizes tr{display:block;width:100%}
  .sp-sizes thead{display:none}
  .sp-sizes tr{background:var(--paper);border:1px solid var(--line);border-radius:11px;margin-bottom:10px;padding:6px 0}
  .sp-sizes td{display:flex;justify-content:space-between;gap:14px;border:0;padding:7px 14px;font-size:14px}
  .sp-sizes td::before{content:attr(data-label);font:700 11px var(--sans);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
  .sp-cta-in{flex-direction:column;align-items:flex-start}
  .sp-cta-acts{width:100%}
}

/* ---- Mobile accordion (JS adds .sp-acc on small screens, toggles .collapsed) ---- */
.sp-sec.sp-acc > h2{cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;user-select:none}
.sp-sec.sp-acc > h2::after{content:"";width:10px;height:10px;border-right:2px solid var(--rust);border-bottom:2px solid var(--rust);transform:rotate(45deg);transition:transform .2s;flex:0 0 auto;margin:0 4px}
.sp-sec.sp-acc.collapsed > h2::after{transform:rotate(-45deg)}
.sp-sec.sp-acc.collapsed > :not(h2){display:none}

/* ---- Reviews (Elfsight) ---- */
.sp-reviews{min-height:140px}
.sp-reviews .sp-reviews-note{font:400 14px var(--read);color:var(--ink-muted);margin-bottom:14px}
