:root{
  --canvas:#E7EDF4;--canvas-2:#D9E2EC;--surface:#F3F7FC;
  --navy:#1F2E4A;--navy-2:#16223A;
  --ink:#1E2536;--ink-2:#5A6478;--ink-3:#929BAD;
  --blue:#3E5C86;--blue-deep:#2F4A72;--blue-soft:#A9BBD8;--steel:#C7D3E4;
  --line:rgba(30,37,54,.13);--line-2:rgba(30,37,54,.07);--line-light:rgba(236,231,221,.16);
  --maxw:1220px;
  --shadow:0 30px 70px -34px rgba(22,34,58,.42);--shadow-sm:0 18px 40px -24px rgba(22,34,58,.34);
  --r:26px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--canvas);color:var(--ink);font-family:"Inter",system-ui,sans-serif;
  font-size:17px;line-height:1.62;letter-spacing:-.002em;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.05;
  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='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
header,main,footer{position:relative;z-index:1}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
a{color:inherit;text-decoration:none}
.eyebrow{font-family:"Inter";font-size:11.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--blue);font-weight:600}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:"Satoshi",sans-serif;font-weight:700;font-size:14.5px;letter-spacing:-.01em;
  padding:14px 26px;border-radius:999px;background:var(--navy);color:var(--canvas);border:1px solid var(--navy);
  transition:background .2s ease,transform .2s ease,border-color .2s ease;cursor:pointer}
.btn:hover{transform:translateY(-2px);background:var(--blue);border-color:var(--blue)}
.btn.line{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.line:hover{background:transparent;color:var(--blue);border-color:var(--blue)}

header{position:sticky;top:0;z-index:60;background:rgba(231,237,244,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-2)}
.bar{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand b{font-family:"Satoshi",sans-serif;font-weight:900;font-size:20px;letter-spacing:-.03em;line-height:1;color:var(--navy)}
.brand small{display:block;font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin-top:3px}
.brand-logo{display:block;height:52px;width:auto}
nav.links{display:flex;gap:34px;font-size:14.5px;color:var(--ink-2);font-weight:500}
nav.links a{position:relative;padding:4px 0}
nav.links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--blue);transition:width .25s ease}
nav.links a:hover{color:var(--ink)}nav.links a:hover::after{width:100%}

/* Hamburger button: hidden on desktop, shown on tablet portrait and phones */
.navtoggle{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:var(--surface);
  cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0}
.navtoggle span{display:block;width:20px;height:2px;background:var(--navy);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.navtoggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle.open span:nth-child(2){opacity:0}
.navtoggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobilemenu{display:none;flex-direction:column;padding:6px 0 14px}
.mobilemenu.open{display:flex}
.mobilemenu a{display:flex;align-items:center;min-height:46px;padding:6px 2px;font-family:"Satoshi",sans-serif;font-weight:700;font-size:16px;letter-spacing:-.01em;color:var(--navy);border-bottom:1px solid var(--line-2)}
.mobilemenu a.btn{justify-content:center;color:var(--canvas);border-bottom:none;margin-top:12px;min-height:50px}

@media(max-width:900px){
  nav.links{display:none}
  .bar > .header-cta{display:none}
  .navtoggle{display:inline-flex}
}
/* Desktop only: the hero zeroes the .wrap horizontal padding, so the header
   must drop its 32px gutter to share the same content box, then a small
   negative margin compensates the logo PNG's transparent left padding so the
   visible "H" lines up with the hero "B"/"O". Mobile header is left untouched. */
@media(min-width:901px){
  .bar{padding-left:0;padding-right:0}
  .brand-logo{margin-left:-8px}
}

.hero{padding:96px 0 70px;display:grid;grid-template-columns:1.06fr .94fr;gap:64px;align-items:center}
@media(max-width:920px){.hero{grid-template-columns:1fr;gap:40px;padding:60px 0 48px}}
@media(max-width:640px){.hero{gap:30px}section.hero{padding-top:64px}.hero .eyebrow{margin-bottom:18px}.lede{margin-top:22px;font-size:16.5px}.hero-cta{margin-top:28px}}
.hero .eyebrow{display:block;margin-bottom:26px}
h1{font-family:"Satoshi",sans-serif;font-weight:700;font-size:clamp(34px,8.5vw,86px);line-height:1.0;letter-spacing:-.035em;color:var(--navy)}
h1 .lt{font-weight:500;color:var(--blue)}
.lede{margin-top:30px;max-width:46ch;color:var(--ink-2);font-size:18.5px}
.hero-cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}

.pedestal{position:relative}
.tile{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;
  background:radial-gradient(120% 90% at 50% 12%, #F2F5FA 0%, #DEE6F1 55%, #C7D3E4 100%);
  border:1px solid rgba(63,92,134,.28);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center}
.tile .obj{width:100%;padding:0 44px;position:relative;z-index:1;animation:float 9s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.tile .ribbon{position:absolute;z-index:2;top:26px;left:26px;font-family:"Inter";font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--blue-deep);font-weight:700;border:1px solid rgba(47,74,114,.4);padding:7px 15px;border-radius:999px;background:rgba(248,245,238,.6)}
.price-chip{position:absolute;z-index:3;right:-12px;bottom:34px;background:var(--navy);color:var(--canvas);
  border-radius:18px;padding:18px 22px;box-shadow:var(--shadow-sm);max-width:220px}
.price-chip .e{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-soft);font-weight:700}
.price-chip .t{font-family:"Satoshi",sans-serif;font-weight:500;font-size:18px;line-height:1.25;margin-top:6px;letter-spacing:-.01em}
/* Keep the chip inside the viewport below desktop widths (it overhangs the
   pedestal by design on wide screens, which would otherwise overflow at 1024) */
@media(max-width:1080px){.price-chip{right:6px}}
/* Phones: drop the chip into normal flow under the tile so nothing hangs off the edge */
@media(max-width:640px){
  .tile .obj{padding:0 28px}
  .price-chip{position:static;max-width:none;width:100%;margin-top:14px;right:auto;bottom:auto;display:flex;flex-direction:column;gap:4px;padding:16px 20px}
  .price-chip .t{margin-top:0}
}

.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--canvas)}
.trust .inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
@media(max-width:760px){.trust .inner{grid-template-columns:repeat(2,1fr)}}
.trust .t{padding:26px 24px;border-right:1px solid var(--line)}
.trust .t:last-child{border-right:none}
@media(max-width:760px){.trust .t{border-bottom:1px solid var(--line)}.trust .t:nth-child(even){border-right:none}.trust .t:nth-last-child(-n+2){border-bottom:none}}
.trust .t b{display:block;font-family:"Satoshi",sans-serif;font-weight:700;font-size:15px;letter-spacing:-.01em;color:var(--navy)}
.trust .t span{font-size:13px;color:var(--ink-2)}

.incl{background:var(--canvas-2);border-bottom:1px solid var(--line-2)}
.incl .inner{padding:74px 0}
.incl h2{font-family:"Satoshi",sans-serif;font-weight:700;font-size:clamp(28px,3.6vw,42px);letter-spacing:-.03em;max-width:20ch;color:var(--navy)}
.incl .sub{margin-top:14px;color:var(--ink-2);font-size:16px;max-width:54ch}
.incl .grid4{margin-top:38px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:820px){.incl .grid4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.incl .grid4{grid-template-columns:1fr}}
.incl .it{background:var(--surface);border:1px solid var(--line-2);border-radius:18px;padding:24px 22px;box-shadow:var(--shadow-sm)}
.incl .it .n{font-family:"Satoshi",sans-serif;font-weight:900;font-size:15px;color:var(--blue);letter-spacing:-.02em}
.incl .it h4{font-family:"Satoshi";font-weight:700;font-size:16px;letter-spacing:-.01em;margin:12px 0 6px;color:var(--navy)}
.incl .it p{font-size:13.5px;color:var(--ink-2)}

section.block{padding:100px 0}
.head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:34px}
.head .eyebrow{display:block;margin-bottom:16px}
.head h2{font-family:"Satoshi",sans-serif;font-weight:700;font-size:clamp(32px,4.6vw,56px);line-height:1.0;letter-spacing:-.035em;max-width:16ch;color:var(--navy)}
.head .aside{color:var(--ink-2);font-size:15px;max-width:30ch;text-align:right;padding-bottom:8px}
@media(max-width:760px){.head{flex-direction:column;align-items:flex-start}.head .aside{text-align:left}}

.filterbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:42px}
.fbtn{font-family:"Satoshi",sans-serif;font-weight:700;font-size:13.5px;letter-spacing:-.01em;color:var(--ink-2);
  background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:10px 18px;cursor:pointer;transition:background .2s,color .2s,border-color .2s}
.fbtn:hover{border-color:var(--blue)}
.fbtn.active{background:var(--navy);color:var(--canvas);border-color:var(--navy)}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.grid{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .28s,box-shadow .28s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card.hide{display:none}
.ptile{position:relative;margin:14px 14px 0;border-radius:18px;overflow:hidden;aspect-ratio:1/1;
  background:radial-gradient(120% 92% at 50% 14%, #F0F4F9 0%, #DDE5F0 56%, #C7D3E4 100%);display:flex;align-items:center;justify-content:center}
.ptile .obj{width:82%;position:relative;z-index:1}
/* When a tile holds a photo, let it cover the whole tile edge to edge.
   The tile keeps overflow:hidden so the rounded corners still clip it.
   Illustration fallbacks (no img.pimg) keep their centred sizing. */
.ptile:has(img.pimg) .obj,
.tile:has(img.pimg) .obj{position:static;width:auto;padding:0;animation:none}
.ptile img.pimg,
.tile img.pimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ptile .no{position:absolute;z-index:2;top:14px;left:16px;font-family:"Satoshi",sans-serif;font-weight:900;font-size:26px;letter-spacing:-.04em;color:rgba(47,74,114,.4)}
.ptile .badge{position:absolute;z-index:2;top:16px;right:16px;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-deep);font-weight:700;
  border:1px solid rgba(47,74,114,.32);padding:5px 10px;border-radius:999px;background:rgba(248,245,238,.6)}
.card .body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:14px;flex:1}
.card .name{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.card .name h4{font-family:"Satoshi",sans-serif;font-weight:700;font-size:22px;letter-spacing:-.025em;color:var(--navy)}
.card .name .by{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:600;white-space:nowrap}
.card .desc{font-size:14px;color:var(--ink-2)}
.feat{display:flex;flex-direction:column;gap:0;margin-top:2px}
.feat .r{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px solid var(--line-2);font-size:13px}
.feat .r:last-child{border-bottom:none}
.feat .k{color:var(--ink-3)}.feat .v{font-weight:600;color:var(--ink);text-align:right}
.ship{font-size:12px;color:var(--ink-2);display:flex;align-items:center;gap:8px}
.ship .dot{width:6px;height:6px;border-radius:50%;background:var(--blue);flex:none}
.buy{border-top:1px solid var(--line);padding-top:16px;margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.buy .price{display:flex;flex-direction:column}
.buy .price .pe{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3);font-weight:700}
.buy .price .pv{font-family:"Satoshi",sans-serif;font-weight:700;font-size:17px;letter-spacing:-.02em;color:var(--navy)}
.order-btn{font-family:"Satoshi",sans-serif;font-weight:700;font-size:13.5px;letter-spacing:-.01em;padding:11px 20px;border-radius:999px;
  background:var(--navy);color:var(--canvas);border:none;cursor:pointer;transition:background .2s,transform .2s}
.order-btn:hover{background:var(--blue);transform:translateY(-2px)}

.ordering{background:var(--navy);color:var(--canvas)}
.ordering .head h2{color:var(--canvas)}.ordering .head .aside{color:rgba(236,231,221,.6)}.ordering .eyebrow{color:var(--blue-soft)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line-light);margin-top:36px}
@media(max-width:820px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}
.stp{padding:40px 28px 26px;border-right:1px solid var(--line-light)}
.stp:last-child{border-right:none}
@media(max-width:820px){.stp{border-bottom:1px solid var(--line-light)}.stp:nth-child(even){border-right:none}.stp:nth-last-child(-n+2){border-bottom:none}}
@media(max-width:480px){.stp{border-right:none}.stp:nth-child(odd){border-bottom:1px solid var(--line-light)}}
.stp .rn{font-family:"Satoshi",sans-serif;font-weight:900;font-size:28px;color:var(--blue-soft);letter-spacing:-.04em;margin-bottom:16px}
.stp h5{font-family:"Satoshi",sans-serif;font-weight:700;font-size:20px;letter-spacing:-.02em;margin-bottom:10px}
.stp p{font-size:14px;color:rgba(236,231,221,.72)}

.faq{max-width:860px;margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:24px 0;display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-family:"Satoshi",sans-serif;font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--navy)}
.qa .ic{font-family:"Satoshi";font-weight:500;font-size:24px;color:var(--blue);transition:transform .25s ease;flex:none;line-height:1}
.qa.open .ic{transform:rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .3s ease}
.qa .ans p{padding:0 0 24px;color:var(--ink-2);font-size:15.5px;max-width:70ch}
.qa.open .ans{max-height:360px}

.enq{background:var(--surface);border:1px solid var(--line-2);border-radius:30px;overflow:hidden;display:grid;grid-template-columns:.92fr 1.08fr;box-shadow:var(--shadow)}
@media(max-width:860px){.enq{grid-template-columns:1fr}}
.enq .left{padding:54px 46px;background:var(--canvas-2);border-right:1px solid var(--line)}
@media(max-width:860px){.enq .left{border-right:none;border-bottom:1px solid var(--line)}}
@media(max-width:860px){.enq .left,.enq .right{padding:40px 32px}}
@media(max-width:640px){.enq .left,.enq .right{padding:30px 22px}.enq{border-radius:22px}.detail{margin-top:24px}}
.enq .left .eyebrow{display:block;margin-bottom:18px}
.enq .left h3{font-family:"Satoshi",sans-serif;font-weight:700;font-size:clamp(30px,3.6vw,44px);line-height:1.04;letter-spacing:-.035em;color:var(--navy)}
.enq .left h3 b{color:var(--blue)}
.enq .left p{margin-top:18px;color:var(--ink-2);font-size:15px}
.detail{margin-top:32px;display:flex;flex-direction:column;gap:16px}
.detail .d{display:flex;gap:13px;align-items:flex-start}
.detail .d .ic{font-family:"Satoshi",sans-serif;font-weight:700;color:var(--blue);font-size:14px;min-width:22px;padding-top:2px}
.detail .d b{font-family:"Satoshi";font-weight:700;font-size:14px;letter-spacing:-.01em;color:var(--navy)}
.detail .d span{display:block;font-size:13.5px;color:var(--ink-2)}
.enq .right{padding:54px 46px}
.frm{display:grid;grid-template-columns:1fr 1fr;gap:26px 22px}
.frm .full{grid-column:1/-1}
@media(max-width:700px){.frm{grid-template-columns:1fr;gap:22px}}
.field label{display:block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:700;margin-bottom:9px}
.field input,.field select,.field textarea{width:100%;background:transparent;border:none;border-bottom:1.5px solid var(--line);
  color:var(--ink);font-family:"Inter",sans-serif;font-size:16px;padding:8px 2px;transition:border-color .2s}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-bottom-color:var(--blue)}
.field textarea{resize:vertical;min-height:70px}.field select{appearance:none;cursor:pointer}
.hp{position:absolute;left:-9999px}
.submit-row{grid-column:1/-1;display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:6px}
.submit{font-family:"Satoshi",sans-serif;font-weight:700;font-size:15px;letter-spacing:-.01em;padding:15px 34px;border-radius:999px;border:none;
  background:var(--navy);color:var(--canvas);cursor:pointer;transition:background .2s,transform .2s}
.submit:hover{background:var(--blue);transform:translateY(-2px)}
.submit-row .fn{font-size:12.5px;color:var(--ink-3);max-width:32ch}

footer{background:var(--navy-2);color:rgba(236,231,221,.72);padding:66px 0 54px}
.foot{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
footer .brand b{color:var(--canvas)}footer .brand small{color:rgba(236,231,221,.5)}
.disc{font-size:12.5px;color:rgba(236,231,221,.48);max-width:64ch;margin-top:22px;line-height:1.7}
.refs{font-size:13.5px;display:flex;flex-direction:column;gap:9px}
.refs .t{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-soft);font-weight:700;margin-bottom:4px}
.copy{margin-top:46px;padding-top:24px;border-top:1px solid var(--line-light);font-size:12.5px;color:rgba(236,231,221,.4)}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){*{animation:none!important}.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}.tile .obj{animation:none}}

/* ============================================================
   Responsive pass: tablet and phone spacing and tap targets.
   Desktop (above 900px) is unchanged.
   ============================================================ */
/* Touch targets at least 44px tall on tablet and phone widths */
@media(max-width:1024px){
  .fbtn,.order-btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
  /* Restore the side gutter the .incl .inner padding override removes (desktop above 1024 keeps its full bleed) */
  .incl .inner{padding:74px 32px}
}
@media(max-width:900px){
  section.block{padding:72px 0}
  .incl .inner{padding:58px 32px}
  .order-btn{padding:12px 22px}
}
@media(max-width:640px){
  .wrap{padding:0 20px}
  /* Body text reads like a phone page, not a zoomed-in one */
  body{font-size:16px;line-height:1.5}
  section.block{padding:46px 0}
  /* Restore the side gutter the .incl .inner override removes, and tighten vertical padding */
  .incl .inner{padding:38px 20px}

  /* Headings: smaller and tighter so a two line heading does not dominate */
  h1{font-size:34px;line-height:1.08}
  .head h2{font-size:27px;line-height:1.12}
  .incl h2{font-size:26px;line-height:1.15;margin-top:10px}
  .head{margin-bottom:22px;gap:10px}

  /* Body and supporting text */
  .lede{font-size:16px;line-height:1.5;margin-top:18px}
  .incl .sub{font-size:15px;line-height:1.5;margin-top:10px}
  .qa .ans p{font-size:15px;line-height:1.5}
  .stp p{font-size:14px;line-height:1.5}

  /* Inner padding: content sits comfortably, not swimming in space */
  .incl .it{padding:18px 18px}
  .incl .grid4{margin-top:24px;gap:12px}
  .card .body{padding:18px 18px 20px;gap:11px}
  .ptile{margin:12px 12px 0}
  .qa button{padding:16px 0;font-size:17px;gap:14px}

  /* Gaps between stacked blocks: a tight list, not long empty scrolls */
  .grid{gap:16px}
  .filterbar{gap:8px;margin-bottom:24px}

  .trust .t{padding:18px 16px}
  .stp{padding:26px 20px 22px}
  footer{padding:44px 0 36px}
  .foot{gap:24px}
  .copy{margin-top:28px}

  /* Keep filter chips comfortably tappable */
  .fbtn{padding:11px 16px}
}

/* Footer legal links */
.refs a{transition:color .2s}
.refs a:hover{color:var(--blue-soft)}

/* Legal pages (privacy, terms, returns): simple readable text layout */
.legal{padding:60px 0 84px}
.legal .col{max-width:780px}
.legal .eyebrow{display:block;margin-bottom:14px}
.legal h1{font-family:"Satoshi",sans-serif;font-weight:700;font-size:clamp(32px,4.6vw,48px);line-height:1.05;letter-spacing:-.035em;color:var(--navy)}
.legal .updated{font-size:13.5px;color:var(--ink-3);margin:10px 0 6px}
.legal h2{font-family:"Satoshi",sans-serif;font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--navy);margin:34px 0 8px}
.legal p{color:var(--ink-2);font-size:16px;line-height:1.7;margin:0 0 14px;max-width:74ch}
.legal a{color:var(--blue);text-decoration:underline}
@media(max-width:640px){.legal{padding:44px 0 60px}.legal h2{margin-top:28px}}
