*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --c0:#FFFFFF;
  --c1:#F5F6F8;
  --c2:#EBEDF0;
  --c3:#D8DBE2;
  --c4:#C0C4CE;
  --line:#E0E3EA;
  --t0:#111827;
  --t1:#374151;
  --t2:#6B7280;
  --t3:#9CA3AF;
  --blue:#3060FF;
  --blue-hi:#4F7CFF;
  --blue-dim:rgba(48,96,255,.08);
  --blue-border:rgba(48,96,255,.2);
  --r:10px;
}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',sans-serif;
  background:var(--c0);color:var(--t0);
  font-size:15px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

/* scrollbar */
::-webkit-scrollbar{width:6px;} ::-webkit-scrollbar-track{background:var(--c1);} ::-webkit-scrollbar-thumb{background:var(--c3);border-radius:3px;}

/* ─── NAV ─── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;height:60px;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line);
}
.nav-logo{display:flex;align-items:center;text-decoration:none;}
.nav-logo img{height:28px;width:auto;filter:none;}
.nav-links{display:flex;gap:30px;list-style:none;}
.nav-links a{font-size:13.5px;font-weight:450;color:var(--t2);text-decoration:none;transition:color .15s;letter-spacing:-.01em;}
.nav-links a:hover{color:var(--t0);}
.nav-right{display:flex;gap:8px;align-items:center;}
.n-login{font-size:13.5px;font-weight:500;color:var(--t1);background:none;border:1px solid var(--line);padding:7px 16px;border-radius:var(--r);cursor:pointer;text-decoration:none;transition:all .15s;}
.n-login:hover{border-color:var(--t2);color:var(--t0);}
.n-signup{font-size:13.5px;font-weight:600;color:#fff;background:var(--blue);border:none;padding:7px 18px;border-radius:var(--r);cursor:pointer;text-decoration:none;transition:all .15s;letter-spacing:-.01em;}
.n-signup:hover{background:var(--blue-hi);}

/* ─── HERO ─── */
.hero{
  min-height:100svh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;padding:100px 24px 60px;
  position:relative;overflow:hidden;
}
.hero-glow{
  position:absolute;top:-200px;left:50%;transform:translateX(-50%);
  width:800px;height:600px;
  background:radial-gradient(ellipse at center,rgba(48,96,255,.08) 0%,transparent 65%);
  pointer-events:none;
}
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,black 0%,transparent 70%);
  opacity:.35;pointer-events:none;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12px;font-weight:500;letter-spacing:.02em;
  color:var(--t2);background:var(--c2);
  padding:5px 13px;border-radius:99px;margin-bottom:32px;
  border:1px solid var(--line);position:relative;z-index:1;
  animation:up .6s ease both;
}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);box-shadow:0 0 6px var(--blue);}
.hero h1{
  font-size:clamp(36px,6vw,76px);font-weight:800;
  line-height:1.02;letter-spacing:-.04em;
  color:var(--t0);max-width:840px;
  position:relative;z-index:1;
  animation:up .6s .08s ease both;
}
.hero h1 span{color:var(--blue-hi);}
.hero-sub{
  font-size:17px;font-weight:400;color:var(--t2);
  max-width:440px;margin-top:20px;line-height:1.65;
  position:relative;z-index:1;
  animation:up .6s .16s ease both;
}
.hero-cta{
  display:flex;gap:10px;margin-top:32px;
  position:relative;z-index:1;
  animation:up .6s .24s ease both;
}
.cta-main{
  font-size:14px;font-weight:600;color:#ffffff;
  background:var(--blue);border:none;cursor:pointer;
  padding:11px 26px;border-radius:var(--r);
  text-decoration:none;transition:all .15s;letter-spacing:-.01em;
  box-shadow:0 0 0 1px rgba(48,96,255,.3),0 8px 32px rgba(48,96,255,.2);
}
.cta-main:hover{background:var(--blue-hi);box-shadow:0 0 0 1px rgba(48,96,255,.4),0 12px 40px rgba(48,96,255,.25);transform:translateY(-1px);}
.cta-sec{
  font-size:14px;font-weight:500;color:var(--t1);
  background:none;border:1px solid var(--line);cursor:pointer;
  padding:11px 22px;border-radius:var(--r);text-decoration:none;transition:all .15s;
}
.cta-sec:hover{border-color:var(--t2);color:var(--t0);}
.hero-screen{
  width:min(960px,92%);margin-top:60px;
  position:relative;z-index:1;
  animation:up .7s .32s ease both;
}
.screen-chrome{
  background:var(--c2);border:1px solid var(--line);
  border-radius:12px;overflow:hidden;
  box-shadow:0 0 0 1px var(--line),0 40px 100px rgba(0,0,0,.1);
}
.screen-bar{
  display:flex;align-items:center;gap:6px;
  padding:11px 16px;background:var(--c1);border-bottom:1px solid var(--line);
}
.dot{width:10px;height:10px;border-radius:50%;}
.dr{background:#FF5F57;}.dy{background:#FEBC2E;}.dg{background:#28C840;}
.screen-url{
  flex:1;background:var(--c2);border:1px solid var(--line);
  border-radius:6px;padding:4px 12px;font-size:11px;color:var(--t3);
  text-align:center;margin:0 10px;letter-spacing:.02em;
}
.screen-bar-space{width:60px;}
.screen-chrome img{width:100%;display:block;}

/* ─── LOGOS / SOCIAL PROOF ─── */
.logos-strip{
  padding:48px 24px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--c1);
}
.logos-inner{max-width:900px;margin:0 auto;text-align:center;}
.logos-label{font-size:12px;font-weight:500;color:var(--t3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:28px;}
.logos-row{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;}
.logo-company{font-size:15px;font-weight:700;color:var(--t3);letter-spacing:-.02em;transition:color .2s;}
.logo-company:hover{color:var(--t1);}

/* ─── SECTION ─── */
section{padding:96px 24px;}
.wrap{max-width:1080px;margin:0 auto;}
.label{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--blue-hi);margin-bottom:16px;
}
.label::before{content:'';width:14px;height:1px;background:var(--blue-hi);}
h2{
  font-size:clamp(28px,3.5vw,46px);font-weight:800;
  letter-spacing:-.04em;line-height:1.08;color:var(--t0);
}
.sub{font-size:15px;color:var(--t2);margin-top:12px;line-height:1.7;max-width:440px;font-weight:400;}

/* ─── HOW IT WORKS ─── */
#how{background:var(--c1);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.how-header{text-align:center;margin-bottom:64px;}
.how-header h2,.how-header .sub{max-width:100%;margin-left:auto;margin-right:auto;}
.how-header .sub{max-width:480px;}
.steps-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);border-radius:14px;overflow:hidden;
  background:var(--c0);
}
.step{
  padding:28px 24px;border-right:1px solid var(--line);
  transition:background .2s;
}
.step:last-child{border-right:none;}
.step:hover{background:var(--c2);}
.step-n{
  font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--t3);
  margin-bottom:16px;
}
.step-icon{
  width:38px;height:38px;border-radius:9px;
  background:var(--blue-dim);border:1px solid var(--blue-border);
  display:grid;place-items:center;font-size:17px;margin-bottom:16px;
}
.step-title{font-size:14px;font-weight:700;color:var(--t0);margin-bottom:6px;letter-spacing:-.02em;}
.step-desc{font-size:13px;color:var(--t2);line-height:1.6;}
.guides{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
  background:var(--line);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;margin-top:20px;
}
.guide{
  background:var(--c0);padding:28px;transition:background .2s;
}
.guide:hover{background:var(--c1);}
.guide-title{
  font-size:13.5px;font-weight:700;color:var(--t0);
  margin-bottom:16px;letter-spacing:-.02em;display:flex;align-items:center;gap:8px;
}
.guide-icon{font-size:15px;}
.guide-steps{display:flex;flex-direction:column;gap:10px;}
.gs{display:flex;gap:10px;align-items:flex-start;}
.gs-num{
  min-width:20px;height:20px;border-radius:5px;
  background:var(--c3);border:1px solid var(--c4);
  font-size:10px;font-weight:700;color:var(--t3);
  display:grid;place-items:center;flex-shrink:0;margin-top:1px;
}
.gs-text{font-size:13px;color:var(--t2);line-height:1.55;}
.gs-text strong{color:var(--t1);font-weight:600;}

/* ─── FEATURES ─── */
#features{background:var(--c0);}
.feature-block{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:center;padding:72px 0;
  border-bottom:1px solid var(--line);
}
.feature-block:last-child{border-bottom:none;}
.feature-block.flip{direction:rtl;}
.feature-block.flip>*{direction:ltr;}
.ftag{
  display:inline-block;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;
  color:var(--blue-hi);background:var(--blue-dim);border:1px solid var(--blue-border);
  padding:3px 10px;border-radius:5px;margin-bottom:14px;
}
.ftitle{font-size:clamp(22px,2.5vw,32px);font-weight:800;letter-spacing:-.03em;color:var(--t0);margin-bottom:12px;line-height:1.15;}
.fdesc{font-size:14.5px;color:var(--t2);line-height:1.7;margin-bottom:22px;}
.flist{list-style:none;display:flex;flex-direction:column;gap:9px;}
.flist li{
  display:flex;align-items:flex-start;gap:9px;
  font-size:13.5px;color:var(--t2);line-height:1.5;
}
.flist li::before{
  content:'';width:16px;height:16px;border-radius:4px;flex-shrink:0;margin-top:2px;
  background:var(--blue-dim) url("data:image/svg+xml,%3Csvg width='8' height='7' viewBox='0 0 8 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 3.5L3 5.5L7 1.5' stroke='%234F7CFF' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
  border:1px solid var(--blue-border);
}
.fscreen{
  border-radius:12px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 20px 60px rgba(0,0,0,.08);
}
.fscreen img{width:100%;display:block;}

/* ─── FEATURES GRID ─── */
#all-features{background:var(--c1);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.fgrid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--line);border-radius:14px;
  overflow:hidden;margin-top:48px;
}
.fc{
  padding:26px 24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--c0);transition:background .18s;
}
.fc:hover{background:var(--c2);}
.fc:nth-child(3n){border-right:none;}
.fc:nth-last-child(-n+3){border-bottom:none;}
.fc-icon{
  width:36px;height:36px;border-radius:8px;
  background:var(--blue-dim);border:1px solid var(--blue-border);
  display:grid;place-items:center;font-size:16px;margin-bottom:12px;
}
.fc-name{font-size:13.5px;font-weight:700;color:var(--t0);margin-bottom:4px;letter-spacing:-.02em;}
.fc-desc{font-size:12.5px;color:var(--t2);line-height:1.6;}

/* ─── PRODUCTIVITY ─── */
#productivity{background:var(--c0);}
.prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:48px;align-items:start;}
.pcards{display:flex;flex-direction:column;gap:12px;}
.pcard{
  background:var(--c1);border:1px solid var(--line);
  border-radius:12px;padding:22px;transition:border-color .2s;
}
.pcard:hover{border-color:var(--c4);}
.pcard-title{font-size:14px;font-weight:700;color:var(--t0);margin-bottom:4px;letter-spacing:-.02em;}
.pcard-desc{font-size:13px;color:var(--t2);line-height:1.6;}
.lb{
  background:var(--c1);border:1px solid var(--line);
  border-radius:12px;padding:24px;
}
.lb-head{
  font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--t3);margin-bottom:18px;
}
.lb-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);}
.lb-row:last-child{border-bottom:none;}
.lb-n{font-size:13px;font-weight:700;color:var(--t3);width:18px;flex-shrink:0;}
.lb-n.g{color:#FFC849;}
.lb-av{
  width:32px;height:32px;border-radius:50%;
  background:var(--blue-dim);border:1px solid var(--blue-border);
  display:grid;place-items:center;font-size:11px;font-weight:700;color:var(--blue-hi);flex-shrink:0;
}
.lb-info{flex:1;}
.lb-name{font-size:13px;font-weight:600;color:var(--t0);line-height:1;margin-bottom:2px;}
.lb-role{font-size:11px;color:var(--t3);}
.lb-count{font-size:12px;color:var(--t3);flex-shrink:0;}
.lb-bar-wrap{width:80px;height:3px;background:var(--c3);border-radius:99px;overflow:hidden;flex-shrink:0;}
.lb-bar{height:100%;background:var(--blue);border-radius:99px;}

/* ─── AI ─── */
#ai{background:var(--c1);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.ai-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:48px;}
.ai-panel{background:var(--c0);border:1px solid var(--line);border-radius:12px;padding:24px;}
.ai-panel-title{font-size:13.5px;font-weight:700;color:var(--t0);margin-bottom:4px;letter-spacing:-.02em;}
.ai-panel-desc{font-size:12.5px;color:var(--t2);line-height:1.6;margin-bottom:18px;}
.msgs{display:flex;flex-direction:column;gap:8px;}
.msg{max-width:90%;}
.msg-who{font-size:10px;font-weight:600;color:var(--t3);margin-bottom:3px;letter-spacing:.04em;text-transform:uppercase;}
.msg-who.r{text-align:right;}
.bubble{padding:9px 13px;border-radius:10px;font-size:12.5px;line-height:1.5;}
.b-in{background:var(--c2);border:1px solid var(--line);color:var(--t1);border-bottom-left-radius:3px;}
.b-out{background:var(--blue);color:#fff;border-bottom-right-radius:3px;margin-left:auto;}
.tg-list{display:flex;flex-direction:column;gap:7px;margin-top:4px;}
.tg-item{
  display:flex;align-items:center;gap:9px;
  background:var(--c2);border:1px solid var(--line);
  border-radius:8px;padding:9px 13px;
  font-size:12.5px;color:var(--t2);
}
.tg-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0;}

/* ─── PRICING ─── */
#pricing{background:var(--c0);}
.pricing-head{text-align:center;margin-bottom:48px;}
.pricing-head h2,.pricing-head .sub{margin-left:auto;margin-right:auto;text-align:center;max-width:100%;}
.pricing-head .sub{max-width:400px;}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.pcard-wrap{position:relative;}
.pbadge{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:var(--blue);color:#fff;
  font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:3px 11px;border-radius:99px;white-space:nowrap;
}
.pc{
  background:var(--c1);border:1px solid var(--line);
  border-radius:14px;padding:24px;
  transition:border-color .2s;height:100%;
}
.pc:hover{border-color:var(--c4);}
.pc.hi{background:var(--blue);border-color:var(--blue);}
.pc-tier{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--t3);margin-bottom:12px;}
.pc.hi .pc-tier{color:rgba(255,255,255,.5);}
.pc-price{font-size:38px;font-weight:800;color:var(--t0);letter-spacing:-.04em;display:flex;align-items:flex-start;gap:1px;line-height:1;}
.pc.hi .pc-price{color:#fff;}
.pc-sym{font-size:17px;font-weight:400;color:var(--t3);margin-top:6px;}
.pc.hi .pc-sym{color:rgba(255,255,255,.5);}
.pc-period{font-size:11px;color:var(--t3);align-self:flex-end;margin-bottom:4px;padding-left:2px;}
.pc.hi .pc-period{color:rgba(255,255,255,.45);}
.pc-desc{font-size:12.5px;color:var(--t2);margin:12px 0 18px;line-height:1.6;}
.pc.hi .pc-desc{color:rgba(255,255,255,.6);}
.pc-features{display:flex;flex-direction:column;gap:8px;margin-bottom:22px;}
.pcf{display:flex;align-items:flex-start;gap:7px;font-size:12.5px;color:var(--t2);}
.pc.hi .pcf{color:rgba(255,255,255,.75);}
.pcf-check{color:var(--blue-hi);flex-shrink:0;font-size:12px;font-weight:700;}
.pc.hi .pcf-check{color:rgba(255,255,255,.85);}
.pc-btn{
  width:100%;padding:10px;border-radius:8px;font-size:13px;
  font-weight:600;cursor:pointer;transition:all .15s;border:none;
  font-family:'Inter',sans-serif;letter-spacing:-.01em;
}
.pc-btn-dim{background:none;border:1px solid var(--line);color:var(--t1);}
.pc-btn-dim:hover{border-color:var(--t2);color:var(--t0);}
.pc-btn-white{background:#fff;color:var(--blue);border:1px solid rgba(255,255,255,.3);}
.pc-btn-white:hover{background:rgba(255,255,255,.9);}

/* ─── CTA ─── */
#cta{
  background:var(--c1);border-top:1px solid var(--line);
  text-align:center;padding:100px 24px;position:relative;overflow:hidden;
}
#cta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 80% at 50% 100%,rgba(48,96,255,.06) 0%,transparent 60%);
  pointer-events:none;
}
#cta h2{max-width:560px;margin:0 auto;position:relative;z-index:1;}
#cta .sub{margin:14px auto 0;text-align:center;max-width:380px;position:relative;z-index:1;}
.cta-row{display:flex;gap:10px;justify-content:center;margin-top:32px;position:relative;z-index:1;}

/* ─── FOOTER ─── */
footer{background:var(--c0);border-top:1px solid var(--line);padding:56px 40px 36px;}
.footer-main{max-width:1080px;margin:0 auto;}
.footer-top{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px;}
.footer-brand img{height:26px;filter:none;opacity:.7;}
.footer-brand-tag{font-size:12px;color:var(--t3);margin-top:10px;line-height:1.6;max-width:200px;}
.fcol-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t3);margin-bottom:14px;}
.fcol-links{display:flex;flex-direction:column;gap:9px;}
.fcol-links a{font-size:13px;color:var(--t2);text-decoration:none;transition:color .15s;}
.fcol-links a:hover{color:var(--t0);}
.fcol-links span{font-size:13px;color:var(--t2);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--line);padding-top:22px;
}
.footer-copy{font-size:12px;color:var(--t3);}
.footer-legal{display:flex;gap:18px;}
.footer-legal a{font-size:12px;color:var(--t3);text-decoration:none;cursor:pointer;transition:color .15s;}
.footer-legal a:hover{color:var(--t1);}
.socials{display:flex;gap:8px;}
.soc{
  width:34px;height:34px;border-radius:8px;
  background:var(--c2);border:1px solid var(--line);
  display:grid;place-items:center;transition:all .18s;text-decoration:none;
}
.soc:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-2px);}
.soc svg{width:16px;height:16px;fill:var(--t2);transition:fill .18s;}
.soc:hover svg{fill:#fff;}

/* ─── MODAL ─── */
.overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.4);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;padding:24px;
}
.overlay.on{display:flex;}
.modal{
  background:var(--c1);border:1px solid var(--line);
  border-radius:16px;width:min(680px,100%);max-height:78vh;
  display:flex;flex-direction:column;
  box-shadow:0 40px 100px rgba(0,0,0,.15);
  animation:up .2s ease both;
}
.modal-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;border-bottom:1px solid var(--line);flex-shrink:0;
}
.modal-ttl{font-size:16px;font-weight:700;color:var(--t0);letter-spacing:-.02em;}
.modal-x{
  width:30px;height:30px;border-radius:7px;border:1px solid var(--line);
  background:none;cursor:pointer;display:grid;place-items:center;
  font-size:15px;color:var(--t2);transition:all .15s;
}
.modal-x:hover{background:var(--c3);color:var(--t0);}
.modal-bd{overflow-y:auto;padding:24px;flex:1;}
.modal-bd h2{font-size:13.5px;font-weight:700;color:var(--t0);margin:20px 0 6px;letter-spacing:-.02em;}
.modal-bd h2:first-child{margin-top:0;}
.modal-bd p{font-size:13px;color:var(--t2);line-height:1.7;margin-bottom:8px;}
.modal-bd ul{padding-left:18px;margin-bottom:8px;}
.modal-bd ul li{font-size:13px;color:var(--t2);line-height:1.7;margin-bottom:3px;}
.modal-updated{font-size:11px;color:var(--t3);margin-bottom:18px;letter-spacing:.04em;text-transform:uppercase;}

/* ─── ANIM ─── */
@keyframes up{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
.rev{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease;}
.rev.on{opacity:1;transform:none;}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){.pgrid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:900px){
  nav{padding:0 20px;}
  .nav-links{display:none;}
  .feature-block{grid-template-columns:1fr;gap:32px;}
  .feature-block.flip{direction:ltr;}
  .prod-grid,.ai-cols{grid-template-columns:1fr;}
  .fgrid{grid-template-columns:1fr 1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
  .steps-row{grid-template-columns:1fr 1fr;}
  .step:nth-child(2){border-right:none;}
  .step:nth-child(3){border-top:1px solid var(--line);}
  .guides{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .fgrid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .pgrid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center;}
  .steps-row{grid-template-columns:1fr;}
  .step{border-right:none;border-bottom:1px solid var(--line);}
  .step:last-child{border-bottom:none;}
  footer{padding:48px 20px 32px;}
}
