/* ===== ECW marketing — content pages: pricing, brands, blog, products ===== */

/* shared helpers */
.container.narrow{max-width:820px}
.section.alt{background:var(--cream)}
.bodytext{font-size:1.06rem;color:var(--ink);margin:0 0 1.1em;line-height:1.7}
.muted{color:var(--gray)}
.small{font-size:.85rem}
.fineprint{font-size:.85rem;color:var(--gray);line-height:1.6;margin-top:1rem}
.fineprint.center{text-align:center}
.big-quote{font-family:"Cormorant Garamond",Georgia,serif;font-size:1.7rem;line-height:1.35;
  font-style:italic;color:var(--slate);border-left:3px solid var(--sage);padding:.4em 0 .4em 1.2rem;margin:1.6rem 0 0}
.num-list{counter-reset:n;list-style:none;padding:0;margin:0;max-width:760px}
.num-list li{position:relative;padding:0 0 1em 2.6rem;margin:0;line-height:1.65;color:var(--ink)}
.num-list li::before{counter-increment:n;content:counter(n);position:absolute;left:0;top:0;
  width:1.8rem;height:1.8rem;border-radius:50%;background:var(--sage);color:var(--slate);
  font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center}
.callout{border-radius:14px;padding:18px 22px;margin:1.4rem 0 0;line-height:1.6}
.callout.warn{background:#fbf0c4;color:#6f5512;border:1px solid #f0e0a0}

/* two-up info blocks */
.two-up{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:start}
.info-block h3{font-size:1.3rem;margin-bottom:.4em}
@media(max-width:760px){.two-up{grid-template-columns:1fr;gap:26px}}

/* ===== PRICING ===== */
.pv-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;max-width:620px;margin:0 auto 26px}
.pv-item{text-align:center;padding:14px 10px;background:var(--paper);border:1px solid #ece7d8;border-radius:10px}
.pv-check{font-size:1.05rem;color:var(--sage-dk);font-weight:700}
.pv-name{font-size:.86rem;font-weight:600;color:var(--slate);margin:.35rem 0 .1rem}
.pv-sub{font-size:.76rem;color:var(--gray);margin:0}
.tier-tiles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:0 0 18px}
.tier-tile{background:var(--paper);border:1px solid #ece7d8;border-radius:14px;padding:22px 16px;text-align:center;box-shadow:0 8px 24px rgba(51,60,69,.05)}
.tier-amt{font-family:"Cormorant Garamond",Georgia,serif;font-size:2.3rem;font-weight:600;color:var(--slate)}
.tier-amt .price-start{margin-right:.15rem}
.tier-label{font-size:.92rem;font-weight:600;color:var(--slate);margin:.2rem 0 .3rem}
.tier-sample{font-size:.82rem;color:var(--gray);line-height:1.5;margin:0}
.tier-sample a{color:var(--slate);font-weight:600}
.finder-cue{display:flex;align-items:center;gap:.9rem;background:var(--sage-tint);border-radius:12px;padding:.85rem 1.1rem;max-width:620px;margin:0 auto 14px;text-decoration:none}
.finder-cue-q{flex:1;font-size:.88rem;color:var(--ink);line-height:1.5}
.finder-cue-q b{color:var(--slate)}
.finder-cue-go{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--sage-dk);white-space:nowrap}
.finder-cue:hover{background:#e7e9da}
.price-footnote{text-align:center;font-size:.8rem;color:var(--gray);max-width:520px;margin:0 auto 6px;line-height:1.6}
@media(max-width:560px){
  .tier-tiles{grid-template-columns:1fr;max-width:340px;margin-left:auto;margin-right:auto}
  .pv-strip{gap:8px}
  .pv-sub{display:none}
}
.price-amt{font-family:"Cormorant Garamond",Georgia,serif;font-size:2.4rem;font-weight:600;color:var(--slate)}
.price-notes{max-width:760px;margin:1.2rem auto 0}

.info-table{width:100%;border-collapse:collapse;margin:.4rem 0 0}
.info-table th{text-align:left;vertical-align:top;padding:.7em 1em .7em 0;color:var(--slate);font-weight:600;
  white-space:nowrap;border-bottom:1px solid #ece7d8;width:1%}
.info-table td{padding:.7em 0;border-bottom:1px solid #ece7d8;color:var(--ink)}
.info-table td .muted{display:block;font-size:.88rem;margin-top:.15em}
.price-card{margin-bottom:2.2rem}
.price-card h3{font-size:1.45rem;margin-bottom:.2em}
.policy-list{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:1rem}
.policy-item h4{font-size:1.05rem;color:var(--slate);margin-bottom:.3em}
.policy-item p{font-size:.94rem;color:var(--ink);margin:0;line-height:1.6}
@media(max-width:680px){.policy-list{grid-template-columns:1fr}}

/* ===== BRANDS ===== */
.brand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:18px;margin-top:1.6rem}
.brand-grid.small{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));max-width:760px;margin-left:auto;margin-right:auto}
.brand-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  background:#fff;border:1px solid #ece7d8;border-radius:16px;padding:26px 18px;min-height:140px;
  text-decoration:none;transition:.18s ease}
.brand-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(51,60,69,.1);border-color:var(--sage)}
.brand-logo{height:56px;display:flex;align-items:center;justify-content:center;margin-bottom:.6rem}
.brand-logo img{max-height:56px;max-width:150px;width:auto;object-fit:contain}
.brand-name{font-weight:600;color:var(--slate);font-size:.95rem;display:none}
.brand-name.show{display:block}              /* shown only if the logo fails to load */
.brand-card .brand-turn{font-size:.78rem;color:var(--green-ink);margin-top:.35rem}

/* ===== AFTERCARE PRODUCTS ===== */
.product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,200px));gap:18px;margin-top:1.4rem;justify-content:center;max-width:900px;margin-left:auto;margin-right:auto}
.product-grid.kits{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));max-width:820px;margin-left:auto;margin-right:auto}
.product-card{display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;
  background:#fff;border:1px solid #ece7d8;border-radius:16px;padding:20px 16px;transition:.18s ease}
a.product-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(51,60,69,.1);border-color:var(--sage)}
.product-img{height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:.7rem}
.product-img img{max-height:120px;width:auto;object-fit:contain}
.product-name{font-weight:600;color:var(--slate);font-size:1rem}
.product-for{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--green-ink);margin-top:.2rem}
.product-card.kit .product-for{text-transform:none;letter-spacing:0;color:var(--gray);font-size:.82rem;margin-top:.4rem;line-height:1.45}
.product-price{margin-top:.5rem;font-family:Arial,sans-serif;font-weight:700;color:var(--slate);font-variant-numeric:tabular-nums}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px}
.blog-card{display:flex;flex-direction:column;background:#fff;border:1px solid #ece7d8;border-radius:18px;
  overflow:hidden;text-decoration:none;transition:.18s ease}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(51,60,69,.12);border-color:var(--sage)}
.blog-thumb{display:block;aspect-ratio:16/10;overflow:hidden;background:#f0eee6}
.blog-thumb img{width:100%;height:100%;object-fit:cover}
.blog-card .blog-meta{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--green-ink);padding:18px 22px 0}
.blog-card h3{font-size:1.4rem;margin:.3em 0;padding:0 22px}
.blog-card p{font-size:.94rem;color:var(--gray);padding:0 22px;margin:0 0 1em;flex:1}
.blog-more{padding:0 22px 20px;color:var(--steel);font-weight:600;font-size:.9rem}

/* ===== ARTICLE ===== */
.article{padding:80px 0 0}
.article-title{font-size:2.8rem;line-height:1.1;margin:.2em 0 .1em}
.article-meta{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--green-ink);margin-bottom:1.4rem}
.article-hero{width:100%;border-radius:16px;margin-bottom:1.8rem;box-shadow:0 14px 40px rgba(51,60,69,.12)}
.article-body{font-size:1.08rem;line-height:1.75;color:var(--ink)}
.article-body h2{font-size:1.7rem;margin:1.6em 0 .4em}
.article-body p{margin:0 0 1.1em}
.article-body figure{margin:1.6rem 0}
.article-body figure img{width:100%;border-radius:14px}
.article-body figcaption{font-size:.84rem;color:var(--gray);text-align:center;margin-top:.5em;font-style:italic}
@media(max-width:560px){.article-title{font-size:2rem}}

/* ===== Sidebar nav — expandable Services / Team submenus ===== */
.c-side{overflow-y:auto}                       /* let the nav scroll if both groups open */
.c-nav-group{margin:0}
.c-nav-group > summary{list-style:none;cursor:pointer;color:var(--slate);text-transform:uppercase;
  letter-spacing:.1em;font-size:.82rem;font-weight:600;display:flex;align-items:baseline;gap:10px}
.c-nav-group > summary::-webkit-details-marker{display:none}
.c-nav-group > summary span{color:var(--sage-dk);font-size:.68rem}
.c-nav-group > summary::after{content:"+";margin-left:auto;color:var(--sage-dk);font-weight:700}
.c-nav-group[open] > summary::after{content:"–"}
.c-nav-group > summary:hover{color:var(--steel)}
.c-sub{display:flex;flex-direction:column;gap:9px;margin:11px 0 4px;padding-left:22px;border-left:1px solid #e2dece}
.c-sub a{color:var(--gray);font-size:.78rem;letter-spacing:.03em;text-transform:none;font-weight:500;display:block}
.c-sub a:hover{color:var(--sage-dk)}

/* Portfolio image download deterrent (casual only) */
.mq-item img, .pf-img img { -webkit-user-drag:none; user-drag:none; -webkit-touch-callout:none; user-select:none; }

/* Reusable callout box (content pack: scam warning, 'ask us', 'worried right now?', etc.) */
.notice{background:#fbfaf4;border:1px solid #e4e0cd;border-left:4px solid #c2bf8b;border-radius:8px;padding:1.1rem 1.4rem;margin:1.4rem 0}
.notice h3{margin:0 0 .45rem;color:#333c45}
.notice p{margin:0}

/* ===== All-in piercing pricing + jewelry ladder (June 2026 rollout) ===== */
.price-start{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--gray);font-weight:700}
.reversal-note{margin-top:1.6rem}
.editor-note{margin:0 0 1.2rem}
.editor-note em{font-style:normal;color:var(--green-ink)}

.jl-wrap{margin-top:2.4rem}
.jl-title{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;font-size:1.5rem;margin:0 0 .9rem}
.jl-rung{margin-bottom:1.6rem}
.jl-rung-head{display:flex;align-items:baseline;gap:.6rem;border-bottom:1px solid var(--sage);padding-bottom:.3rem;margin-bottom:.6rem}
.jl-rung-label{font-weight:700;color:var(--slate)}
.jl-rung-price{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--green-ink);font-weight:700}
.jl-caption{font-size:.88rem;color:var(--gray);margin:.1rem 0 .6rem}
.jl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.8rem}
.jl-card{display:flex;flex-direction:column;gap:.25rem;background:#fff;border:1px solid #e7e4d8;border-radius:12px;padding:.55rem;text-decoration:none;color:var(--ink);transition:box-shadow .15s}
.jl-card:hover{box-shadow:0 6px 18px rgba(51,60,69,.12)}
.jl-img{aspect-ratio:1;border-radius:8px;overflow:hidden;background:#faf8f3;display:flex;align-items:center;justify-content:center}
.jl-img img{width:100%;height:100%;object-fit:cover}
.jl-name{font-size:.82rem;font-weight:600;line-height:1.25}
.jl-brand{font-size:.72rem;color:var(--gray)}

/* line icons (replace emoji) + about proof strip (June 2026) */
.svc-icon svg{width:34px;height:34px;color:var(--green-ink)}
.proof-strip{font-weight:600;letter-spacing:.04em;color:var(--slate);font-size:1.02rem}

/* ── Piercing Finder + clustered tiers (28-piercing-finder spec, 2026-06-11) ── */
.pf{margin-top:1.2rem}
.pf-search{width:100%;box-sizing:border-box;padding:.85rem 1rem;font-size:1.05rem;border:1.5px solid #d8d8cf;border-radius:10px;background:#fff;color:#333c45}
.pf-search:focus{outline:none;border-color:#c2bf8b}
.pf-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.9rem 0}
.pf-chip{border:1.5px solid #d8d8cf;background:#fff;color:#333c45;border-radius:999px;padding:.4rem .9rem;font-size:.85rem;cursor:pointer}
.pf-chip.is-active{background:#333c45;color:#fff;border-color:#333c45}
.pf-chip--intimate{border-style:dashed}
.pf-notice{background:#f4f3ea;border:1px solid #e7e4d8;border-radius:8px;padding:.55rem .8rem;font-size:.85rem;color:#333c45;margin:.2rem 0 .9rem}
.pf-notice a{color:#333c45}
.pf-list{margin-top:.5rem;border:1px solid #e7e4d8;border-radius:12px;background:#fff;overflow:hidden}
.pf-row{display:flex;gap:.75rem;align-items:flex-start;padding:.7rem .95rem;border-bottom:1px solid #f2efe6}
.pf-row:last-child{border-bottom:0}
.pf-row[hidden]{display:none}
.pf-thumb{width:54px;height:54px;object-fit:cover;border-radius:8px;flex:none}
.pf-main{min-width:0;flex:1}
.pf-line{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem;margin:0}
.pf-name{font-size:1rem;font-weight:600;color:#333c45}
.pf-aliases{font-size:.78rem;color:#7c7c74;margin:.18rem 0 0;line-height:1.4}
.pf-alias-rest{display:none}
.pf-aliases.open .pf-alias-rest{display:inline}
.pf-morebtn{border:0;background:none;color:#333c45;font-size:.75rem;font-weight:700;cursor:pointer;padding:0;margin-left:.25rem;border-bottom:1px dashed #c2bf8b}
.pf-math summary{cursor:pointer}
.pf-browse{display:block;margin:1.1rem auto 0;border:1.5px solid #d8d8cf;background:#fff;color:#333c45;border-radius:999px;padding:.55rem 1.3rem;font-weight:600;font-size:.92rem;cursor:pointer}
.pf-browse:hover{border-color:#c2bf8b}
.pf-browse[hidden]{display:none}
.pf-area{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:#7c7c74}
.pf-chip-price{background:#c2bf8b;color:#333c45;border-radius:999px;padding:.12rem .55rem;font-size:.8rem;font-weight:700}
.pf-age{background:#bbd6e2;color:#333c45;border-radius:999px;padding:.12rem .5rem;font-size:.72rem;font-weight:600}
.pf-math,.pf-cnote{font-size:.78rem;color:#7c7c74;margin:.45rem 0 0;line-height:1.4}
.pf-notoffered{font-size:.78rem;color:#9a4b3f;font-weight:600;margin:.4rem 0 0}
.pf-empty{text-align:center;color:#7c7c74;margin:1rem 0}
.pf-escape{text-align:center;color:#7c7c74;font-size:.9rem;margin:1.4rem 0 0}
.pf-escape a{color:#333c45}
.intimate-page .intimate-list{max-width:380px;margin:1.6rem auto;background:#f4f3ea;border-radius:12px;padding:1rem 1.4rem}
.intimate-list-label{font-weight:700;color:#333c45;margin:0 0 .3rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
.intimate-list ul{columns:2;margin:0;padding-left:1.1rem}
.intimate-list li{font-size:.9rem;color:#333c45;margin:.15rem 0}
.intimate-brief,.intimate-vip{max-width:560px;margin:1rem auto}

/* text-only heroes (service pages): one column, no empty art band */
.hero-solo{min-height:auto}
.hero-solo .hero-inner{grid-template-columns:1fr;padding:46px 24px 40px}
