/*
Theme Name: Topolis Out Theme
Author: Topolis AB
Description: Custom luxury theme for Topolis hot tubs, saunas and timber houses
Version: 4.1.0
Text Domain: topolis-simple
*/

/* ── Base reset & root ── */
*,*::before,*::after{box-sizing:border-box}
:root{--max:1200px;--text:#171717;--muted:#636363;--line:#e9e9e9;--soft:#f6f6f4;--green:#adddbd;--green-dark:#35582d;--dark:#151515;--radius:22px;--topolis-green:#adddbd;--topolis-dark:#151515;--topolis-text:#1d1d1b;--topolis-line:#e9e9e9;--topolis-radius:22px}
body{margin:0;font-family:'Urbanist',Arial,Helvetica,sans-serif;color:var(--topolis-text);background:#fff;line-height:1.55;letter-spacing:.01em}
a{color:inherit}
h1,h2,h3{font-family:'Frank Ruhl Libre',Georgia,serif}
img{max-width:100%;height:auto}

/* ── Layout ── */
.wrap{max-width:var(--max);margin:auto;padding:0 24px}
.content{padding:70px 24px;max-width:1120px;margin:auto}
.content-narrow{max-width:920px}
.section{padding:90px 0}
@media(max-width:640px){.section{padding:52px 0}}

/* ── Typography ── */
.eyebrow{font-size:13px;color:var(--muted);margin:0 0 24px}
.muted{color:var(--muted);font-size:14px;opacity:.72}
.green{color:#17733a;font-weight:600}
.stars{letter-spacing:3px;color:#00b67a}

/* ── Buttons ── */
.btn,.button,.wc-forward{display:inline-flex!important;align-items:center;justify-content:center;min-height:46px;background:#020202!important;color:#fff!important;border-radius:999px!important;padding:0 32px!important;text-decoration:none!important;border:0!important;font-weight:500;font-family:'Frank Ruhl Libre',Georgia,serif;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}
.btn:hover,.button:hover{background:#222!important;color:#fff!important}
.btn-small{min-height:36px;font-size:13px;padding:10px 16px!important}

/* ── Trust strip ── */
.trust-strip{background:var(--topolis-green);padding:18px 0;position:relative;z-index:2}
.trust-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;font-size:14px}
.trust-grid span{display:flex;align-items:center;gap:12px}
.trust-grid svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:none}
@media(max-width:900px){.trust-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.trust-grid{grid-template-columns:1fr}}

/* ── Hero ── */
.hero-design{min-height:760px;background:linear-gradient(90deg,rgba(255,255,255,.18),rgba(255,255,255,.05)),var(--hero-img);background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:0 0 58px}
.hero-card{width:min(560px,100%);border-radius:20px;background:rgba(255,255,255,.70);backdrop-filter:blur(20px);padding:24px 24px 26px;box-shadow:0 18px 45px rgba(0,0,0,.12)}
.hero-card h1{font-weight:400;font-size:clamp(44px,5vw,64px);line-height:1.08;margin:0 0 24px;text-align:center;letter-spacing:-.04em}
.hero-card p{margin:0 auto 22px;text-align:center;max-width:500px}
.hero-cta{text-align:center}
.rating{font-size:14px;text-align:center;margin-bottom:22px}
.star{color:#00b67a}
.check-grid{border:1px solid #fff;border-radius:10px;padding:18px 20px;display:grid;grid-template-columns:1fr 1fr;gap:18px 28px;margin-bottom:22px}
.check{display:flex;align-items:center;gap:12px}
.check svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;flex:none}
@media(max-width:900px){.hero-design{min-height:auto;padding:110px 0 34px}.check-grid{grid-template-columns:1fr}}
@media(max-width:520px){.hero-card h1{font-size:42px}.hero-card{padding:20px}}

/* ── Page hero (ACF builder) ── */
.topolis-page .nt-page-hero{min-height:760px;background-image:linear-gradient(90deg,rgba(255,255,255,.06),rgba(255,255,255,0)),var(--hero-bg);background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:0 0 56px}
.nt-page-hero__inner{width:100%}
.nt-page-hero__copy{width:min(560px,100%);max-width:560px;border-radius:18px;background:rgba(255,255,255,.72);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);padding:24px 24px 28px;box-shadow:0 20px 55px rgba(0,0,0,.16);text-align:center}
.nt-page-hero h1{font-size:clamp(44px,5.3vw,66px);font-weight:400;line-height:1.06;margin:0 0 24px;color:#1d1d1b}
.nt-page-hero p{font-size:16px;line-height:1.55;margin:0 auto 22px;max-width:500px}
.hero-points{border:1px solid rgba(255,255,255,.95);border-radius:10px;padding:20px;display:grid;grid-template-columns:1fr 1fr;gap:18px 30px;text-align:left;margin:0 0 24px}
.hero-points span{display:flex;align-items:center;gap:8px;font-size:15px}
.hero-points svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8}
@media(max-width:900px){.topolis-page .nt-page-hero{min-height:auto;padding:100px 0 35px}.hero-points{grid-template-columns:1fr}}
@media(max-width:640px){.nt-page-hero__copy{padding:20px}.nt-page-hero h1{font-size:40px}}

/* ── NT Builder sections ── */
.nt-included-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:48px;align-items:center}
.nt-included-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:24px}
.nt-included-list span{display:flex;align-items:center;gap:8px}
.nt-text-image .nt-two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.nt-text-image.is-reverse .nt-copy{order:2}
.nt-text-image.is-beige .nt-copy{background:#f7f1e8;border-radius:30px;padding:48px}
.nt-text-image.is-green .nt-copy{background:var(--topolis-green);color:#020202;border-radius:30px;padding:48px}
.nt-image img{width:100%;border-radius:20px;display:block;object-fit:cover}
.nt-copy{max-width:620px}
.nt-copy p{font-size:17px}
.nt-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;margin-top:28px}
.nt-card{background:#fff;border:1px solid var(--topolis-line);border-radius:20px;padding:28px}
.nt-card h3{font-family:'Urbanist',Arial,sans-serif;font-size:22px;font-weight:500;margin:0 0 10px}
.nt-card p{margin:0;color:#555}
.nt-card-icon{width:44px;height:44px;border-radius:999px;background:var(--topolis-green);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.nt-card-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8}
.nt-gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.nt-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:18px}
.nt-cta{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;align-items:center;background:#f6f6f4;color:#020202;border-radius:30px;padding:42px}
.nt-form-box{background:#fff;color:#111;border-radius:20px;padding:28px;border:1px solid var(--topolis-line)}
.nt-form-box input,.nt-form-box textarea,.nt-form-box select{width:100%;border:1px solid #ddd;border-radius:12px;padding:13px 14px;margin-bottom:12px;font-family:'Urbanist',Arial,sans-serif}
.nt-faq details{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;margin:12px 0;padding:18px 22px}
.nt-faq summary{cursor:pointer;font-weight:700}
.nt-seo-content:empty{display:none}
.nt-seo-content{padding-top:20px}
@media(max-width:980px){.nt-included-grid,.nt-text-image .nt-two-col,.nt-cta{grid-template-columns:1fr}.nt-text-image.is-reverse .nt-copy{order:0}.nt-cards,.nt-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.nt-cards,.nt-gallery,.nt-included-list{grid-template-columns:1fr}.nt-text-image.is-beige .nt-copy,.nt-text-image.is-green .nt-copy,.nt-cta{padding:26px}}

/* ── Product grid ── */
.topolis-product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(245px,1fr));gap:38px}
.topolis-product-card{display:block;text-decoration:none;color:inherit}
.topolis-product-card__image{height:280px;display:flex;align-items:center;justify-content:center;background:#fff}
.topolis-product-card__image img{max-width:100%;max-height:100%;width:100%;height:100%;object-fit:contain}
.topolis-product-card__body{padding:18px 0 0}
.topolis-product-card h3{font-family:'Urbanist',Arial,sans-serif;font-weight:400;font-size:18px;margin:0 0 4px}
.topolis-price,.topolis-price .amount{font-family:'Frank Ruhl Libre',Georgia,serif;font-size:34px;font-weight:400;color:#171717}

/* ── WooCommerce shop ── */
.woocommerce ul.products{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:34px;padding:0!important;margin:30px 0!important}
.woocommerce ul.products li.product{list-style:none!important;border:0!important;border-radius:20px;padding:18px!important;background:#fff}
.woocommerce ul.products li.product img{height:250px!important;object-fit:contain;background:#fff;border-radius:16px}
.woocommerce-loop-product__title{font-size:18px!important;font-weight:400}
.price{font-weight:400;color:#111!important}

/* ── Footer ── */
.site-footer{background:#111;color:#fff;padding:64px 0 0;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1.3fr 1fr 1fr;gap:40px;padding-bottom:44px}
.footer-brand p{max-width:340px;color:#d6d6d6}
.footer-logo{display:inline-block;margin-bottom:18px}
.footer-logo img{width:170px;height:auto;display:block}
.site-footer h3{font-family:'Urbanist',Arial,sans-serif;font-weight:600;font-size:15px;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin:6px 0 18px}
.site-footer h2{font-family:'Urbanist',Arial,sans-serif;font-weight:600}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.footer-links--two-col{grid-template-columns:1fr 1fr;column-gap:22px}
.footer-links a{color:#c9c9c9;text-decoration:none;font-size:15px;transition:color .15s}
.footer-links a:hover{color:var(--topolis-green)}
.footer-socials{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.footer-socials a{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.28);border-radius:999px;color:#e6e6e6;transition:all .15s}
.footer-socials a:hover{background:var(--topolis-green);border-color:var(--topolis-green);color:#111}
.footer-socials svg{width:18px;height:18px;fill:currentColor}
.footer-cta{display:inline-flex;align-items:center;min-height:40px;margin-top:14px;padding:0 22px;border:1px solid rgba(255,255,255,.35);border-radius:999px;color:#fff;text-decoration:none;font-size:14px;letter-spacing:.06em;text-transform:uppercase;transition:all .15s}
.footer-cta:hover{background:var(--topolis-green);border-color:var(--topolis-green);color:#111}
.footer-small{border-top:1px solid rgba(255,255,255,.12);padding:20px 24px;color:#aaa;font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer-legal a{color:#aaa;text-decoration:none}
.footer-legal a:hover{color:#fff}
.site-footer a{color:#ccc;text-decoration:none}
.site-footer a:hover{color:#fff}
@media(max-width:980px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr;gap:32px}.footer-links--two-col{grid-template-columns:1fr 1fr}}

/* ── Chat widgets ── */
.chat-pill{position:fixed;right:92px;bottom:34px;z-index:60;background:#fff;border-radius:12px;padding:13px 18px;box-shadow:0 2px 15px rgba(0,0,0,.18);text-decoration:none;color:#111}
.chat-dot{position:fixed;right:34px;bottom:30px;z-index:61;width:52px;height:52px;border:0;border-radius:999px;background:var(--green-dark);color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer}
@media(max-width:900px){.chat-pill{display:none}}

/* ── Misc ── */
.split-large{display:grid;grid-template-columns:42% 58%;gap:54px;align-items:start}
.included-list{display:grid;grid-template-columns:1fr 1fr;gap:22px 44px;margin:28px 0}
.product-focus{display:grid;grid-template-columns:1fr 1fr;gap:46px}
.feature-block{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}
.soft-box{background:var(--green);border-radius:24px;padding:42px}
.image-round img,.content img{max-width:100%;height:auto;border-radius:18px}
.delivery-note{display:flex;gap:10px;align-items:center;margin:12px 0;padding:12px 14px;background:#f7f1e8;border-radius:12px}
.delivery-note svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8}
.topolis-gallery{columns:3 260px;column-gap:18px}
.topolis-gallery img{width:100%;margin:0 0 18px;border-radius:10px}
@media(max-width:900px){.split-large,.product-focus,.feature-block{grid-template-columns:1fr}}
