/* ============================================================
   LAGRETO — Services & product pages
   Components for the 3-product offer + How it works.
   Reuses global tokens, .reveal, .btn, .label from styles.css
   ============================================================ */

/* label with leading rule (matches section-head aesthetic) */
.label.rule { display:inline-flex; align-items:center; gap:12px; }
.label.rule::before { content:''; width:28px; height:1px; background:currentColor; display:inline-block; }
.narrow { max-width: 920px; margin-left:auto; margin-right:auto; }
.center { text-align:center; }
.stack > * + * { margin-top: clamp(40px,5vw,72px); }

/* ── SERVICES INDEX — product cards ─────────────────────── */
.svc-hero { padding-top: clamp(140px,16vh,210px); padding-bottom: clamp(36px,5vw,64px); text-align:center; }
.svc-hero .lead { max-width: 60ch; margin: 26px auto 0; }
.svc-pill { display:inline-flex; align-items:center; gap:8px; background:var(--surface); border:1px solid var(--line-strong); border-radius:100px; padding:8px 16px; font-size:13px; color:var(--ink-soft); margin-bottom:26px; }
.svc-pill b { color:var(--accent); }

.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media(max-width:900px){ .svc-grid { grid-template-columns:1fr; max-width:480px; margin:0 auto; } }
.svc-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; display:flex; flex-direction:column; text-decoration:none; color:inherit; transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease); }
.svc-card:hover { transform:translateY(-6px); box-shadow:0 36px 70px -38px rgba(27,23,38,.32); border-color:var(--line-strong); }
.svc-card.featured { border:2px solid var(--accent); }
.svc-thumb { position:relative; height:210px; overflow:hidden; }
.svc-thumb img { width:100%; height:100%; object-fit:cover; object-position:center 18%; transition:transform .6s var(--ease); }
.svc-card:hover .svc-thumb img { transform:scale(1.05); }
.svc-thumb::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg,rgba(27,23,38,0) 40%,rgba(27,23,38,.34) 100%); }
.svc-tag { position:absolute; top:14px; left:14px; z-index:2; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; background:rgba(255,255,255,.92); color:var(--accent-deep); padding:5px 11px; border-radius:100px; }
.svc-tag.dark { background:var(--ink); color:#fff; }
.svc-body { padding:28px 26px 30px; display:flex; flex-direction:column; flex:1; }
.svc-body .q { font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; color:var(--accent); margin-bottom:10px; }
.svc-body h3 { font-family:var(--display); font-size:28px; font-weight:500; letter-spacing:-.01em; margin-bottom:8px; }
.svc-body p { font-size:15px; color:var(--ink-soft); margin-bottom:18px; flex:1; }
.svc-mini { list-style:none; margin:0 0 22px; }
.svc-mini li { font-size:13.5px; color:var(--muted); padding:5px 0 5px 22px; position:relative; }
.svc-mini li::before { content:'✓'; position:absolute; left:0; color:var(--accent); font-weight:600; }
.svc-foot { display:flex; align-items:center; justify-content:space-between; }

/* ── PRODUCT PAGE ───────────────────────────────────────── */
.p-hero { display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; padding-top:clamp(120px,15vh,180px); }
@media(max-width:860px){ .p-hero { grid-template-columns:1fr; padding-top:clamp(110px,16vh,150px); } }
.p-hero h1 { margin-bottom:20px; }
.p-hero .lead { margin-bottom:30px; }
.p-hero-actions { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.p-hero-img { position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/5; box-shadow:0 50px 90px -50px rgba(27,23,38,.5); }
.p-hero-img img { width:100%; height:100%; object-fit:cover; }
.p-hero-badge { position:absolute; bottom:18px; left:18px; right:18px; background:rgba(255,255,255,.94); backdrop-filter:blur(8px); border-radius:14px; padding:16px 18px; display:flex; align-items:center; gap:14px; }
.p-hero-badge .n { font-family:var(--display); font-size:34px; line-height:1; color:var(--accent); }
.p-hero-badge .t { font-size:13px; color:var(--ink-soft); line-height:1.4; }

.back-link { display:inline-flex; align-items:center; gap:8px; font-size:14px; color:var(--muted); font-family:var(--mono); text-decoration:none; }
.back-link:hover { color:var(--accent); }
.back-link svg { transition:transform .2s var(--ease); }
.back-link:hover svg { transform:translateX(-3px); }

/* problem strip */
.problem { background:var(--ink); color:#fff; border-radius:var(--radius-lg); padding:clamp(36px,5vw,64px); }
.problem .label { color:var(--accent-2); }
.problem .label.rule::before { background:var(--accent-2); }
.problem h2 { font-family:var(--display); font-weight:400; font-size:clamp(26px,3.4vw,46px); line-height:1.1; letter-spacing:-.02em; margin:20px 0 16px; max-width:20ch; }
.problem p { color:rgba(255,255,255,.74); max-width:62ch; font-size:18px; }
.problem p + p { margin-top:16px; }

/* framing */
.framing { text-align:center; }
.framing h2 { margin:18px auto 18px; max-width:24ch; }
.framing p { max-width:60ch; margin:0 auto; color:var(--ink-soft); font-size:19px; }
.framing .hl { color:var(--accent); font-weight:500; }

/* deep items — alternating image / copy */
.deep-head { margin-bottom:clamp(36px,4vw,56px); }
.deep-head h2 { margin:16px 0 14px; max-width:24ch; }
.deep-head p { color:var(--muted); max-width:56ch; }
.deep-item { display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; padding:clamp(48px,6vw,80px) 0; border-top:1px solid var(--line); }
.deep-item:last-child { border-bottom:1px solid var(--line); }
.deep-item:nth-child(even) .deep-visual { order:-1; }
@media(max-width:860px){ .deep-item { grid-template-columns:1fr; gap:24px; } .deep-item:nth-child(even) .deep-visual { order:0; } }
.deep-visual { border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/3; box-shadow:0 24px 48px -24px rgba(27,23,38,.28); }
.deep-visual img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.deep-item:hover .deep-visual img { transform:scale(1.03); }
.deep-num { font-family:var(--display); font-size:clamp(48px,6vw,80px); font-weight:300; color:var(--accent-2); line-height:.8; margin-bottom:16px; }
.deep-pain-tag { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); display:block; margin-bottom:12px; }
.deep-pain { font-family:var(--display); font-style:italic; font-size:clamp(21px,2.4vw,30px); font-weight:400; line-height:1.22; letter-spacing:-.01em; color:var(--ink); margin-bottom:22px; max-width:26ch; }
.deep-pain::before { content:'“'; color:var(--accent-2); } .deep-pain::after { content:'”'; color:var(--accent-2); }
.deep-fix-label { font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); display:inline-block; margin-bottom:8px; }
.deep-name { font-family:var(--display); font-size:clamp(20px,2.2vw,26px); font-weight:500; letter-spacing:-.01em; margin-bottom:12px; }
.deep-do { color:var(--ink-soft); margin-bottom:18px; max-width:62ch; }
.deep-result { display:flex; gap:12px; align-items:flex-start; background:var(--accent-soft); border-radius:12px; padding:14px 18px; max-width:62ch; }
.deep-result .ico { flex-shrink:0; width:22px; height:22px; border-radius:50%; background:var(--accent); color:#fff; display:grid; place-items:center; font-size:12px; margin-top:2px; }
.deep-result .txt { font-size:15px; } .deep-result .txt b { color:var(--accent-deep); }

/* breather */
.breather { border-radius:var(--radius-lg); overflow:hidden; position:relative; aspect-ratio:21/9; box-shadow:0 40px 80px -50px rgba(27,23,38,.4); }
.breather img { width:100%; height:100%; object-fit:cover; }
.breather .cap { position:absolute; bottom:0; left:0; right:0; padding:40px clamp(24px,4vw,56px) 28px; background:linear-gradient(0deg,rgba(27,23,38,.8),transparent); color:#fff; font-family:var(--display); font-size:clamp(20px,2.4vw,30px); font-style:italic; }

/* synthesis */
.synth { background:var(--grad-soft); border-radius:var(--radius-lg); padding:clamp(36px,5vw,68px); }
.synth h2 { margin:18px 0 28px; max-width:24ch; }
.synth-chain { display:flex; flex-wrap:wrap; align-items:center; gap:10px 14px; margin-bottom:28px; }
.synth-chip { background:var(--surface); border:1px solid var(--line-strong); border-radius:100px; padding:9px 18px; font-size:14px; font-weight:500; }
.synth-plus { color:var(--accent); font-size:18px; font-weight:600; }
.synth-eq { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.synth-eq .arrow { color:var(--accent); font-size:24px; }
.synth-eq .big { font-family:var(--display); font-size:clamp(22px,2.6vw,34px); font-weight:500; letter-spacing:-.01em; }
.synth p { color:var(--ink-soft); max-width:64ch; margin-top:20px; }

/* included grid */
.incl { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(32px,4vw,56px); }
.incl h2 { margin-bottom:8px; } .incl .sub { color:var(--muted); margin-bottom:34px; }
.incl-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0 48px; }
@media(max-width:720px){ .incl-grid { grid-template-columns:1fr; } }
.incl-item { display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-top:1px solid var(--line); }
.incl-item .tick { flex-shrink:0; width:22px; height:22px; border-radius:50%; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; font-size:11px; margin-top:3px; }
.incl-item .it-t { font-weight:550; font-size:15.5px; } .incl-item .it-d { font-size:13.5px; color:var(--muted); }

/* acquisition band */
.acq { background:var(--ink); color:#fff; border-radius:var(--radius-lg); padding:clamp(36px,5vw,64px); text-align:center; }
.acq .label { color:var(--accent-2); } .acq .label.rule::before { background:var(--accent-2); }
.acq h2 { max-width:26ch; margin:18px auto 18px; color:#fff; }
.acq p { max-width:60ch; margin:0 auto; color:rgba(255,255,255,.75); font-size:18px; }

/* proof */
.proof-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:24px; }
@media(max-width:820px){ .proof-grid { grid-template-columns:1fr; } }
.proof-quote { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(28px,3.5vw,44px); display:flex; flex-direction:column; justify-content:center; }
.proof-quote .stars { color:var(--accent-2); font-size:18px; letter-spacing:3px; margin-bottom:18px; }
.proof-quote blockquote { font-family:var(--display); font-size:clamp(20px,2.2vw,28px); font-weight:400; line-height:1.32; letter-spacing:-.01em; }
.proof-img { border-radius:var(--radius); overflow:hidden; min-height:240px; }
.proof-img img { width:100%; height:100%; object-fit:cover; }

/* price block */
.price-block { background:var(--ink); color:#fff; border-radius:var(--radius-lg); padding:clamp(36px,5vw,68px); text-align:center; }
.price-block .label { color:var(--accent-2); } .price-block .label.rule::before { background:var(--accent-2); }
.price-block .price-big { font-family:var(--display); font-size:clamp(56px,9vw,104px); font-weight:400; letter-spacing:-.03em; line-height:1; margin:18px 0 6px; }
.price-block .one { font-family:var(--mono); font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:28px; }
.price-block .guarantees { display:flex; gap:24px; justify-content:center; flex-wrap:wrap; margin-bottom:32px; }
.price-block .guarantees span { font-size:13.5px; color:rgba(255,255,255,.8); display:inline-flex; align-items:center; gap:8px; }
.price-block .guarantees span::before { content:'✓'; color:var(--accent-2); }
.price-block .btn-grad { font-size:16px; padding:18px 38px; }
.val-stack { text-align:left; max-width:480px; margin:0 auto 30px; }
.val-cap { font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:14px; }
.val-row { display:flex; justify-content:space-between; gap:16px; padding:10px 0; border-bottom:1px dotted rgba(255,255,255,.16); font-size:14.5px; color:rgba(255,255,255,.84); }
.val-row .v { color:rgba(255,255,255,.5); font-variant-numeric:tabular-nums; white-space:nowrap; }
.val-total { display:flex; justify-content:space-between; gap:16px; padding:16px 0 0; font-size:15px; }
.val-total .vt-l { color:rgba(255,255,255,.7); }
.val-total .vt-n { color:#fff; text-decoration:line-through; text-decoration-color:var(--accent-2); text-decoration-thickness:2px; font-variant-numeric:tabular-nums; }
.cta-micro { font-size:12.5px; color:rgba(255,255,255,.6); margin-top:16px; font-family:var(--mono); letter-spacing:.03em; }

/* PS block */
.ps { background:var(--surface); border:1px solid var(--line); border-left:3px solid var(--accent); border-radius:var(--radius); padding:clamp(24px,3.4vw,40px); }
.ps .lbl { font-family:var(--mono); font-size:12px; letter-spacing:.1em; color:var(--accent); text-transform:uppercase; }
.ps p { margin-top:14px; font-size:clamp(18px,1.8vw,21px); line-height:1.5; color:var(--ink-soft); max-width:66ch; }
.ps p b { color:var(--ink); font-weight:550; }

/* faq */
.svc-faq .faq-item { border-top:1px solid var(--line); padding:22px 0; }
.svc-faq .faq-item summary { font-family:var(--display); font-size:20px; font-weight:500; cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:20px; align-items:center; }
.svc-faq .faq-item summary::-webkit-details-marker { display:none; }
.svc-faq .faq-item summary::after { content:'+'; color:var(--accent); font-size:24px; transition:transform .2s; }
.svc-faq .faq-item[open] summary::after { transform:rotate(45deg); }
.svc-faq .faq-item p { color:var(--ink-soft); margin-top:14px; max-width:72ch; }

/* process (how it works page) */
.process { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(36px,5vw,64px); }
.process h2 { margin:10px 0 10px; }
.process > .sub { color:var(--muted); font-size:15px; margin-bottom:36px; }
.process-steps { display:grid; grid-template-columns:repeat(5,1fr); gap:0; position:relative; margin-top:8px; }
.process-steps::before { content:''; position:absolute; top:27px; left:calc(10% + 8px); right:calc(10% + 8px); height:1px; background:var(--line-strong); z-index:0; }
@media(max-width:860px){ .process-steps { grid-template-columns:1fr 1fr; gap:28px 16px; } .process-steps::before { display:none; } }
@media(max-width:480px){ .process-steps { grid-template-columns:1fr; gap:24px; } }
.process-step { text-align:center; padding:0 8px; position:relative; z-index:1; }
.ps-num { width:56px; height:56px; border-radius:50%; background:var(--surface); border:2px solid var(--accent); color:var(--accent); font-family:var(--display); font-size:22px; display:grid; place-items:center; margin:0 auto 16px; }
.ps-title { font-family:var(--display); font-size:17px; font-weight:500; margin-bottom:8px; letter-spacing:-.01em; }
.ps-desc { font-size:13px; color:var(--muted); line-height:1.5; }
.process-note { margin-top:28px; text-align:center; font-size:12.5px; color:var(--accent); font-family:var(--mono); letter-spacing:.06em; display:flex; align-items:center; justify-content:center; gap:10px; }
.process-note::before, .process-note::after { content:''; width:20px; height:1px; background:var(--accent); }

/* process teaser (on product pages) */
.process-teaser { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px 28px; text-decoration:none; transition:.25s var(--ease); }
.process-teaser:hover { border-color:var(--accent); transform:translateY(-2px); box-shadow:0 20px 40px -24px rgba(108,59,170,.4); }
.process-teaser .pt-text { font-size:16px; color:var(--ink-soft); } .process-teaser .pt-text b { color:var(--ink); font-weight:600; }
.process-teaser .pt-link { display:inline-flex; align-items:center; gap:8px; font-weight:500; color:var(--accent); font-size:15px; white-space:nowrap; }
.process-teaser .pt-link svg { transition:transform .25s var(--ease); }
.process-teaser:hover .pt-link svg { transform:translate(3px,-3px); }

/* delivery-by-product grid */
.dl-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media(max-width:760px){ .dl-grid { grid-template-columns:1fr; } }
.dl-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px 28px; text-align:center; }
.dl-card.feat { border:2px solid var(--accent); }
.dl-card .dl-name { font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; }
.dl-card .dl-num { font-family:var(--display); font-size:clamp(52px,7vw,76px); line-height:.9; color:var(--ink); }
.dl-card .dl-unit { font-size:14px; color:var(--muted); margin-top:10px; }
