/* ClicknFile · pdp.css
 * Shared styles for all product detail pages.
 * Loaded by every PDP. To change PDP look, edit here.
 *
 * Layered with motion.css (animations + responsive edge cases).
 */

:root{--primary:#1B4D4A;--primary-light:#2a6b67;--accent:#F5A623;--accent-dark:#d4891a;--bg:#F5EFE0;--bg-dark:#EDE6D0;--bg-card:#FDFAF4;--text:#1A1A1A;--text-muted:#6b6560;--white:#fff;--border:rgba(27,77,74,.10);--shadow:0 4px 24px rgba(27,77,74,.08);--shadow-hover:0 16px 48px rgba(27,77,74,.16);--radius:20px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:"Montserrat",sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6;}
img{max-width:100%;height:auto;display:block;}a{color:inherit;}
header>nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 5vw;height:72px;background:rgba(245,239,224,.85);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid rgba(27,77,74,.06);transition:height .25s ease,background .25s ease,box-shadow .25s ease,border-color .25s ease;}
header>nav.scrolled{height:60px;background:rgba(245,239,224,.92);box-shadow:0 8px 24px -12px rgba(27,77,74,.18),0 1px 0 rgba(27,77,74,.04);border-bottom-color:transparent;}
.nav-logo{text-decoration:none;display:flex;align-items:center;flex-shrink:0;transition:transform .25s ease;}
.nav-logo:hover{transform:scale(1.04);}
.nav-logo img{height:36px;width:auto;transition:height .25s ease;}
nav.scrolled .nav-logo img{height:32px;}
.nav-links{display:flex;gap:.35rem;list-style:none;align-items:center;}
.nav-links a{position:relative;font-size:.72rem;font-weight:700;color:var(--text-muted);text-decoration:none;letter-spacing:.08em;text-transform:uppercase;transition:color .2s,background .2s;white-space:nowrap;padding:.55rem .85rem;border-radius:100px;}
.nav-links a:hover{color:var(--primary);background:rgba(27,77,74,.06);}
.nav-links a{position:relative;}
.nav-links a.active{color:var(--primary);}
.nav-links a.active::after{content:"";position:absolute;left:50%;bottom:-3px;width:22px;height:2px;border-radius:2px;background:var(--accent);transform:translateX(-50%);animation:nav-active-glow 2.6s ease-in-out infinite;}
@keyframes nav-active-glow{0%,100%{opacity:.65;box-shadow:0 0 6px 0 rgba(245,166,35,.4);}50%{opacity:1;box-shadow:0 0 12px 2px rgba(245,166,35,.7);}}
.nav-cta{background:linear-gradient(180deg,#F8B043 0%,#F5A623 50%,#E89510 100%)!important;color:var(--text)!important;padding:.55rem 1.1rem!important;border-radius:100px!important;font-weight:800!important;text-transform:none!important;font-size:.78rem!important;letter-spacing:0!important;box-shadow:0 1px 0 rgba(255,255,255,.4) inset,0 -1px 0 rgba(0,0,0,.08) inset,0 4px 12px -2px rgba(245,166,35,.45)!important;transition:transform .2s,box-shadow .2s!important;}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.5) inset,0 -1px 0 rgba(0,0,0,.08) inset,0 8px 18px -2px rgba(245,166,35,.55)!important;background:linear-gradient(180deg,#F8B043 0%,#F5A623 50%,#E89510 100%)!important;}
.nav-cta::after{display:none!important;}
.nav-burger{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text);padding:.4rem;border-radius:8px;transition:background .2s;}
.nav-burger:hover{background:rgba(27,77,74,.08);}
h1{font-size:clamp(2rem,4.2vw,3.4rem);font-weight:900;line-height:1.04;letter-spacing:-.035em;color:var(--text);}
h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:900;letter-spacing:-.028em;line-height:1.12;color:var(--text);margin-bottom:.5rem;}
h3{font-size:1.05rem;font-weight:800;color:var(--text);margin-bottom:.5rem;}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:var(--primary);color:var(--white);padding:.85rem 1.75rem;border-radius:100px;font-size:.85rem;font-weight:800;text-decoration:none;transition:background .2s,transform .2s;box-shadow:0 4px 18px rgba(27,77,74,.28);}
.btn-primary:hover{background:var(--primary-light);transform:translateY(-2px);}
.btn-accent{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:var(--accent);color:var(--text);padding:1.05rem 2rem;border-radius:100px;font-size:.95rem;font-weight:800;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 8px 26px rgba(245,166,35,.4);}
.btn-accent:hover{background:var(--accent-dark);transform:translateY(-3px);box-shadow:0 14px 36px rgba(245,166,35,.5);}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:var(--white);color:var(--text);padding:.85rem 1.75rem;border-radius:100px;font-size:.85rem;font-weight:700;text-decoration:none;border:2px solid var(--border);transition:all .2s;}
.btn-secondary:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px);}
.btn-ghost{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:var(--white);padding:.9rem 1.8rem;border-radius:100px;font-size:.88rem;font-weight:700;text-decoration:none;border:2px solid rgba(255,255,255,.25);transition:all .2s;}
.btn-ghost:hover{border-color:white;background:rgba(255,255,255,.1);}
.section-tag{font-family:"Caveat",cursive;font-size:1.35rem;font-weight:700;color:var(--accent-dark);margin-bottom:.4rem;display:flex;align-items:center;gap:.4rem;}

/* PDP layout */
.pdp-wrap{position:relative;padding:96px 5vw 0;}
.breadcrumb{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.72rem;color:var(--text-muted);font-weight:600;margin-bottom:1.5rem;position:relative;z-index:2;}
.breadcrumb a{color:var(--text-muted);text-decoration:none;}
.breadcrumb a:hover{color:var(--primary);}
.breadcrumb .sep{opacity:.4;}
.breadcrumb .current{color:var(--text);font-weight:700;}

.pdp-main{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:start;padding-bottom:3.5rem;}

/* Gallery left */
.pdp-gallery{position:sticky;top:90px;}
.pdp-gallery-main{position:relative;aspect-ratio:5/4;background:var(--bg-card);border-radius:24px;overflow:hidden;border:1px solid rgba(27,77,74,.08);box-shadow:0 1px 0 rgba(255,255,255,.6) inset,0 0 0 1px rgba(27,77,74,.04),0 12px 32px -8px rgba(27,77,74,.10),0 32px 64px -16px rgba(27,77,74,.10);}
.pdp-gallery-main img{width:100%;height:100%;object-fit:contain;}
.pdp-gallery-main video{width:100%;height:100%;object-fit:contain;display:block;background:#000;}
.pdp-gallery-main img[hidden],.pdp-gallery-main video[hidden]{display:none;}
.pdp-gallery-badge{position:absolute;top:18px;left:18px;z-index:2;}
.pdp-gallery-thumbs{display:flex;gap:.6rem;margin-top:.85rem;flex-wrap:wrap;}
.pdp-gallery-thumb{width:72px;height:72px;border-radius:10px;overflow:hidden;border:1.5px solid var(--border);cursor:pointer;transition:border-color .2s,transform .2s;background:var(--bg-card);padding:0;position:relative;}
.pdp-gallery-thumb:hover{transform:translateY(-2px);}
.pdp-gallery-thumb.active{border-color:var(--primary);}
.pdp-gallery-thumb img{width:100%;height:100%;object-fit:cover;}
.pdp-gallery-thumb-video::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.22);z-index:1;}
.pdp-gallery-thumb-video .pdp-thumb-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:26px;height:26px;background:rgba(255,255,255,.94);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--primary);padding-left:2px;z-index:2;pointer-events:none;}

/* Info right */
.pdp-info{padding-top:.25rem;}
.pdp-cat{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--primary);opacity:.7;margin-bottom:.55rem;}
.pdp-title{margin-bottom:.7rem;}
.pdp-rating{display:flex;align-items:center;gap:.6rem;margin-bottom:1.1rem;font-size:.78rem;color:var(--text-muted);font-weight:600;}
.pdp-stars{color:var(--accent);letter-spacing:.05em;font-size:.95rem;}
.pdp-price-wrap{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.25rem;padding:1.1rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.pdp-price{font-size:2.6rem;font-weight:900;color:var(--primary);letter-spacing:-.035em;line-height:1;}
.pdp-price sup{font-size:1.05rem;vertical-align:super;font-weight:800;}
.pdp-price-meta{display:flex;flex-direction:column;gap:.15rem;padding-bottom:.4rem;}
.pdp-price-note{font-size:.72rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em;}
.pdp-price-sub{font-size:.7rem;color:var(--text-muted);font-weight:600;}
.pdp-tagline{font-family:"Caveat",cursive;font-size:1.55rem;font-weight:700;color:var(--accent-dark);margin-bottom:1.25rem;}
.pdp-short-desc{font-size:.93rem;color:var(--text-muted);line-height:1.75;margin-bottom:1.5rem;}
.pdp-cta-row{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem;}
.pdp-cta-row .btn-accent{width:100%;font-size:1rem;padding:1.15rem 1.8rem;}
.pdp-etsy-note{font-size:.7rem;color:var(--text-muted);text-align:center;font-weight:600;margin-top:-.15rem;}
.pdp-etsy-note span{color:var(--accent-dark);font-weight:800;}
/* Sold-out card replaces the "Buy on Etsy" button on PDPs whose product
 * has status:"soldout" in products.json. Kept indexable so SEO survives. */
.pdp-soldout-card{padding:1.25rem 1.4rem;background:var(--bg-card);border:1.5px solid rgba(245,166,35,.4);border-left:4px solid var(--accent);border-radius:14px;}
.pdp-soldout-title{font-size:.85rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-dark);margin-bottom:.55rem;}
.pdp-soldout-msg{font-size:.85rem;line-height:1.6;color:var(--text);}
.pdp-soldout-msg a{color:var(--accent-dark);font-weight:700;text-decoration:underline;}
.pdp-trust{display:grid;grid-template-columns:1fr 1fr;gap:.55rem .9rem;font-size:.74rem;color:var(--text-muted);font-weight:700;padding:1.1rem 1.2rem;background:var(--bg-card);border:1.5px solid var(--border);border-radius:14px;}
.pdp-trust-item{display:flex;align-items:center;gap:.45rem;}
.pdp-trust-item svg{flex-shrink:0;color:var(--primary);}

/* Sections under fold */
.pdp-section{position:relative;padding:4rem 5vw;background:var(--white);border-top:1px solid var(--border);overflow:hidden;}
.pdp-section.alt{background:var(--bg);border-top:1px solid var(--border);}
.pdp-section-inner{position:relative;z-index:2;max-width:1400px;margin:0 auto;}
.pdp-section h2{margin-bottom:.5rem;}
.pdp-section .section-desc{font-size:.93rem;color:var(--text-muted);max-width:640px;margin-bottom:2rem;line-height:1.7;}

/* Long description */
.pdp-long{font-size:.97rem;color:var(--text-muted);line-height:1.85;max-width:760px;}

/* Features grid */
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem 1.25rem;margin-top:1.75rem;}
.feature-item{display:flex;gap:.7rem;align-items:flex-start;padding:1rem 1.15rem;background:var(--bg-card);border:1.5px solid var(--border);border-radius:14px;transition:border-color .2s,transform .2s,box-shadow .2s;}
.feature-item:hover{border-color:rgba(27,77,74,.3);transform:translateY(-2px);box-shadow:0 8px 22px rgba(27,77,74,.06);}
.feature-check{flex-shrink:0;width:24px;height:24px;background:rgba(27,77,74,.1);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:900;margin-top:.05rem;}
.feature-text{font-size:.84rem;color:var(--text);font-weight:600;line-height:1.55;}

/* What's inside + Specs side by side */
.box-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;margin-top:1.75rem;}
.box{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.85rem;position:relative;overflow:hidden;}
.box-title{font-family:"Caveat",cursive;font-size:1.45rem;font-weight:700;color:var(--accent-dark);margin-bottom:.9rem;}
.box ul{list-style:none;display:flex;flex-direction:column;gap:.65rem;}
.box ul li{display:flex;gap:.7rem;align-items:flex-start;font-size:.84rem;color:var(--text);line-height:1.55;}
.box ul li::before{content:"";flex-shrink:0;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-top:.55rem;}
.spec-row{display:flex;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px dashed var(--border);font-size:.81rem;}
.spec-row:last-child{border-bottom:none;}
.spec-label{color:var(--text-muted);font-weight:600;}
.spec-val{color:var(--text);font-weight:700;text-align:right;}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:.65rem;margin-top:1.75rem;max-width:780px;}
.faq-item{background:var(--bg-card);border:1.5px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .2s;}
.faq-item.open{border-color:rgba(27,77,74,.25);}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:1.15rem 1.35rem;font-family:inherit;font-size:.93rem;font-weight:700;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;}
.faq-q::after{content:"+";font-size:1.3rem;font-weight:300;color:var(--primary);transition:transform .25s;flex-shrink:0;}
.faq-item.open .faq-q::after{transform:rotate(45deg);}
.faq-a{padding:0 1.35rem;font-size:.86rem;color:var(--text-muted);line-height:1.7;height:0;overflow:hidden;}
.faq-a-inner{padding-bottom:1.15rem;}

/* Related */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1.75rem;}
.related-card{background:var(--bg-card);border-radius:var(--radius);overflow:hidden;border:1.5px solid var(--border);transition:transform .3s cubic-bezier(.34,1.4,.64,1),box-shadow .3s,border-color .3s;text-decoration:none;color:inherit;display:flex;flex-direction:column;position:relative;}
.related-card.soldout .related-img img{filter:grayscale(.5) opacity(.7);}
.related-card.soldout .related-price{color:var(--text-muted);text-decoration:line-through;}
.related-soldout-pill{position:absolute;top:10px;left:10px;z-index:2;background:#6B6560;color:#FFF;font-size:.55rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .55rem;border-radius:100px;box-shadow:0 4px 14px rgba(107,101,96,.3);}
.related-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:rgba(27,77,74,.2);}
.related-img{aspect-ratio:5/4;overflow:hidden;}
.related-img img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform .5s ease;}
.related-card:hover .related-img img{transform:scale(1.06);}
.related-body{padding:1.15rem 1.25rem 1.3rem;flex:1;display:flex;flex-direction:column;}
.related-cat{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--primary);opacity:.6;margin-bottom:.3rem;}
.related-name{font-size:.88rem;font-weight:800;line-height:1.3;color:var(--text);margin-bottom:.85rem;flex:1;}
.related-price{font-size:1.25rem;font-weight:900;color:var(--primary);letter-spacing:-.02em;}
.related-price sup{font-size:.55rem;vertical-align:super;}

/* Final CTA */
.final-cta{position:relative;background:var(--primary);text-align:center;padding:5rem 5vw;overflow:hidden;}
.final-cta-inner{position:relative;z-index:2;}
.final-cta h2{color:var(--white);margin-bottom:.4rem;}
.final-cta-tagline{font-family:"Caveat",cursive;font-size:1.65rem;color:var(--accent);margin-bottom:1.85rem;}
.final-cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}

/* Footer */
footer{background:#0f1a19;color:rgba(255,255,255,.5);padding:4rem 5vw 0;}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.07);}
.footer-logo-text{font-family:"Montserrat",sans-serif;font-size:1.4rem;font-weight:900;letter-spacing:-.02em;color:var(--white);text-decoration:none;display:inline-block;margin-bottom:.9rem;}
.footer-logo-text span{color:var(--accent);}
.footer-tagline{font-family:"Caveat",cursive;font-size:1.25rem;color:var(--accent);margin-bottom:.5rem;}
.footer-brand-desc{font-size:.77rem;color:rgba(255,255,255,.35);line-height:1.65;margin-bottom:1.2rem;max-width:280px;}
.social-links{display:flex;gap:.55rem;flex-wrap:wrap;}
.social-link{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);transition:all .2s;text-decoration:none;}
.social-link:hover{background:var(--accent);border-color:var(--accent);color:#111;transform:translateY(-2px);}
.social-link svg{width:14px;height:14px;}
.footer-col{display:flex;flex-direction:column;gap:.55rem;}
.footer-col-title{font-size:.62rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:.5rem;}
.footer-col a{font-size:.77rem;color:rgba(255,255,255,.36);text-decoration:none;transition:color .2s;font-weight:500;}
.footer-col a:hover{color:rgba(255,255,255,.85);}
.footer-trust{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;padding:1.1rem 0;border-bottom:1px solid rgba(255,255,255,.06);}
.footer-trust span{font-size:.69rem;font-weight:600;color:rgba(255,255,255,.28);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.67rem;padding:1.1rem 0;}

/* Responsive (base – refined further in motion.css for edge widths) */
@media(max-width:1100px){
  .pdp-main{grid-template-columns:1fr;gap:2rem;}
  .pdp-gallery{position:static;}
  .related-grid{grid-template-columns:repeat(2,1fr);}
  .footer-inner{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  header>nav{padding:0 4vw;}
  .nav-links{display:flex;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:rgba(245,239,224,.96);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);padding:1.25rem 6vw;gap:.5rem;border-top:1px solid rgba(27,77,74,.06);z-index:199;box-shadow:0 12px 32px -8px rgba(27,77,74,.18);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .25s ease,transform .25s ease,visibility 0s linear .25s;}
  header>nav.open .nav-links{opacity:1;visibility:visible;transform:translateY(0);transition:opacity .25s ease,transform .25s ease,visibility 0s;}
  .nav-links a{padding:.85rem 1rem;font-size:.85rem;letter-spacing:.05em;}
  .nav-burger{display:block;}
  header>nav.scrolled .nav-links{top:60px;}
  .pdp-wrap{padding:84px 4vw 0;}
  .pdp-section{padding:3rem 4vw;}
  .feature-grid{grid-template-columns:1fr;}
  .box-grid{grid-template-columns:1fr;}
  .related-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
}


/* ----- Customer reviews on PDP ----- */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;margin-top:1.5rem;}
.review-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:18px;padding:1.6rem;margin:0;position:relative;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;}
.review-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px -10px rgba(27,77,74,.18);border-color:rgba(27,77,74,.18);}
.review-stars{color:var(--accent);font-size:1.05rem;letter-spacing:.05em;margin-bottom:.85rem;}
.review-text{font-size:.95rem;line-height:1.65;color:var(--text);margin:0 0 1.1rem;font-style:normal;quotes:"\201C" "\201D";}
.review-text::before{content:open-quote;color:var(--accent);font-size:1.4rem;font-weight:800;margin-right:.15em;line-height:0;vertical-align:-0.2em;}
.review-text::after{content:close-quote;color:var(--accent);font-size:1.4rem;font-weight:800;margin-left:.15em;line-height:0;vertical-align:-0.2em;}
.review-author{font-size:.82rem;color:var(--text-muted);font-weight:600;display:flex;justify-content:space-between;align-items:baseline;gap:.7rem;flex-wrap:wrap;}
.review-author strong{color:var(--text);font-weight:700;}
.review-date{font-size:.74rem;opacity:.75;font-weight:500;}
