/* ============================================================
   BuatinKonten — Premium UI System
   ============================================================ */
:root{
  --bg:#FBF9F6;
  --bg-2:#F3EEE6;
  --ink:#17130E;
  --ink-soft:#3A332B;
  --muted:#7A7064;
  --line:#E8E1D5;
  --line-strong:#D8CFBF;
  --card:#FFFFFF;
  --accent:#CF5A33;
  --accent-deep:#B5491F;
  --accent-soft:#F6E7DE;
  --forest:#21372F;
  --gold:#C9A227;
  --shadow:0 1px 2px rgba(23,19,14,.04),0 12px 32px -12px rgba(23,19,14,.14);
  --shadow-lg:0 2px 6px rgba(23,19,14,.05),0 36px 70px -28px rgba(23,19,14,.30);
  --radius:22px;
  --radius-sm:14px;
  --maxw:1180px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Plus Jakarta Sans",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60% 50% at 78% -5%,rgba(207,90,51,.10),transparent 60%),
    radial-gradient(50% 40% at 8% 8%,rgba(33,55,47,.07),transparent 60%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-weight:600;font-size:.98rem;
  padding:.95rem 1.6rem;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .25s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--ink);color:#fff;box-shadow:0 10px 26px -10px rgba(23,19,14,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 38px -12px rgba(23,19,14,.6)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 12px 28px -10px rgba(207,90,51,.6)}
.btn-accent:hover{transform:translateY(-2px);background:var(--accent-deep)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{background:#fff;border-color:var(--ink);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.btn-light:hover{transform:translateY(-2px)}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:rgba(251,249,246,.78);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
.nav.scrolled{border-color:var(--line);box-shadow:0 8px 30px -24px rgba(23,19,14,.4)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.brand .dot{width:30px;height:30px;border-radius:9px;background:var(--ink);color:#fff;
  display:grid;place-items:center;font-family:var(--serif);font-size:1.05rem;transform:rotate(-6deg)}
.brand b{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a.lnk{font-size:.94rem;color:var(--ink-soft);font-weight:500;position:relative}
.nav-links a.lnk::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;background:var(--accent);transition:width .3s}
.nav-links a.lnk:hover::after{width:100%}
.nav-cta{display:flex;gap:.7rem;align-items:center}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---------- Hero ---------- */
.hero{position:relative;padding:74px 0 40px;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;color:var(--accent-deep);
  background:var(--accent-soft);border:1px solid #efd6c8;padding:.45rem 1rem;border-radius:999px;margin-bottom:1.6rem}
.eyebrow .pulse{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(207,90,51,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(207,90,51,.5)}70%{box-shadow:0 0 0 9px rgba(207,90,51,0)}100%{box-shadow:0 0 0 0 rgba(207,90,51,0)}}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.5rem,6.2vw,4.7rem);
  line-height:1.02;letter-spacing:-.025em;max-width:14ch;margin:0 auto 1.4rem}
.hero h1 em{font-style:italic;color:var(--accent);position:relative}
.hero h1 .uline{background:linear-gradient(transparent 64%,rgba(201,162,39,.35) 0);padding:0 .05em}
.hero p.lead{font-size:clamp(1.05rem,2vw,1.28rem);color:var(--muted);max-width:46ch;margin:0 auto 2.2rem}
.hero-cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.2rem}
.trust{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;color:var(--muted);font-size:.86rem;margin-top:.4rem}
.trust span{display:inline-flex;align-items:center;gap:.4rem}
.trust svg{width:16px;height:16px;color:var(--accent)}

/* hero preview mock */
.hero-mock{margin:54px auto 0;max-width:980px;position:relative}
.mock-window{background:var(--card);border:1px solid var(--line);border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-lg);transform:perspective(1600px) rotateX(7deg);transform-origin:center top}
.mock-bar{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--line);background:#fff}
.mock-bar i{width:11px;height:11px;border-radius:50%;display:block}
.mock-bar .r{background:#ff5f57}.mock-bar .y{background:#febc2e}.mock-bar .g{background:#28c840}
.mock-bar .url{margin-left:.8rem;font-size:.78rem;color:var(--muted);background:var(--bg-2);
  padding:.3rem .9rem;border-radius:8px;flex:1;max-width:320px;text-align:center}
.mock-body{display:grid;grid-template-columns:1fr 1.25fr;gap:0;min-height:340px}
.mock-left{padding:26px;border-right:1px solid var(--line);background:linear-gradient(180deg,#fff,var(--bg))}
.mock-left h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.9rem}
.mock-field{background:#fff;border:1px solid var(--line);border-radius:12px;padding:.7rem .9rem;
  font-size:.86rem;color:var(--ink-soft);margin-bottom:.7rem;text-align:left}
.mock-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin:.4rem 0 1rem}
.mock-chips b{font-size:.74rem;padding:.32rem .7rem;border-radius:999px;border:1px solid var(--line);font-weight:600;color:var(--ink-soft)}
.mock-chips b.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.mock-gen{background:var(--accent);color:#fff;text-align:center;border-radius:12px;padding:.7rem;font-weight:600;font-size:.86rem}
.mock-right{padding:24px;text-align:left;background:#fff}
.mock-card{border:1px solid var(--line);border-radius:12px;padding:.8rem .95rem;margin-bottom:.7rem;
  font-size:.8rem;color:var(--ink-soft);background:var(--bg)}
.mock-card .t{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-deep);font-weight:700;margin-bottom:.3rem}
.mock-skel{height:7px;border-radius:4px;background:linear-gradient(90deg,var(--bg-2),#fff,var(--bg-2));background-size:200% 100%;animation:shimmer 1.6s infinite;margin:.35rem 0}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.float-badge{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:.7rem .95rem;box-shadow:var(--shadow);font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.5rem}
.float-badge .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:1rem}
.fb-1{top:18%;left:-26px;animation:floaty 5s ease-in-out infinite}
.fb-2{bottom:14%;right:-22px;animation:floaty 6s ease-in-out infinite .8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Marquee ---------- */
.marquee{border-block:1px solid var(--line);margin-top:60px;padding:18px 0;overflow:hidden;background:rgba(255,255,255,.4)}
.marquee-track{display:flex;gap:3.5rem;width:max-content;animation:scroll 26s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--serif);font-size:1.3rem;color:var(--ink-soft);opacity:.6;white-space:nowrap;display:flex;align-items:center;gap:1rem}
.marquee-track span::after{content:"✳";color:var(--accent);font-size:.9rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- Section ---------- */
section{position:relative}
.sec{padding:96px 0}
.sec-head{text-align:center;max-width:660px;margin:0 auto 58px}
.kicker{font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.9rem}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4.3vw,3.1rem);line-height:1.08;letter-spacing:-.02em;margin-bottom:1rem}
.sec-head h2 em{font-style:italic;color:var(--accent)}
.sec-head p{color:var(--muted);font-size:1.08rem}
.divider{display:flex;align-items:center;justify-content:center;gap:1rem;color:var(--line-strong);margin:0 auto}
.divider::before,.divider::after{content:"";height:1px;width:70px;background:var(--line-strong)}
.divider span{color:var(--accent)}

/* ---------- Styles grid ---------- */
.styles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}
.style-card{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);background:#fff;transition:transform .35s,box-shadow .35s}
.style-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.style-card .grad{height:118px;width:100%}
.style-card .tag{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);border:1px solid var(--line);
  font-size:.64rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.26rem .6rem;border-radius:999px;color:var(--ink)}
.style-card .meta{padding:13px 15px 15px}
.style-card .meta h5{font-family:var(--serif);font-size:1.2rem;font-weight:600;color:var(--ink);margin-bottom:.2rem}
.style-card .meta p{color:var(--muted);font-size:.8rem;line-height:1.45}
.sg-editorial{background:linear-gradient(135deg,#f2ede4 42%,#d11f26)}
.sg-bold{background:linear-gradient(135deg,#1a1a1a,#3d3d3d)}
.sg-clean{background:linear-gradient(135deg,#fdfdfd,#e3e3e6)}
.sg-cozy{background:linear-gradient(135deg,#c98a5e,#e9c39a)}
.sg-warm{background:linear-gradient(135deg,#d9663f,#f0a868)}
.sg-cinematic{background:linear-gradient(135deg,#16222a,#3a6073)}
.sg-modern{background:linear-gradient(135deg,#6a5acd,#48c6ef 90%)}

/* ---------- Features list ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  box-shadow:var(--shadow);transition:transform .35s,box-shadow .35s,border-color .35s;position:relative;overflow:hidden}
.feat:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:var(--shadow-lg)}
.feat .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;
  background:var(--accent-soft);margin-bottom:1.1rem}
.feat h3{font-size:1.22rem;font-weight:700;letter-spacing:-.01em;margin-bottom:.5rem}
.feat p{color:var(--muted);font-size:.96rem}
.feat .pill{display:inline-block;margin-top:1rem;font-size:.76rem;font-weight:600;color:var(--accent-deep);
  background:var(--accent-soft);padding:.3rem .75rem;border-radius:999px}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:step}
.step{position:relative;padding-top:18px}
.step .n{font-family:var(--serif);font-size:3.2rem;color:var(--accent);opacity:.25;line-height:1;font-weight:600}
.step h4{font-size:1.2rem;font-weight:700;margin:.5rem 0}
.step p{color:var(--muted);font-size:.96rem}
.step::before{content:"";position:absolute;top:34px;right:-12px;width:24px;height:24px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23D8CFBF' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E") center/contain no-repeat}
.step:last-child::before{display:none}

/* ---------- Pricing ---------- */
.price-wrap{display:flex;justify-content:center}
.price-card{background:var(--ink);color:#fff;border-radius:30px;padding:46px;max-width:520px;width:100%;
  position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.price-card::before{content:"";position:absolute;top:-40%;right:-20%;width:60%;height:120%;
  background:radial-gradient(circle,rgba(207,90,51,.4),transparent 70%);filter:blur(10px)}
.price-card .ribbon{display:inline-block;background:var(--accent);color:#fff;font-size:.76rem;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;padding:.35rem .9rem;border-radius:999px;margin-bottom:1.4rem;position:relative}
.price-card h3{font-family:var(--serif);font-size:1.9rem;font-weight:600;margin-bottom:.4rem;position:relative}
.price-card .sub{color:rgba(255,255,255,.6);font-size:.95rem;margin-bottom:1.6rem;position:relative}
.price-amt{display:flex;align-items:baseline;gap:.7rem;margin-bottom:.3rem;position:relative}
.price-amt .now{font-family:var(--serif);font-size:3.4rem;font-weight:600}
.price-amt .was{font-size:1.2rem;color:rgba(255,255,255,.45);text-decoration:line-through}
.price-amt .off{font-size:.78rem;font-weight:700;background:var(--gold);color:#1a1a1a;padding:.25rem .6rem;border-radius:6px}
.price-note{color:rgba(255,255,255,.55);font-size:.84rem;margin-bottom:1.8rem;position:relative}
.price-list{list-style:none;margin-bottom:2rem;position:relative}
.price-list li{display:flex;align-items:flex-start;gap:.7rem;padding:.5rem 0;font-size:.96rem;color:rgba(255,255,255,.9)}
.price-list li svg{width:20px;height:20px;color:var(--accent);flex-shrink:0;margin-top:2px}
.price-card .btn{width:100%;justify-content:center;position:relative}

/* ---------- Testimonials ---------- */
.testi-grid{columns:3;column-gap:20px}
.testi{break-inside:avoid;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;margin-bottom:20px;box-shadow:var(--shadow)}
.testi .stars{color:var(--gold);font-size:.95rem;margin-bottom:.8rem;letter-spacing:2px}
.testi p{font-size:.98rem;color:var(--ink-soft);margin-bottom:1.2rem}
.testi .who{display:flex;align-items:center;gap:.7rem}
.testi .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:1rem}
.testi .who b{font-size:.92rem;display:block}
.testi .who span{font-size:.8rem;color:var(--muted)}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:760px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:14px;background:var(--card);overflow:hidden;transition:box-shadow .3s,border-color .3s}
.faq-item.open{box-shadow:var(--shadow);border-color:var(--line-strong)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:20px 24px;cursor:pointer;font-weight:600;font-size:1.04rem}
.faq-q .ico{width:26px;height:26px;flex-shrink:0;border-radius:50%;border:1px solid var(--line-strong);
  display:grid;place-items:center;transition:transform .3s,background .3s,color .3s}
.faq-item.open .faq-q .ico{transform:rotate(45deg);background:var(--accent);color:#fff;border-color:var(--accent)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 24px 22px;color:var(--muted);font-size:.97rem}

/* ---------- CTA band ---------- */
.cta-band{background:var(--forest);color:#fff;border-radius:34px;padding:64px 40px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 50% 0,rgba(201,162,39,.18),transparent 60%)}
.cta-band h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:600;margin-bottom:1rem;position:relative}
.cta-band p{color:rgba(255,255,255,.7);max-width:48ch;margin:0 auto 2rem;position:relative}
.cta-band .hero-cta{position:relative}

/* ---------- Footer ---------- */
footer{padding:64px 0 40px;border-top:1px solid var(--line);margin-top:96px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:44px}
.foot-grid p{color:var(--muted);font-size:.92rem;max-width:34ch;margin-top:1rem}
.foot-col h6{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);margin-bottom:1rem}
.foot-col a{display:block;color:var(--muted);font-size:.92rem;padding:.3rem 0;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
  padding-top:28px;border-top:1px solid var(--line);color:var(--muted);font-size:.86rem}

/* ---------- Showcase slider ---------- */
.show-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:44px 26px;align-items:start;max-width:1040px;margin:0 auto;justify-content:center}
.show-block{display:flex;flex-direction:column;align-items:center;min-width:0}
@media(max-width:880px){.show-grid{max-width:440px}}
.show-carousel{display:flex;align-items:center;justify-content:center;gap:10px;max-width:100%;margin:0 auto}
.sc-viewport{width:300px;max-width:72vw;overflow:hidden;border-radius:22px;border:1px solid var(--line);box-shadow:var(--shadow-lg);background:#000}
.sc-track{display:flex;transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.sc-slide{min-width:100%;position:relative;margin:0}
.sc-slide img{display:block;width:100%;aspect-ratio:4/5;object-fit:cover}
.sc-slide figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;color:#fff;font-size:.85rem;font-weight:600;background:linear-gradient(transparent,rgba(0,0,0,.7))}
.sc-arrow{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:1px solid var(--line-strong);background:#fff;
  font-size:1.6rem;line-height:1;color:var(--ink);cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);transition:.2s}
.sc-arrow:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.06)}
.sc-dots{display:flex;gap:8px;justify-content:center;margin-top:22px}
.sc-dot{width:9px;height:9px;border-radius:50%;border:0;background:var(--line-strong);cursor:pointer;transition:.25s;padding:0}
.sc-dot.on{background:var(--accent);width:26px;border-radius:6px}
.sc-label{text-align:center;margin-top:14px;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
@media(max-width:560px){.sc-arrow{width:42px;height:42px;font-size:1.4rem}.show-carousel{gap:8px}}

/* ---------- Floating CTA ---------- */
.float-cta{position:fixed;z-index:55;right:20px;bottom:20px;display:flex;align-items:center;gap:.6rem;
  background:var(--accent);color:#fff;font-weight:700;font-size:.96rem;padding:.95rem 1.5rem;border-radius:999px;text-decoration:none;
  box-shadow:0 14px 34px -10px rgba(207,90,51,.65);transform:translateY(130px);opacity:0;
  transition:transform .45s cubic-bezier(.2,.7,.2,1),opacity .4s,background .2s}
.float-cta.show{transform:none;opacity:1;animation:ctaPulse 2.4s ease-in-out infinite}
.float-cta:hover{background:var(--accent-deep)}
.float-cta svg{width:20px;height:20px}.float-cta b{font-weight:800}
@keyframes ctaPulse{0%,100%{box-shadow:0 14px 34px -10px rgba(207,90,51,.6)}50%{box-shadow:0 16px 44px -6px rgba(207,90,51,.92)}}
@media(max-width:560px){.float-cta{left:14px;right:14px;bottom:14px;justify-content:center;font-size:1rem}}

/* ---------- Checkout modal ---------- */
.modal-overlay{position:fixed;inset:0;z-index:80;background:rgba(20,15,10,.55);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:18px;opacity:0;visibility:hidden;transition:.3s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal-box{background:#fff;border-radius:24px;max-width:440px;width:100%;max-height:92vh;overflow:auto;position:relative;
  box-shadow:var(--shadow-lg);transform:translateY(20px) scale(.98);transition:.3s}
.modal-overlay.open .modal-box{transform:none}
.modal-x{position:absolute;top:10px;right:14px;background:none;border:0;font-size:1.9rem;line-height:1;color:var(--muted);cursor:pointer;z-index:2}
.modal-top{padding:26px 26px 20px;background:linear-gradient(180deg,var(--accent-soft),#fff);border-radius:24px 24px 0 0;text-align:center}
.modal-top .ribbon{display:inline-block;background:var(--accent);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.04em;padding:.3rem .8rem;border-radius:999px;margin-bottom:.7rem}
.modal-top h3{font-family:var(--serif);font-size:1.45rem;font-weight:600;margin-bottom:.5rem}
.modal-price{display:flex;align-items:baseline;gap:.6rem;justify-content:center}
.modal-price .now{font-family:var(--serif);font-size:2rem;font-weight:600;color:var(--accent-deep)}
.modal-price .was{font-size:1rem;color:var(--muted);text-decoration:line-through}
.modal-sub{color:var(--muted);font-size:.88rem;margin-top:.6rem}
.modal-body{padding:22px 26px 26px}
.buy-step{display:flex;gap:.8rem;margin-bottom:1.1rem}
.bs-n{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--ink);color:#fff;font-weight:700;font-size:.86rem;display:grid;place-items:center}
.bs-c{font-size:.95rem;color:var(--ink-soft);flex:1;min-width:0}
.bank-card{display:flex;align-items:center;gap:.8rem;background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:.8rem 1rem;margin-top:.6rem}
.bank-logo{font-size:1.5rem}
.bank-name{font-weight:700;font-size:.9rem}
.bank-acc{font-family:var(--serif);font-size:1.25rem;font-weight:600;letter-spacing:.03em}
.bank-an{font-size:.74rem;color:var(--muted)}
.bank-copy{margin-left:auto;align-self:center;background:var(--ink);color:#fff;border:0;border-radius:8px;font-size:.76rem;font-weight:600;padding:.45rem .7rem;cursor:pointer;white-space:nowrap}
.m-inp{width:100%;font-family:var(--sans);font-size:.95rem;border:1px solid var(--line);border-radius:11px;padding:.75rem .9rem;margin-top:.5rem;background:var(--bg)}
.m-inp:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff}
.m-upload{display:flex;align-items:center;justify-content:center;gap:.4rem;cursor:pointer;margin-top:.5rem;
  border:1.5px dashed var(--line-strong);border-radius:11px;padding:.75rem;font-size:.86rem;font-weight:600;color:var(--ink-soft);background:var(--bg);transition:.2s;text-align:center}
.m-upload:hover{border-color:var(--accent);color:var(--accent-deep);background:#fff}
.m-uploadmsg{font-size:.78rem;font-weight:600;margin-top:.4rem;min-height:1em;word-break:break-all}
.m-confirm{width:100%;justify-content:center;gap:.5rem;margin-top:.4rem}
.m-note{text-align:center;font-size:.8rem;color:var(--muted);margin-top:.8rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .nav-links{display:none}
  .burger{display:flex}
  .mock-body{grid-template-columns:1fr}
  .mock-left{border-right:0;border-bottom:1px solid var(--line)}
  .styles-grid{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:34px}
  .step::before{display:none}
  .testi-grid{columns:2}
  .foot-grid{grid-template-columns:1fr 1fr}
  .float-badge{display:none}
}
@media(max-width:560px){
  .styles-grid{grid-template-columns:1fr}
  .testi-grid{columns:1}
  .foot-grid{grid-template-columns:1fr}
  .sec{padding:64px 0}
  .price-card{padding:32px 24px}
  .cta-band{padding:44px 22px}
}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:60;background:var(--bg);transform:translateX(100%);
  transition:transform .4s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;padding:24px}
.mobile-menu.open{transform:none}
.mobile-menu .mm-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.mobile-menu a.lnk{font-family:var(--serif);font-size:1.8rem;padding:14px 0;border-bottom:1px solid var(--line)}
.mm-close{background:none;border:0;font-size:2rem;cursor:pointer;line-height:1}
