
  :root{
    --navy:#1F3051; --navy-700:#172541; --navy-900:#0f1a30;
    --gold:#B19355; --ink:#2E2E2E; --ink-soft:#5a5a5a;
    --bg:#FFFFFF; --bg-soft:#F7F6F3; --line:#E7E4DD; --navy-tint:#EEF1F6;
    --display:'Fraunces','Playfair Display',Georgia,serif;
    --body:'Montserrat',sans-serif;
    --maxw:1180px;
    --acc-ess:#B19355; --acc-bal:#6E8B8A; --acc-aut:#6E2F3A; --acc-evo:#3E5C7E; --acc-lab:#4B6B4A;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
  h1,h2,h3,.display{font-family:var(--display);font-weight:600;color:var(--navy);line-height:1.14}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  ::selection{background:var(--navy);color:#fff}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

  .eyebrow{font-family:var(--body);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600;display:inline-block;margin-bottom:18px}
  .eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--gold);vertical-align:middle;margin-right:12px;transform:translateY(-3px)}

  .btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--body);font-size:.9rem;font-weight:600;letter-spacing:.02em;padding:15px 28px;border:1.5px solid transparent;cursor:pointer;transition:.2s;border-radius:2px;background:none}
  .btn svg{width:16px;height:16px}
  .btn-primary{background:var(--navy);color:#fff}
  .btn-primary:hover{background:var(--navy-700)}
  .btn-ghost{color:var(--navy);border-color:var(--navy)}
  .btn-ghost:hover{background:var(--navy);color:#fff}
  .btn-gold{color:var(--navy);border-color:var(--gold)}
  .btn-gold:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
  .btn-white{background:#fff;color:var(--navy)}
  .btn-white:hover{background:var(--bg-soft)}
  .btn-outline-white{color:#fff;border-color:rgba(255,255,255,.6)}
  .btn-outline-white:hover{background:#fff;color:var(--navy);border-color:#fff}
  a.btn:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

  /* header */
  header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
  .logo-link img{height:40px;width:auto}
  .menu{display:flex;gap:28px;list-style:none}
  .menu a{font-size:.8rem;font-weight:500;color:var(--ink);letter-spacing:.02em;padding:6px 0;border-bottom:2px solid transparent;transition:.18s;cursor:pointer;white-space:nowrap}
  .menu a:hover{color:var(--navy)}
  .menu a.active{color:var(--navy);border-bottom-color:var(--gold)}
  .nav-actions{display:flex;align-items:center;gap:16px}
  .icon-btn{background:none;border:none;cursor:pointer;color:var(--navy);display:flex;padding:6px}
  .icon-btn svg{width:20px;height:20px}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
  .burger span{width:24px;height:2px;background:var(--navy);display:block}

  /* search overlay */
  .search-overlay{position:fixed;inset:0;background:rgba(15,26,48,.5);z-index:70;display:none;align-items:flex-start;justify-content:center;padding-top:14vh}
  .search-overlay.open{display:flex}
  .search-box{background:#fff;width:min(620px,90vw);border-radius:4px;padding:28px;box-shadow:0 30px 80px rgba(0,0,0,.3)}
  .search-box label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .search-box input{width:100%;font-size:1.2rem;font-family:var(--display);border:none;border-bottom:2px solid var(--navy);padding:14px 2px;margin-top:10px;color:var(--navy)}
  .search-box input:focus{outline:none}
  .search-hints{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
  .search-hints button{font-size:.78rem;border:1px solid var(--line);background:var(--bg-soft);color:var(--ink-soft);padding:7px 14px;border-radius:20px;cursor:pointer}
  .search-hints button:hover{border-color:var(--navy);color:var(--navy)}

  /* page system */
  .page{display:none}
  .page.active{display:block;animation:fade .35s ease}
  @keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
  @media (prefers-reduced-motion:reduce){.page.active{animation:none}*{scroll-behavior:auto !important}}

  section{padding:96px 0}
  .section-soft{background:var(--bg-soft)}
  .lead{font-size:1.06rem;color:var(--ink-soft);max-width:620px}

  /* HERO full bleed */
  .hero-full{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden;
    background:
      linear-gradient(180deg,rgba(15,26,48,.35),rgba(15,26,48,.85) 78%),
      radial-gradient(120% 90% at 75% 18%,#34507f 0%,var(--navy) 42%,var(--navy-900) 100%);
    /* Em produção: trocar por linear-gradient(...) , url('foto-hero.jpg') center/cover */
  }
  .hero-full::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.025) 0 2px,transparent 2px 26px);pointer-events:none}
  .hero-full .wrap{position:relative;z-index:2;padding-top:60px;padding-bottom:60px}
  .hero-full .eyebrow{color:var(--gold)}
  .hero-full h1{color:#fff;font-size:4.7rem;line-height:1.05;max-width:15ch;margin-bottom:8px;letter-spacing:-.5px}
  .hero-since{display:inline-block;font-family:var(--body);font-size:.92rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:14px 0 26px}
  .hero-full p.lead{color:#dfe5ef;margin-bottom:34px}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
  .hero-seal{position:absolute;top:50%;right:48px;transform:translateY(-50%);width:130px;height:130px;border-radius:50%;border:1px solid var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--gold);text-align:center;z-index:2}
  .hero-seal b{font-family:var(--display);font-size:2.4rem;line-height:.9}
  .hero-seal span{font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;margin-top:6px}
  .photo-flag{position:absolute;right:14px;bottom:12px;z-index:3;font-size:.6rem;letter-spacing:.06em;color:rgba(255,255,255,.5);text-transform:uppercase}

  /* two doors */
  .doors{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:3px;overflow:hidden}
  .door{padding:52px 46px;transition:.25s;cursor:pointer;background:#fff}
  .door + .door{border-left:1px solid var(--line)}
  .door:hover{background:var(--navy);color:#fff}
  .door:hover h3,.door:hover .door-num{color:#fff}
  .door:hover .door-arrow{color:var(--gold)}
  .door .door-num{font-family:var(--body);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .door h3{font-size:1.7rem;margin:14px 0 12px}
  .door p{font-size:.95rem;opacity:.85;margin-bottom:22px;min-height:48px}
  .door-arrow{color:var(--navy);font-weight:600;font-size:.84rem;letter-spacing:.03em;display:inline-flex;align-items:center;gap:8px;transition:.2s}

  /* prova */
  .prova-band{background:var(--navy)}
  .prova-band .eyebrow{color:var(--gold)}
  .prova-band h2{color:#fff}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;margin-top:46px}
  .stat{padding:10px 18px;border-right:1px solid rgba(255,255,255,.14)}
  .stat:last-child{border-right:none}
  .stat b{font-family:var(--display);font-size:2.4rem;color:#fff;display:block;line-height:1.05}
  .stat span{font-size:.78rem;color:#c3cde0;display:block;margin-top:10px;line-height:1.4}

  /* partner logos */
  .partners{text-align:center}
  .partners .eyebrow{display:block}
  .logo-row{display:grid;grid-template-columns:repeat(5,1fr);gap:30px;align-items:center;margin-top:34px}
  .plogo{height:64px;background:var(--bg-soft);border:1px dashed var(--line);border-radius:3px;display:flex;align-items:center;justify-content:center;color:#b3b3b3;font-size:.72rem}

  /* lines carousel */
  .lines-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:42px;flex-wrap:wrap}
  .carousel{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:14px}
  .carousel::-webkit-scrollbar{height:6px}.carousel::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
  .line-card{flex:0 0 300px;scroll-snap-align:start;border:1px solid var(--line);border-radius:3px;overflow:hidden;background:#fff;cursor:pointer;transition:.2s}
  .line-card:hover{box-shadow:0 14px 34px rgba(31,48,81,.1);transform:translateY(-3px)}
  .line-img{aspect-ratio:4/3;background:var(--navy-tint);display:flex;align-items:center;justify-content:center;color:#9aa9c2;font-size:.74rem;position:relative}
  .line-accent{position:absolute;left:0;top:0;width:100%;height:4px}
  .line-body{padding:24px}
  .line-body h3{font-size:1.25rem;margin-bottom:6px}
  .line-tag{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .line-body p{font-size:.9rem;color:var(--ink-soft);margin:10px 0 14px;min-height:60px}
  .line-by{font-size:.7rem;color:var(--ink-soft);font-style:italic}
  .carousel-nav{display:flex;gap:10px}
  .cbtn{width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--navy);transition:.2s}
  .cbtn:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

  /* why */
  .why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:48px}
  .why-card{padding-top:26px;border-top:2px solid var(--navy)}
  .why-card .n{font-family:var(--display);font-size:1rem;color:var(--gold)}
  .why-card h3{font-size:1.22rem;margin:12px 0 10px}
  .why-card p{font-size:.93rem;color:var(--ink-soft)}

  /* testimonials */
  .testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
  .testi{border:1px solid var(--line);border-radius:3px;padding:32px 28px;background:#fff}
  .testi .q{font-family:var(--display);color:var(--gold);font-size:2.4rem;line-height:0;display:block;height:18px}
  .testi p{font-size:.95rem;margin:18px 0 22px;min-height:78px}
  .testi .who b{color:var(--navy);display:block;font-size:.9rem}
  .testi .who{font-size:.8rem;color:var(--ink-soft)}
  .ph-note{font-size:.74rem;color:var(--gold);letter-spacing:.03em;margin-top:24px}

  /* anniversary */
  .anniv{background:var(--navy);color:#fff;text-align:center;padding:90px 0}
  .anniv .years{font-family:var(--display);font-size:4.4rem;color:#fff}
  .anniv .years b{color:var(--gold)}
  .anniv p{color:#c3cde0;max-width:560px;margin:18px auto 0}

  .cta-final{text-align:center}
  .cta-final h2{font-size:2.5rem;margin-bottom:16px}
  .cta-final .lead{margin:0 auto 30px}
  .cta-final .hero-cta{justify-content:center}

  /* page hero (internal) */
  .page-hero{background:var(--bg-soft);padding:78px 0 66px;border-bottom:1px solid var(--line)}
  .page-hero h1{font-size:2.9rem;margin-bottom:14px}
  .page-hero.dark{background:var(--navy);border-bottom:none;color:#fff;padding:96px 0}
  .page-hero.dark h1{color:#fff;font-size:3.2rem;max-width:18ch}
  .page-hero.dark .eyebrow{color:var(--gold)}
  .page-hero.dark .lead{color:#cdd6e6}

  /* story */
  .story-intro{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
  .story-portrait{aspect-ratio:3/4;background:var(--navy-tint);border-radius:3px;display:flex;align-items:center;justify-content:center;color:#9aa9c2;font-size:.76rem;text-align:center;padding:20px}
  .quote-big{font-family:var(--display);font-size:1.7rem;color:var(--navy);line-height:1.35}
  .quote-sign{margin-top:24px;font-size:.9rem;color:var(--ink-soft)}
  .quote-sign b{color:var(--navy);display:block;font-size:1rem}

  /* PMVV */
  .purpose{text-align:center;max-width:760px;margin:0 auto}
  .purpose h2{font-size:2.4rem;line-height:1.25}
  .mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:56px}
  .mv-card{background:#fff;border:1px solid var(--line);border-radius:3px;padding:38px;border-top:3px solid var(--gold)}
  .mv-card h3{font-family:var(--body);font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
  .mv-card p{font-size:1.12rem;color:var(--navy);font-family:var(--display);line-height:1.4}
  .values{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;margin-top:50px}
  .value{padding-top:20px;border-top:2px solid var(--navy)}
  .value h4{font-family:var(--display);font-size:1.05rem;color:var(--navy);margin-bottom:8px}
  .value p{font-size:.84rem;color:var(--ink-soft)}

  /* timeline carousel */
  .tl-wrap{position:relative;margin-top:30px}
  .tl-track{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:10px}
  .tl-track::-webkit-scrollbar{height:6px}.tl-track::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
  .tl-node{flex:0 0 300px;scroll-snap-align:start;padding:0 28px;position:relative}
  .tl-node::before{content:"";position:absolute;top:18px;left:0;width:100%;height:2px;background:var(--line)}
  .tl-node::after{content:"";position:absolute;top:12px;left:28px;width:14px;height:14px;border-radius:50%;background:var(--gold);border:3px solid #fff;box-shadow:0 0 0 1px var(--gold)}
  .tl-node .tl-year{font-family:var(--display);font-size:1.9rem;color:var(--navy);margin-top:44px}
  .tl-node h3{font-size:1.05rem;margin:8px 0 8px}
  .tl-node p{font-size:.88rem;color:var(--ink-soft)}

  /* lines index page */
  .lines-index{display:grid;grid-template-columns:1fr 1fr;gap:26px}
  .lindex{border:1px solid var(--line);border-radius:3px;overflow:hidden;background:#fff;cursor:pointer;transition:.2s;display:flex;flex-direction:column}
  .lindex:hover{box-shadow:0 16px 40px rgba(31,48,81,.1);transform:translateY(-3px)}
  .lindex-banner{aspect-ratio:21/9;background:var(--navy-tint);display:flex;align-items:center;justify-content:center;color:#9aa9c2;font-size:.78rem;position:relative}
  .lindex-body{padding:30px 32px}
  .lindex-body .line-tag{margin-bottom:8px;display:block}
  .lindex-body h3{font-size:1.5rem;margin-bottom:10px}
  .lindex-body p{font-size:.94rem;color:var(--ink-soft);margin-bottom:18px}

  /* line detail products */
  .line-detail-head{display:flex;align-items:center;gap:18px;margin-bottom:8px}
  .line-dot{width:14px;height:14px;border-radius:50%}
  .prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px}
  .prod{cursor:pointer}
  .prod-img{aspect-ratio:3/4;background:var(--navy-tint);border-radius:3px;display:flex;align-items:center;justify-content:center;color:#9aa9c2;font-size:.74rem;transition:.2s;position:relative;overflow:hidden}
  .prod:hover .prod-img{box-shadow:0 14px 30px rgba(31,48,81,.12)}
  .prod-cap{margin-top:12px;font-size:.86rem;color:var(--navy);font-weight:500}
  .prod-cap span{display:block;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .back-link{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--ink-soft);cursor:pointer;margin-bottom:22px}
  .back-link:hover{color:var(--navy)}

  /* product modal */
  .modal-overlay{position:fixed;inset:0;background:rgba(15,26,48,.55);z-index:80;display:none;align-items:center;justify-content:center;padding:24px}
  .modal-overlay.open{display:flex}
  .modal{background:#fff;width:min(860px,96vw);max-height:90vh;overflow:auto;border-radius:4px;display:grid;grid-template-columns:1fr 1fr;box-shadow:0 40px 100px rgba(0,0,0,.35)}
  .modal-img{background:var(--navy-tint);display:flex;align-items:center;justify-content:center;color:#9aa9c2;font-size:.78rem;min-height:340px}
  .modal-body{padding:40px}
  .modal-close{position:absolute;top:18px;right:22px;background:#fff;border:1px solid var(--line);width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:1.1rem;color:var(--navy);z-index:1}
  .modal-tag{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .modal-body h3{font-size:1.7rem;margin:8px 0 16px}
  .modal-spec{margin:18px 0;border-top:1px solid var(--line)}
  .modal-spec div{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);font-size:.9rem}
  .modal-spec dt{font-weight:600;color:var(--navy);min-width:130px}
  .modal-spec dd{color:var(--ink-soft)}
  .modal-cta{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}

  /* motives (lojista) */
  .motives{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;margin-top:50px}
  .motive{text-align:left;padding:28px 22px;border:1px solid var(--line);border-radius:3px;background:#fff}
  .motive .micon{width:42px;height:42px;color:var(--navy);margin-bottom:16px}
  .motive .micon svg{width:42px;height:42px;stroke:var(--navy);fill:none;stroke-width:1.4}
  .motive h4{font-size:1rem;color:var(--navy);margin-bottom:8px}
  .motive p{font-size:.84rem;color:var(--ink-soft)}

  /* how it works (uniform) */
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:50px;counter-reset:step}
  .step{position:relative;padding-top:30px;border-top:2px solid var(--navy)}
  .step .snum{font-family:var(--display);font-size:1rem;color:var(--gold)}
  .step h4{font-size:1.1rem;margin:10px 0 8px}
  .step p{font-size:.9rem;color:var(--ink-soft)}
  .bordado{margin-top:50px;background:var(--navy);color:#fff;border-radius:4px;padding:48px;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center}
  .bordado .eyebrow{color:var(--gold)}
  .bordado h3{color:#fff;font-size:1.9rem;margin-bottom:14px}
  .bordado p{color:#cdd6e6;font-size:.98rem}
  .bordado-visual{aspect-ratio:4/3;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:3px;display:flex;align-items:center;justify-content:center;color:#9fb0c9;font-size:.78rem}

  /* forms */
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
  .form-side h2{font-size:2rem;margin-bottom:16px}
  .form-side .lead{margin-bottom:24px}
  .form-perks{list-style:none}
  .form-perks li{padding:12px 0;border-bottom:1px solid var(--line);font-size:.92rem;display:flex;gap:12px;align-items:flex-start}
  .form-perks li i{flex:0 0 7px;height:7px;background:var(--gold);border-radius:50%;margin-top:9px;display:block}
  form.card{background:#fff;border:1px solid var(--line);border-radius:3px;padding:38px}
  .field{margin-bottom:18px}
  .field.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  label{display:block;font-size:.78rem;font-weight:600;color:var(--navy);margin-bottom:7px}
  input,select,textarea{width:100%;font-family:var(--body);font-size:.92rem;padding:12px 14px;border:1px solid var(--line);border-radius:2px;background:#fff;color:var(--ink);transition:.18s}
  input:focus,select:focus,textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px var(--navy-tint)}
  textarea{resize:vertical;min-height:90px}
  .form-note{font-size:.74rem;color:var(--ink-soft);margin-top:14px}
  .form-success{display:none;background:var(--navy-tint);border:1px solid var(--navy);border-radius:3px;padding:24px;color:var(--navy);font-size:.95rem}
  .form-success.show{display:block}
  .file-up{display:flex;align-items:center;gap:12px;border:1.5px dashed var(--line);border-radius:2px;padding:16px 14px;cursor:pointer;color:var(--ink-soft);font-size:.86rem;transition:.18s;background:var(--bg-soft)}
  .file-up:hover{border-color:var(--navy);color:var(--navy)}
  .file-up svg{width:22px;height:22px;flex:0 0 22px;stroke:var(--navy);fill:none;stroke-width:1.6}
  .file-up.has-file{border-style:solid;border-color:var(--navy);color:var(--navy);background:var(--navy-tint)}

  /* blog */
  .blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  .post{border:1px solid var(--line);border-radius:3px;overflow:hidden;background:#fff;cursor:pointer;transition:.2s}
  .post:hover{box-shadow:0 14px 34px rgba(31,48,81,.1);transform:translateY(-3px)}
  .post-img{aspect-ratio:16/10;background:var(--navy-tint);display:flex;align-items:center;justify-content:center;color:#9aa9c2;font-size:.74rem}
  .post-body{padding:24px}
  .post-cat{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .post-body h3{font-size:1.1rem;margin:10px 0;line-height:1.3}
  .post-body p{font-size:.88rem;color:var(--ink-soft)}

  /* contact */
  .contact-top{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
  .intent-block{border:1px solid var(--line);border-radius:3px;padding:34px;margin-bottom:22px;background:#fff}
  .intent-block .eyebrow{margin-bottom:12px}
  .intent-block h3{font-size:1.4rem;margin-bottom:10px}
  .intent-block p{font-size:.92rem;color:var(--ink-soft);margin-bottom:20px}
  .contact-bottom{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;margin-top:60px;align-items:start}
  .contact-block{border-top:2px solid var(--navy);padding-top:20px;margin-bottom:26px}
  .contact-block h4{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px}
  .contact-block p{font-size:1rem}
  .map-ph{aspect-ratio:16/12;background:var(--navy-tint);border-radius:3px;display:flex;align-items:center;justify-content:center;color:#9aa9c2;font-size:.78rem;text-align:center;padding:20px}

  /* social strip */
  .social-strip{background:var(--bg-soft);border-top:1px solid var(--line);padding:42px 0}
  .social-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
  .social-inner h3{font-size:1.5rem}
  .social-icons{display:flex;gap:14px}
  .social-icons a{width:46px;height:46px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--navy);transition:.2s}
  .social-icons a:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
  .social-icons svg{width:20px;height:20px}

  /* footer */
  footer{background:var(--navy-700);color:#cdd6e6;padding:64px 0 30px;font-size:.88rem}
  .foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
  .foot-logo img{height:46px;width:auto;margin-bottom:18px}
  footer h4{color:#fff;font-family:var(--body);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
  footer ul{list-style:none}
  footer li{margin-bottom:10px}
  footer a:hover{color:var(--gold)}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.78rem;color:#8d99b3}
  .flag{display:inline-block;font-size:.64rem;letter-spacing:.04em;background:#FBF4E6;color:#8a6d2f;border:1px solid #E8D9B5;border-radius:20px;padding:3px 11px;margin-left:6px}
  .hero-full h1 .hl{font-style:italic;color:var(--gold);font-weight:600}
  .intent-block{transition:transform .2s, box-shadow .2s;cursor:pointer}
  .intent-block.lojista{border-top:3px solid var(--navy)}
  .intent-block.uniform{border-top:3px solid var(--gold)}
  .intent-block:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(31,48,81,.12)}
  .contact-block h4 svg{width:15px;height:15px;vertical-align:-3px;margin-right:7px;stroke:var(--gold);fill:none;stroke-width:2;display:inline-block}
  .lindex-v{flex:0 0 290px;scroll-snap-align:start;border:1px solid var(--line);border-radius:3px;overflow:hidden;background:#fff;cursor:pointer;transition:transform .2s, box-shadow .2s;display:flex;flex-direction:column}
  .lindex-v:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(31,48,81,.12)}
  .lindex-v-banner{aspect-ratio:3/4;background:var(--navy-tint);display:flex;align-items:flex-end;padding:22px;color:#9aa9c2;font-size:.76rem;position:relative}
  .lindex-v-body{padding:24px}
  .lindex-v-body h3{font-size:1.4rem;margin:6px 0 10px}
  .lindex-v-body p{font-size:.88rem;color:var(--ink-soft);margin-bottom:16px;min-height:90px}
  .wa-float{position:fixed;right:22px;bottom:22px;z-index:90;width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.28);transition:transform .2s}
  .wa-float:hover{transform:scale(1.07)}
  .wa-float svg{width:30px;height:30px}
  @media (max-width:980px){.wa-float{width:52px;height:52px;right:16px;bottom:16px}}

  @media (max-width:980px){
    .menu{display:none}.burger{display:flex}
    .menu.open{display:flex;position:absolute;top:78px;left:0;right:0;background:#fff;flex-direction:column;padding:18px 28px;gap:4px;border-bottom:1px solid var(--line);z-index:60}
    .menu.open a{padding:12px 0;border-bottom:1px solid var(--line)}
    .nav-actions .btn{display:none}
    .hero-full h1{font-size:2.7rem}.hero-seal{display:none}
    .hero-full{min-height:auto;padding:40px 0}
    .stats{grid-template-columns:1fr 1fr;gap:24px}.stat{border-right:none}
    .doors{grid-template-columns:1fr}.door + .door{border-left:none;border-top:1px solid var(--line)}
    .logo-row{grid-template-columns:repeat(3,1fr)}
    .why-grid,.testi-grid,.blog-grid,.values,.motives,.steps{grid-template-columns:1fr}
    .story-intro,.form-grid,.mv-grid,.lines-index,.contact-top,.contact-bottom,.bordado{grid-template-columns:1fr}
    .prod-grid{grid-template-columns:1fr 1fr}
    .modal{grid-template-columns:1fr}.modal-img{min-height:200px}
    .field.row{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr 1fr}
    section{padding:60px 0}.anniv .years{font-size:3rem}.page-hero.dark h1{font-size:2.3rem}
  }

/* ===== Overrides p/ fotos reais nos espaços do template ===== */
.line-img,.lindex-v-banner,.prod-img,.ld-photo,.modal-img,.story-portrait,.bordado-visual,.post-img{position:relative;overflow:hidden}
.line-img img,.lindex-v-banner img,.prod-img img,.ld-photo img,.modal-img img,.story-portrait img,.bordado-visual img,.post-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;color:transparent}
.line-img .line-accent,.lindex-v-banner .line-accent{position:absolute;z-index:2}
/* fotos do blog são retrato (pessoas): enquadra o corte no topo p/ não decepar o rosto */
.post-img img{object-position:center 18%}
/* miniaturas da galeria do produto: preenchem o quadrado sem distorcer */
#produto button{position:relative}
#produto button img{display:block;width:100%;height:100%;object-fit:cover;object-position:center 20%}
/* imagem de destaque do post: nunca distorcer (largura fluida, altura proporcional) */
#post img,.post-hero img{height:auto !important;max-width:100%}
.intent-block{display:block}
.line-card,.lindex-v,.door,.post{display:block}
.hero-full.has-photo{background:none}
.hero-full.has-photo .hero-bg{position:absolute;inset:0;z-index:0}
.hero-full.has-photo .hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-full.has-photo::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,26,48,.45),rgba(15,26,48,.86) 78%)}
/* ===== Catálogo de produtos (grid + cards) ===== */
.grid{display:grid;gap:26px}
.grid.c4{grid-template-columns:repeat(4,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
a.card{display:block;background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden;text-decoration:none;color:inherit;transition:box-shadow .18s,transform .18s}
a.card:hover{box-shadow:0 16px 40px rgba(15,26,48,.12);transform:translateY(-3px)}
a.card .thumb{position:relative;width:100%;aspect-ratio:3/4;overflow:hidden;background:#f3f1ec}
a.card .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;color:transparent}
a.card .thumb .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--line)}
a.card .body{padding:16px 18px 20px}
a.card .body .tagline{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
a.card .body h3{font-family:var(--display);font-size:1.05rem;line-height:1.25;margin:0 0 8px;color:var(--navy)}
a.card .body .price{font-size:.9rem;color:var(--muted)}
@media(max-width:980px){.grid.c4{grid-template-columns:repeat(2,1fr)}.grid.c3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid.c4,.grid.c3{grid-template-columns:1fr 1fr;gap:16px}}
/* acessibilidade: skip-link e banner cookies (reuso) */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--gold);color:#fff;padding:10px 16px;z-index:100;font-weight:600}
.skip-link:focus{left:10px;top:10px}
.cookie-bar{position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--navy);color:#fff;padding:16px 22px;display:flex;align-items:center;gap:22px;justify-content:center;flex-wrap:wrap;box-shadow:0 -10px 34px rgba(0,0,0,.22)}
.cookie-bar p{font-size:13.5px;max-width:760px;color:rgba(255,255,255,.9);margin:0}
.cookie-bar a{color:var(--gold);text-decoration:underline}
.cookie-actions{display:flex;gap:10px}
.cookie-bar .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.cookie-bar .btn-ghost:hover{background:#fff;color:var(--navy)}

.cookie-bar[hidden]{display:none!important}
;