/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */

 :root{
    --ink:#081208;
    --walnut:#0a2010;
    --roast:#0a481a;
    --roast-light:#0f5a21;
    --amber:#f9a908;
    --amber-bright:#ffbe3d;
    --ivory:#ece4d1;
    --ivory-dim:#c7c2ad;
    --bronze:#8fae8e;
    --stitch:#e9dfc4;
    --line: rgba(236,228,209,0.16);
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--ink);
    color:var(--ivory);
    font-family:'Inter',sans-serif;
    font-weight:400;
    line-height:1.6;
    overflow-x:hidden;
  }
  img{display:block;max-width:100%;}
  .serif{font-family:'Playfair Display',serif;}
  .eyebrow{
    font-size:11px;
    letter-spacing:0.22em;
    text-transform:uppercase;
    color:var(--amber);
    font-weight:600;
  }
  a{color:inherit;text-decoration:none;}

  /* ===== NAV ===== */
  nav{
    position:fixed;top:0;left:0;right:0;z-index:100;
    display:flex;align-items:center;justify-content:space-between;
    padding:22px 6vw;
    background:linear-gradient(to bottom, rgba(20,15,12,0.85), transparent);
    backdrop-filter:blur(2px);
  }
  .logo{
    font-family:'Playfair Display',serif;
    font-style:italic;
    font-weight:600;
    font-size:22px;
    letter-spacing:0.01em;
  }
  .nav-cta{
    /* border:1px solid rgba(244,236,224,0.35); */
    background-color: var(--amber);
    color: var(--ink);
    padding:9px 20px;
    font-size:12px;
    font-weight: 600;
    letter-spacing:0.1em;
    text-transform:uppercase;
    border-radius:2px;
    transition:all .25s ease;
  }
  .nav-cta:hover{background:var(--amber);color:var(--ink);border-color:var(--roast);}

  /* ===== HERO ===== */
  .hero{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:flex-end;
  }
  .hero-img{
    position:absolute;inset:0;
    width:100%;height:100%;
    object-fit:cover;
    /* object-position:50% 28%; */
  }
  .hero-scrim{
    position:absolute;inset:0;
    background:linear-gradient(to top, rgba(15,11,8,0.98) 8%, rgba(15,11,8,0.55) 38%, rgba(15,11,8,0.05) 60%);
  }
  .hero-inner{
    position:relative;z-index:2;
    width:100%;
    /* padding:0 6vw 6vw; */
    padding:0 6vw 12vw;
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap:40px;
  }
  .hero-copy{max-width:560px;}
  .hero-copy p.lede{
    margin-top: 10px;
    font-size:17px;
    color:var(--ivory-dim);
    max-width:430px;
    font-weight:300;
  }

  .hero-ctas{
    display:flex;align-items:center;gap:22px;
    margin-top:24px;
    justify-content: space-between;
  }
  .btn-primary{
    background:var(--amber);
    color:#1c1208;
    font-weight:600;
    font-size:13px;
    letter-spacing:0.06em;
    text-transform:uppercase;
    padding:16px 30px;
    border-radius:3px;
    display:inline-flex;align-items:center;gap:10px;
    transition:transform .25s ease, background .25s ease;
  }
  .btn-primary:hover{background:var(--amber);transform:translateY(-2px);}
  .btn-secondary{
    font-size:13px;color:var(--ivory-dim);
    border-bottom:1px solid rgba(244,236,224,0.3);
    padding-bottom:3px;
  }
  .hero-price-card{
    flex-shrink:0;
    text-align:right;
    padding-bottom:6px;
  }
  .hero-price-card .price{
    font-family:'Playfair Display',serif;
    font-size:38px;
    font-weight:600;
  }
  .hero-price-card .price-note{
    font-size:12px;color:var(--ivory-dim);margin-top:4px;
  }

  /* ===== MARQUEE STRIP ===== */
  .strip{
    background:var(--roast);
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    padding:16px 0;
    overflow:hidden;
    white-space:nowrap;
  }
  .strip-track{
    display:inline-block;
    animation:scroll 32s linear infinite;
    font-size:13px;letter-spacing:0.14em;text-transform:uppercase;color:var(--bronze);
  }
  .strip-track span{margin:0 28px;}
  .strip-track span.dot{color:var(--amber);}
  @keyframes scroll{
    0%{transform:translateX(0);}
    100%{transform:translateX(-50%);}
  }

  /* ===== SECTION SHARED ===== */
  section{padding:140px 6vw;}
  .section-head{
    max-width:640px;
    margin-bottom:48px;
  }

 
  .section-head h2{
    font-size:clamp(32px,4vw,52px);
    font-weight:600;
    line-height:1.12;
    margin-top:16px;
  }
  .section-head h2 em{
    font-style:italic;
    color:var(--amber-bright);
  }

  /* ===== STORY / CRAFT SECTION ===== */
  .craft{
    background:var(--ink);
  }
  .craft-grid{
    display:grid;
    grid-template-columns:0.9fr 1.1fr;
    gap:90px;
    align-items:center;
  }
  .craft-img-wrap{
    position:relative;
    border-radius:4px;
    overflow:hidden;
  }
  .craft-img-wrap img{
    width:100%;
    filter:contrast(1.06) saturate(1.05);
  }
  .craft-img-tag{
    position:absolute;bottom:18px;left:18px;
    background:rgba(20,15,12,0.78);
    backdrop-filter:blur(6px);
    border:1px solid rgba(244,236,224,0.2);
    padding:10px 16px;
    font-size:11px;letter-spacing:0.08em;text-transform:uppercase;
    color:var(--ivory-dim);
    border-radius:2px;
  }
  .craft-copy p{
    color:var(--ivory-dim);
    font-size:16px;
    margin-bottom:22px;
    max-width:480px;
    font-weight:300;
  }
  .craft-list{
    margin-top:38px;
    display:flex;
    flex-direction:column;
    gap:0;
  }
  .craft-list-item{
    display:flex;
    gap:22px;
    padding:22px 0;
    border-top:1px solid var(--line);
  }
  .craft-list-item:last-child{border-bottom:1px solid var(--line);}
  .craft-list-item .num{
    font-family:'Playfair Display',serif;
    font-style:italic;
    color:var(--amber);
    font-size:18px;
    width:28px;flex-shrink:0;
  }
  .craft-list-item h4{
    font-size:16px;font-weight:600;margin-bottom:4px;
  }
  .craft-list-item p{
    font-size:14px;color:var(--bronze);margin:0;max-width:none;
  }

  /* ===== SPEC / TAG SECTION (signature element) ===== */
  .specs{
    background:var(--roast);
    position:relative;
  }
  .specs-inner{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:80px;
    align-items:start;
  }
  .tag-card{
    background:var(--roast-light);
    border:1.5px dashed rgba(232,220,200,0.3);
    border-radius:6px;
    padding:48px 44px;
    position:relative;
  }
  .tag-card::before{
    content:'';
    position:absolute;
    top:24px;left:24px;right:24px;bottom:24px;
    border:1px solid rgba(232,220,200,0.16);
    border-radius:3px;
    pointer-events:none;
  }
  .tag-hole{
    width:14px;height:14px;
    border-radius:50%;
    border:2px solid rgba(232,220,200,0.4);
    position:absolute;
    top:36px;right:36px;
    background:var(--roast);
  }
  .tag-eyebrow{
    font-family:'Playfair Display',serif;font-style:italic;
    font-size:14px;color:var(--ivory-dim);
    margin-bottom:6px;
  }
  .tag-title{
    font-family:'Playfair Display',serif;
    font-size:26px;font-weight:600;
    margin-bottom:30px;
  }
  .spec-row{
    display:flex;justify-content:space-between;
    padding:16px 0;
    border-top:1px solid rgba(232,220,200,0.14);
    font-size:14px;
  }
  .spec-row:last-of-type{border-bottom:1px solid rgba(232,220,200,0.14);}
  .spec-row .k{color:var(--bronze);}
  .spec-row .v{color:var(--ivory);font-weight:500;text-align:right;}

  .specs-copy h2{
    font-size:clamp(30px,3.6vw,46px);
    font-weight:600;line-height:1.15;margin-bottom:24px;
  }
  .specs-copy p{
    color:var(--ivory-dim);font-size:16px;font-weight:300;margin-bottom:18px;max-width:440px;
  }
  .swatch-row{
    display:flex;gap:14px;margin-top:34px;
  }
  .swatch{
    width:54px;height:54px;border-radius:50%;
    border:2px solid rgba(244,236,224,0.25);
  }

  /* ===== GALLERY / DETAIL STRIP ===== */
  .gallery{
    background:var(--ink);
  }
  .gallery-grid{
    display:grid;
    grid-template-columns:1.3fr 1fr 1fr;
    gap:24px;
  }
  .gallery-grid.two-up{
    grid-template-columns:1fr 1fr;
  }
  .gallery-grid.two-up .gallery-cell{
    aspect-ratio:4/5;
  }
  .gallery-grid img{
    width:100%;height:100%;object-fit:cover;
    border-radius:4px;
    filter:contrast(1.05) saturate(1.04);
  }
  .gallery-cell{
    position:relative;
    overflow:hidden;
    border-radius:4px;
  }
  .gallery-cell.tall{grid-row:span 2;}
  .gallery-caption{
    position:absolute;bottom:16px;left:16px;right:16px;
    font-size:12px;letter-spacing:0.06em;
    color:var(--ivory-dim);
    text-transform:uppercase;
  }

  /* ===== TESTIMONIAL / PROOF ===== */
  .proof{
    background:var(--roast);
    text-align:center;
  }
  .proof-quote{
    max-width:780px;margin:0 auto;
  }
  .proof-quote .stars{
    color:var(--amber-bright);
    font-size:18px;letter-spacing:4px;margin-bottom:30px;
  }
  .proof-quote p{
    font-family:'Playfair Display',serif;
    font-style:italic;
    font-size:clamp(24px,2.6vw,34px);
    font-weight:500;
    line-height:1.4;
    color:var(--ivory);
  }
  .proof-attr{
    margin-top:30px;
    font-size:13px;
    color:var(--bronze);
    letter-spacing:0.05em;
    text-transform:uppercase;
  }
  .proof-row{
    display:flex;justify-content:center;gap:90px;
    margin-top:20px;
    flex-wrap:wrap;
  }
  .proof-stat .num{
    font-family:'Playfair Display',serif;font-size:42px;font-weight:600;color:var(--amber-bright);
  }
  .proof-stat .label{
    font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--bronze);margin-top:6px;
  }

  /* ===== FINAL CTA ===== */
  .final-cta{
    background:var(--ink);
    text-align:center;
    padding-top:160px;
    padding-bottom:120px;
  }
  .final-cta h2{
    font-family:'Playfair Display',serif;
    font-style:italic;
    font-size:clamp(38px,6vw,72px);
    font-weight:600;
    line-height:1.05;
    max-width:820px;
    margin:0 auto 26px;
  }
  .final-cta p{
    color:var(--ivory-dim);font-size:16px;max-width:480px;margin:0 auto 42px;font-weight:300;
  }
  .final-cta .btn-primary{padding:18px 40px;font-size:13px;}
  .guarantee{
    margin-top:28px;
    font-size:12px;
    color:var(--bronze);
    letter-spacing:0.06em;
    text-transform:uppercase;
  }

  /* ===== FOOTER ===== */
  footer{
    background:var(--ink);
    border-top:1px solid var(--line);
    padding:40px 6vw;
    display:flex;justify-content:space-between;align-items:center;
    font-size:12px;color:var(--bronze);
    letter-spacing:0.04em;
  }
  footer .logo{font-size:16px;color:var(--ivory-dim);}

  /* ===== RESPONSIVE ===== */
  @media (max-width:880px){
    section{padding:90px 6vw;}
    .hero-inner{flex-direction:column;align-items:flex-start;gap:34px;}
    .hero-price-card{text-align:left;}
    .craft-grid{grid-template-columns:1fr;gap:48px;}
    .specs-inner{grid-template-columns:1fr;gap:24px;}
    .gallery-grid{grid-template-columns:1fr 1fr;}
    .gallery-cell.tall{grid-row:span 1;}
    .proof-row{gap:50px;}
    footer{flex-direction:column;gap:14px;text-align:center;}

    .hero-img {
      height: 80%;
    }

    .gallery-grid.two-up{
      grid-template-columns: 1fr;
    }
  }
  @media (prefers-reduced-motion: reduce){
    .strip-track{animation:none;}
    html{scroll-behavior:auto;}
  }