@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --bg:#f8f6f2;
  --paper:#ffffff;
  --ink:#141414;
  --muted:#4d4d4d;
  --line:#e8e2d9;
  --accent:#b99b73;
  --accent-soft:#f3ece2;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,Arial,sans-serif;overflow-x:hidden}
.container{width:min(1160px,calc(100% - 48px));margin:auto}
h1,h2,h3{font-family:'Cormorant Garamond',serif;line-height:1.08;letter-spacing:.01em;margin:0 0 12px;color:var(--ink)}
h2{text-align:center;font-size:clamp(2rem,4vw,3rem)}
p{line-height:1.75;color:var(--muted);margin:0 0 12px}
img{max-width:100%;height:auto;display:block}

.topbar{position:sticky;top:0;background:rgba(248,246,242,.94);border-bottom:1px solid var(--line);backdrop-filter:blur(10px);z-index:40}
.nav{height:74px;display:flex;justify-content:space-between;align-items:center;gap:18px}
.logo{font-family:'Cormorant Garamond',serif;font-size:2rem;letter-spacing:.03em}
.logo img{max-height:42px;width:auto;object-fit:contain}
nav{display:flex;gap:20px;align-items:center}
.nav-toggle{display:none;border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 10px;font-size:1rem;line-height:1;cursor:pointer}
nav a{color:var(--ink);text-decoration:none;font-size:.74rem;letter-spacing:.09em;text-transform:uppercase}
.nav-cta{border:1px solid var(--accent);padding:10px 16px;border-radius:999px;background:var(--accent-soft)}

.hero{padding:84px 0 78px;border-bottom:1px solid var(--line);position:relative;background:linear-gradient(180deg,#fbfaf8 0%,#f8f6f2 100%)}
.has-bg-photo{background-size:cover;background-position:center}
.hero.has-bg-photo,.final-cta.has-bg-photo,.offer.has-bg-photo{background-size:cover;background-position:center}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1fr .84fr;gap:44px;align-items:start}
.eyebrow{letter-spacing:.16em;text-transform:uppercase;color:#82674a;font-size:.72rem;font-weight:600;margin-bottom:10px}
.hero-tagline{font-size:.88rem;color:#272727;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
h1{font-size:clamp(2.6rem,5vw,4.5rem);max-width:760px}
.hero-sub{max-width:640px;font-size:1.03rem}
.badges{display:flex;flex-wrap:wrap;gap:11px;margin:16px 0}
.trust-badge{
  display:inline-flex;
  align-items:center;
  padding:8px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid #e5e0d8;
  font-size:13px;
  color:#111;
}
.trust-badge strong{
  font-weight:700;
  color:var(--accent);
  margin:0 4px;
}
.trust-badge a{color:inherit;text-decoration:underline;text-underline-offset:2px}
.trust-badge a:hover,.trust-badge a:focus-visible{text-decoration-thickness:2px}
.rating{margin-top:2px}

.form-card{background:#fff;padding:28px;border:1px solid #ddd4c8;border-radius:16px;box-shadow:0 16px 35px rgba(29,22,16,.07)}
.form-card h2{font-size:2.1rem;text-align:left}
.form-card p{font-size:.95rem}
.form-card label{display:block;margin:11px 0 6px;font-size:.72rem;font-weight:600;color:#37312b;text-transform:uppercase;letter-spacing:.1em}
.form-card input,.form-card textarea{width:100%;padding:12px;border:1px solid #ddd4c8;background:#fff;border-radius:8px;font-family:inherit}
.form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(185,155,115,.18)}
.form-card textarea{min-height:110px;resize:vertical}
.form-card button,.main-btn{width:100%;margin-top:14px;padding:13px;background:#111;color:#fff;border:1px solid #111;cursor:pointer;text-decoration:none;display:inline-block;text-align:center;border-radius:8px;font-weight:600}
.form-card small{display:block;margin-top:11px;text-align:center;color:#69625b;font-size:.75rem}

section{padding:84px 0}
.trust,.portfolio,.faq{background:#fff}
.social,.compare,.value,.offer,.final-cta{border-top:1px solid var(--line);background:var(--bg)}
.social{--social-title-spacing:84px}

.trust-grid,.logo-grid,.testimonial-grid,.portfolio-grid{display:grid;gap:16px}
.trust-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:28px}
.trust-grid article{border:1px solid var(--line);padding:22px;background:#fff;border-radius:14px}
.trust-grid h3{font-size:1.5rem}

.logo-grid{grid-template-columns:repeat(4,minmax(0,1fr));justify-items:center;margin:18px 0 34px}
.social-section-title{font-size:clamp(2rem,4vw,3rem);margin-top:var(--social-title-spacing)}
.social-section-title + .logo-grid,.social-section-title + .testimonial-slider{margin-top:18px}
.logo-grid figure{width:100%;min-height:106px;margin:0;padding:18px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}
.logo-grid img,.award-grid img,.supplier-grid img{max-width:100%;max-height:70px;width:100%;object-fit:contain;object-position:center}
.logo-grid figcaption{margin-top:7px;font-size:.8rem;color:#6b6b6b}

.testimonial-slider{position:relative}
.testimonial-slider-mobile{display:none}
.testimonial-track{overflow:hidden}
.testimonial-slide{display:none}
.testimonial-slide.is-active{display:block}
.testimonial-grid{grid-template-columns:repeat(3,minmax(0,360px));justify-content:center;margin-top:0}
.testimonial-dots{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:28px}
.testimonial-dot{width:11px;height:11px;padding:0;border:1px solid var(--accent);border-radius:999px;background:transparent;cursor:pointer}
.testimonial-dot.is-active{background:var(--accent)}
blockquote{margin:0;border:1px solid var(--line);padding:20px;background:#fff;border-radius:12px}
.testimonial-card{display:flex;flex-direction:column;align-items:center;gap:14px;min-height:100%;padding:20px;text-align:center;background:transparent;border:0}
.testimonial-card p{font-style:italic;margin:0;color:#2d2a26;line-height:1.7}
.testimonial-logo{width:160px;height:160px;max-width:100%;border-radius:999px;object-fit:cover;object-position:center;padding:0;border:1px solid var(--line);background:#fff;margin:0 auto 2px}
.testimonial-logo.img-placeholder{min-height:160px;display:grid;place-items:center;text-align:center}
.testimonial-company{margin-top:-8px;color:var(--muted);font-size:.88rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
cite{font-style:normal;color:#4e4e4e;font-size:.82rem;font-weight:600;line-height:1.5}
cite strong{display:block;color:#111;font-size:.95rem;margin-bottom:2px}
.testimonial-author-meta{display:block}

.portfolio-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:26px auto 0;padding:6px;border:1px solid #d8ccbc;border-radius:12px;width:max-content;max-width:100%;background:#fff}
.portfolio-tab{appearance:none;border:0;background:transparent;color:#111;padding:12px 22px;border-radius:8px;font:inherit;font-size:1rem;cursor:pointer;transition:background .18s ease,color .18s ease}
.portfolio-tab:hover,.portfolio-tab.is-active{background:var(--accent-soft);color:#8a6a42}
.portfolio-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:28px}
.portfolio-grid article{border:1px solid var(--line);background:#fff;border-radius:10px;overflow:hidden}
.portfolio-grid article.is-hidden,.portfolio-empty.is-hidden{display:none}
.portfolio-empty{text-align:center;margin:28px 0 0;color:var(--muted)}
.portfolio-grid img{width:100%;aspect-ratio:4 / 3;height:auto;object-fit:cover;object-position:center}
.portfolio-grid div{padding:14px 16px}
.portfolio-grid span{font-size:.72rem;color:#7d6f60;letter-spacing:.1em;text-transform:uppercase}
.portfolio-cta-wrap{margin-top:28px;display:flex;justify-content:center}
.portfolio-cta{max-width:330px}

.compare{position:relative;overflow:hidden}
.compare::before{content:'';position:absolute;inset:7% auto auto 50%;width:520px;height:520px;border-radius:999px;background:radial-gradient(circle,rgba(185,155,115,.17),rgba(185,155,115,0) 68%);transform:translateX(-50%);pointer-events:none}
.compare .container{position:relative;z-index:1}
.compare-heading{max-width:860px;margin:0 auto 34px;text-align:center}
.compare-heading .eyebrow{display:block;margin-bottom:12px}
.compare-heading p{max-width:720px;margin:0 auto;color:#61594f}
.compare-card{position:relative;overflow:hidden;border:1px solid #dccdb8;border-radius:30px;background:linear-gradient(180deg,#fff,#fbf8f3);box-shadow:0 28px 70px rgba(42,32,22,.11)}
.compare-card::before{content:'';position:absolute;inset:0 33.333% 0 33.333%;background:linear-gradient(180deg,rgba(47,111,78,.12),rgba(255,255,255,.4));border-left:1px solid rgba(47,111,78,.12);border-right:1px solid rgba(47,111,78,.12);pointer-events:none}
.compare-row{position:relative;display:grid;grid-template-columns:.54fr 1.08fr 1fr;min-height:70px;border-top:1px solid rgba(226,211,193,.82)}
.compare-row:first-child{border-top:0}
.compare-row:not(.compare-row-head):hover{background:rgba(255,255,255,.62)}
.compare-row-head{min-height:102px;background:linear-gradient(90deg,#fbf5ec,#fff 46%,#f7f1e9)}
.compare-cell{display:flex;align-items:center;gap:13px;padding:19px 24px;color:#39332d;line-height:1.45}
.compare-cell + .compare-cell{border-left:1px solid rgba(226,211,193,.82)}
.compare-cell-feature{justify-content:center;color:#8a765d;font-size:.76rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;text-align:center}
.compare-row:not(.compare-row-head) .compare-cell-feature span{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#f6eee2,#e8d8c2);color:#7c6040;font-size:.82rem;letter-spacing:0;box-shadow:inset 0 0 0 1px rgba(139,109,72,.08)}
.compare-cell-crown{background:rgba(255,255,255,.58);font-weight:700;color:#171717}
.compare-cell-others{color:#625d58;background:rgba(248,246,242,.66)}
.compare-row-head .compare-cell{align-items:flex-start;justify-content:center;flex-direction:column;gap:9px}
.compare-row-head .compare-cell-feature{align-items:center;justify-content:center}
.compare-row-head strong{font-family:'Cormorant Garamond',serif;font-size:1.62rem;line-height:1.05;color:#141414}
.compare-row-head .compare-cell-crown strong{color:#214f39}
.compare-badge{display:inline-flex;align-items:center;width:max-content;padding:7px 11px;border-radius:999px;background:#214f39;color:#fff;font-size:.66rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 10px 22px rgba(47,111,78,.16)}
.compare-badge.muted{background:#eee7de;color:#715f49;box-shadow:none}
.compare-icon{display:inline-grid;place-items:center;flex:0 0 28px;width:28px;height:28px;border-radius:999px;background:#2f6f4e;color:#fff;font-size:.92rem;font-weight:800;box-shadow:0 9px 20px rgba(47,111,78,.22)}
.compare-icon-muted{background:#d8c9b5;color:#6b5437;box-shadow:none}

.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.stat-grid div{border:1px solid #e3d7c8;padding:16px;text-align:center;background:#fff;border-radius:10px}
.stat-grid strong{font-size:2.2rem;font-family:'Cormorant Garamond',serif;display:block}
.stat-grid span{font-size:.84rem;color:#575757}

.offer-grid{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:center}
.offer-media img{width:100%;aspect-ratio:4 / 3;object-fit:cover;object-position:center;border-radius:12px;border:1px solid var(--line)}
.img-placeholder{width:100%;min-height:120px;display:grid;place-items:center;background:#ece7de;border:1px dashed #cdbca4;color:#665643;border-radius:10px;padding:12px;text-align:center;font-size:.82rem}
.portfolio-grid .img-placeholder{aspect-ratio:4 / 3;min-height:0}
.offer-media .img-placeholder{aspect-ratio:4 / 3;min-height:0}
.logo-grid .img-placeholder{height:70px;min-height:70px}
.offer ul{margin:0;padding-left:18px;line-height:1.8}

.faq details{border:1px solid var(--line);padding:15px;margin:10px 0;background:#fff;border-radius:10px}
.faq summary{cursor:pointer;font-weight:600;list-style:none}
.faq details p{margin:10px 0 0;line-height:1.7}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:'+';margin-right:8px;color:#7f6745}

.final-cta{text-align:center}
.final-cta p{max-width:760px;margin:0 auto 18px}
.designer-grid{display:flex;flex-direction:column;gap:34px;margin:34px auto 12px;max-width:1080px}
.designer-row{display:flex;justify-content:center;gap:34px;width:100%}
.designer-card{flex:0 1 240px;text-align:center}
.designer-photo{width:160px;height:160px;border-radius:999px;object-fit:cover;object-position:center;margin:0 auto 16px;border:1px solid var(--line);background:#fff}
.designer-card h3{font-family:Inter,Arial,sans-serif;font-size:1.15rem;line-height:1.25;font-weight:400;margin:0 0 6px;color:#303030}
.designer-card p{font-size:1rem;line-height:1.35;margin:0;color:#777}
.final-cta .main-btn{max-width:360px}

.whatsapp{position:fixed;right:16px;bottom:18px;background:#1fba57;color:#fff;padding:10px 14px;text-decoration:none;border-radius:24px;font-size:13px;z-index:30}
.footer,.admin-footer{padding:24px 0;text-align:center;border-top:1px solid var(--line);background:#f2eee7;color:#2f2a25;font-size:13px;line-height:1.6}
.footer a,.admin-footer a{color:inherit;text-decoration:none}
.footer a:hover,.admin-footer a:hover{text-decoration:none}

.thankyou-body{display:grid;place-items:center;min-height:100vh}
.thankyou-card{background:#fff;border:1px solid var(--line);padding:34px;text-align:center;width:min(560px,92%)}

@media (max-width: 1080px){.hero-grid{grid-template-columns:1fr}.form-card{max-width:620px}}
@media (max-width: 980px){
  .container{width:min(1180px,calc(100% - 30px))}
  .trust-grid,.logo-grid,.portfolio-grid,.stat-grid,.offer-grid{grid-template-columns:1fr}
  .compare{overflow:hidden}
  .compare::before{width:340px;height:340px;top:120px}
  .compare-heading{margin-bottom:24px;text-align:left}
  .compare-heading h2{text-align:left}
  .compare-heading p{margin-left:0}
  .compare-card{display:grid;gap:16px;overflow:visible;border:0;border-radius:0;background:transparent;box-shadow:none}
  .compare-card::before{display:none}
  .compare-row-head{display:none}
  .compare-row{display:grid;grid-template-columns:1fr;gap:12px;min-height:0;margin:0;padding:15px;border:1px solid #e0d1bd;border-radius:22px;background:linear-gradient(180deg,#fff,#fbf8f3);box-shadow:0 16px 36px rgba(42,32,22,.09)}
  .compare-row:first-child{border-top:1px solid #e0d1bd}
  .compare-cell{padding:0;font-size:.98rem}
  .compare-cell + .compare-cell{border-left:0;border-top:0}
  .compare-cell-feature{justify-content:flex-start;text-align:left}
  .compare-row:not(.compare-row-head) .compare-cell-feature{display:flex;align-items:center;gap:9px;padding:0 0 2px;color:#8a765d;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase}
  .compare-row:not(.compare-row-head) .compare-cell-feature::before{content:'Decision point';font-weight:800}
  .compare-row:not(.compare-row-head) .compare-cell-feature span{width:28px;height:28px;background:#f2e7d8;color:#735a3c}
  .compare-row:not(.compare-row-head) .compare-cell-crown,.compare-row:not(.compare-row-head) .compare-cell-others{position:relative;display:grid;grid-template-columns:32px 1fr;gap:11px;align-items:center;padding:42px 15px 15px;border:1px solid #eee7de;border-radius:16px;min-width:0}
  .compare-row:not(.compare-row-head) .compare-cell-crown{border-color:rgba(47,111,78,.18);background:linear-gradient(180deg,rgba(47,111,78,.1),rgba(255,255,255,.98));box-shadow:inset 4px 0 0 rgba(47,111,78,.72)}
  .compare-row:not(.compare-row-head) .compare-cell-others{background:#f8f6f2;color:#5f5a54}
  .compare-row:not(.compare-row-head) .compare-cell-crown::before,.compare-row:not(.compare-row-head) .compare-cell-others::before{content:attr(data-label);position:absolute;top:13px;left:15px;right:15px;color:#82674a;font-size:.68rem;font-weight:800;letter-spacing:.12em;line-height:1.2;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .compare-row:not(.compare-row-head) .compare-cell-crown::before{color:#24593f}
  .compare-icon{width:28px;height:28px;flex-basis:28px}
  .portfolio-tabs{width:100%;justify-content:stretch}
  .portfolio-tab{flex:1 1 42%;padding:11px 14px}
  .testimonial-slider-desktop{display:none}
  .testimonial-slider-mobile{display:block;margin-top:18px}
  .testimonial-grid{grid-template-columns:1fr}
  .designer-row{flex-direction:column;align-items:center}
  .designer-card{width:min(100%,240px)}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  nav{display:none;position:absolute;top:74px;left:0;right:0;background:rgba(248,246,242,.98);padding:12px 15px;border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:10px}
  nav.is-open{display:flex}
  nav a{font-size:.78rem;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;text-align:center}
  nav .nav-cta{padding:12px 14px}
  section{padding:62px 0}
  .hero{padding:52px 0}
  .social{--social-title-spacing:62px}
}

.logo img{display:block;max-height:42px;width:auto;height:auto;object-fit:contain;}
.choice-group{display:grid;gap:10px;margin:8px 0 14px;}
.choice-item{display:flex;align-items:flex-start;gap:10px;border:1px solid #ddd4c8;border-radius:10px;padding:10px 12px;background:#fff;cursor:pointer;}
.choice-item input{width:auto;margin-top:3px;}
.choice-item:has(input:checked){border-color:var(--accent);background:#fbf6ef;}
.form-card select{width:100%;padding:12px;border:1px solid #ddd4c8;background:#fff;border-radius:8px;font-family:inherit;}
.consent-check{display:flex;gap:10px;align-items:flex-start;margin-top:12px;font-size:13px;line-height:1.45;color:#111;}
.consent-check input[type="checkbox"]{margin-top:2px;flex:0 0 auto;width:18px;height:18px;}
@media (max-width:980px){.logo img{max-height:34px;}}

.form-step{display:none}
.form-step.is-active{display:block}
.form-stepper{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:10px 0 14px}
.step-status{font-size:.86rem;font-weight:700;color:#5b5043;letter-spacing:.02em}
.step-dots{display:flex;gap:8px}
.step-dot{width:10px;height:10px;border-radius:999px;background:#d8ccbc}
.step-dot.is-active{background:var(--accent)}
.form-actions{display:flex;gap:10px;margin-top:12px}
.step-btn{flex:1;padding:11px;border-radius:8px;border:1px solid #111;background:#111;color:#fff;font-weight:600;cursor:pointer}
.step-btn.ghost{background:#fff;color:#111}
.step-review-note{font-size:.85rem;margin:0 0 8px;color:#5b5043}
.logo{max-width:min(240px,42vw)}
.logo img{width:100%;height:42px;object-fit:contain;object-position:left center}
@media (max-width:980px){.logo img{height:34px}}

body.menu-open{overflow:hidden}
