/* Reusable cards, buttons, forms, sliders, cookie controls and UI components. */

/* ---------- Cards / products ---------- */
.grid{display:grid;gap:26px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

.pcard{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--white);border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pcard .img{position:relative;overflow:hidden;aspect-ratio:4/3}
.pcard .img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.pcard:hover .img img{transform:scale(1.06)}
.pcard .img::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(14,37,64,.55),transparent 55%);z-index:1}
.pcard .cat{position:absolute;top:14px;left:14px;z-index:2;background:rgba(255,255,255,.92);color:var(--navy);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;border-radius:2px}
.pcard .body{padding:24px 24px 26px}
.pcard h3{margin-bottom:8px}
.pcard p{font-size:.94rem;color:var(--ink);margin-bottom:16px}

/* feature list */
.flist{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.flist li{display:flex;gap:12px;align-items:flex-start;font-size:.96rem}
.flist li::before{content:"";flex:0 0 18px;height:18px;margin-top:3px;border-radius:50%;background:var(--gold);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/13px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/13px no-repeat;}

/* ---------- Before / After ---------- */
.ba{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);user-select:none;aspect-ratio:16/10;background:var(--grey)}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba .after{clip-path:inset(0 0 0 var(--pos,50%))}
.ba .handle{position:absolute;top:0;bottom:0;left:var(--pos,50%);width:2px;background:var(--gold);z-index:3;transform:translateX(-1px)}
.ba .handle::after{content:"⇆";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;background:var(--white);color:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);font-size:1.1rem}
.ba input[type=range]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:4;margin:0}
.ba .badge{position:absolute;top:14px;z-index:2;font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:6px 11px;border-radius:2px;background:rgba(14,37,64,.8);color:#fff}
.ba .badge.b{left:14px}
.ba .badge.a{right:14px;background:var(--gold);color:var(--navy)}

.slider-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:34px}
.slider-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.slider-card .ba{border-radius:0;box-shadow:none;aspect-ratio:16/11}
.slider-card-body{padding:20px 22px 22px}
.slider-card-body h3{font-size:1.28rem;margin-bottom:6px}
.slider-card-body p{font-size:.94rem;color:var(--ink);margin:0}

/* ---------- Areas ---------- */
.areas-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.area-chip{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px 16px;text-align:center;font-weight:600;font-size:.95rem;transition:.4s var(--ease);position:relative}
.area-chip span{display:block;font-size:.74rem;color:var(--ink);font-weight:500;margin-top:3px}
.area-chip:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:var(--shadow-sm)}

/* ---------- Why choose / steps ---------- */
.steps{counter-reset:s}
.step{display:flex;gap:24px;padding:30px 0;border-top:1px solid var(--line)}
.step:last-child{border-bottom:1px solid var(--line)}
.step .n{counter-increment:s;font-family:'Cormorant Garamond',serif;font-size:2.2rem;color:var(--gold);line-height:1;flex:0 0 60px}
.step .n::before{content:"0" counter(s)}
.step h3{margin-bottom:8px}
.step p{margin:0;color:var(--ink)}

.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.why-cell{background:var(--white);padding:34px 30px}
.why-cell .ic{width:46px;height:46px;border-radius:50%;background:var(--grey);display:flex;align-items:center;justify-content:center;color:var(--gold-deep);margin-bottom:18px}
.why-cell h3{font-size:1.25rem;margin-bottom:10px}
.why-cell p{margin:0;font-size:.95rem;color:var(--ink)}

/* ---------- Reviews ---------- */
.rev-head{display:flex;align-items:center;gap:16px;margin-bottom:34px;flex-wrap:wrap}
.rev-score{font-family:'Cormorant Garamond',serif;font-size:3rem;color:var(--navy);line-height:1}
.stars{color:var(--gold);font-size:1.1rem;letter-spacing:2px}
.rcard{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);height:100%}
.rcard .stars{margin-bottom:14px}
.rcard p{font-size:1rem;color:var(--navy);font-style:italic;margin-bottom:18px}
.rcard .who{display:flex;align-items:center;gap:12px}
.rcard .av{width:42px;height:42px;border-radius:50%;background:var(--navy);color:var(--gold);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Cormorant Garamond',serif}
.rcard .who b{display:block;font-size:.92rem}
.rcard .who span{font-size:.8rem;color:var(--ink)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--navy);color:#fff;border-radius:var(--radius);padding:clamp(40px,6vw,72px);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:18px;border:1px solid rgba(198,169,105,.35);border-radius:3px;pointer-events:none}
.cta-band h2{color:#fff;margin-bottom:14px}
.cta-band p{color:#c2cfdf;max-width:54ch;margin:0 auto 26px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Form ---------- */
.form-wrap{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.02em;margin-bottom:7px;color:var(--navy)}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:var(--radius);font:inherit;font-size:.95rem;color:var(--navy);background:var(--white);transition:border-color .3s var(--ease),box-shadow .3s var(--ease)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(198,169,105,.18)}
.field textarea{resize:vertical;min-height:120px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:22px 40px 22px 0;position:relative;font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--navy)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:'Inter';font-size:1.4rem;color:var(--gold);transition:transform .3s var(--ease)}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--ink);padding:0 40px 22px 0;margin:0}

/* ---------- Cookie consent ---------- */
.cookie-banner{
  position:fixed;left:18px;right:18px;bottom:18px;z-index:1000;display:grid;
  grid-template-columns:1fr auto;gap:22px;align-items:center;max-width:1180px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:22px;color:var(--navy)
}
.cookie-banner h2{font-family:'Inter',sans-serif;font-size:1rem;margin:0 0 6px}
.cookie-banner p{margin:0;color:var(--ink);font-size:.92rem;max-width:68ch}
.cookie-actions,.cookie-modal-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn-plain{background:transparent;border:1px solid transparent;color:var(--gold-deep);padding:12px 16px}
.btn-plain:hover{background:var(--grey)}
.cookie-modal{position:fixed;inset:0;z-index:1001;background:rgba(14,37,64,.62);display:flex;align-items:center;justify-content:center;padding:20px}
.cookie-modal-card{width:min(560px,100%);background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;position:relative;color:var(--navy)}
.cookie-modal-card h2{font-family:'Inter',sans-serif;font-size:1.25rem;margin:0 0 10px}
.cookie-modal-card p{color:var(--ink);font-size:.94rem;margin:0 0 18px}
.cookie-close{position:absolute;top:14px;right:14px;border:0;background:var(--grey);color:var(--navy);width:34px;height:34px;border-radius:50%;cursor:pointer;font:inherit}
.cookie-toggle{display:flex;justify-content:space-between;gap:20px;align-items:center;border-top:1px solid var(--line);padding:16px 0}
.cookie-toggle:last-of-type{border-bottom:1px solid var(--line)}
.cookie-toggle span{display:flex;flex-direction:column;gap:3px}
.cookie-toggle small{color:var(--ink);font-size:.82rem}
.cookie-toggle input{width:22px;height:22px;flex:0 0 auto}
.cookie-modal-actions{justify-content:flex-end;margin-top:20px}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* tags */
.tagrow{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.tag{background:var(--grey);border:1px solid var(--line);color:var(--navy);font-size:.78rem;font-weight:600;padding:7px 14px;border-radius:40px}

/* spec table */
.spec{width:100%;border-collapse:collapse;font-size:.95rem}
.spec th,.spec td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line)}
.spec th{width:42%;color:var(--navy);font-weight:600;background:var(--grey)}
.spec td{color:var(--ink)}

/* tidy contact mini-card (home get-started) */
.contact-mini{margin-top:28px;display:flex;flex-direction:column;gap:2px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--white)}
.contact-mini-row{display:flex;align-items:center;gap:16px;padding:18px 22px;color:var(--navy);border-bottom:1px solid var(--line);transition:background .25s var(--ease)}
.contact-mini-row:last-child{border-bottom:0}
a.contact-mini-row:hover{background:var(--grey)}
.contact-mini-row svg{flex:0 0 20px;color:var(--gold-deep)}
.contact-mini-row span{display:flex;flex-direction:column;line-height:1.3}
.contact-mini-row b{font-size:1rem;font-weight:600}
.contact-mini-row small{font-size:.8rem;color:var(--ink)}

/* placeholder image fallback (decorative SVGs) */
img.ph{background:linear-gradient(135deg,#0E2540,#1B3A5F);color:transparent}
