
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;overflow-x:hidden;background:var(--bg);color:var(--ink);
  font-family:var(--font);font-size:clamp(16px,1rem + .15vw,17.5px);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,p,ul,ol,figure{margin:0}
ul,ol{padding:0;list-style:none}
a{color:inherit;text-decoration:none}
img,svg,canvas,video{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.ico{width:1.2em;height:1.2em;flex:0 0 auto}
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip{position:absolute;left:12px;top:-60px;z-index:200;background:var(--accent);
  color:#fff;padding:10px 16px;border-radius:8px;transition:top .2s}
.skip:focus{top:12px}
.wrap{width:100%;max-width:var(--maxw,1140px);margin-inline:auto;
  padding-inline:clamp(18px,5vw,40px)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:.85em 1.4em;border:1px solid transparent;border-radius:var(--btn-r,12px);
  font-weight:600;line-height:1;cursor:pointer;text-align:center;
  transition:transform .18s ease,box-shadow .25s ease,background .25s ease,border-color .25s ease;
  will-change:transform}
.btn--sm{padding:.6em 1em;font-size:.92rem}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn .ico{width:1.05em;height:1.05em}

/* header */
.site{position:sticky;top:0;z-index:60;background:var(--header-bg);
  backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--header-line);transition:box-shadow .3s,background .3s,border-color .3s}
.site.is-scrolled{box-shadow:0 10px 40px -22px var(--shadow)}
.site__row{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:66px}
.brand{display:inline-flex;align-items:baseline;font-weight:800;letter-spacing:.01em;font-size:1.22rem}
.brand__mark{display:inline-flex;align-items:center;justify-content:center;color:var(--accent)}
.brand__word{color:var(--ink)}
.nav{display:flex;align-items:center;gap:clamp(6px,1.4vw,22px)}
.nav__link{position:relative;padding:.5em .2em;font-weight:500;color:var(--muted);
  transition:color .2s}
.nav__link::after{content:"";position:absolute;left:.2em;right:.2em;bottom:.15em;height:2px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.nav__link:hover,.nav__link.is-active{color:var(--ink)}
.nav__link:hover::after,.nav__link.is-active::after{transform:scaleX(1)}
.site__cta{display:flex;align-items:center;gap:12px}
.langswitch{display:inline-flex;align-items:center;justify-content:center;width:38px;height:34px;
  border:1px solid var(--line);border-radius:8px;font-size:.78rem;font-weight:700;color:var(--muted);
  letter-spacing:.04em;transition:color .2s,border-color .2s}
.langswitch:hover{color:var(--ink);border-color:var(--accent)}
.burger{display:none;width:42px;height:38px;border:1px solid var(--line);border-radius:10px;
  background:transparent;position:relative;cursor:pointer}
.burger span:not(.vh){position:absolute;left:9px;right:9px;height:2px;background:var(--ink);
  border-radius:2px;transition:transform .25s,opacity .2s}
.burger span:nth-child(1){top:12px}.burger span:nth-child(2){top:18px}.burger span:nth-child(3){top:24px}
.site[data-open] .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.site[data-open] .burger span:nth-child(2){opacity:0}
.site[data-open] .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

@media (max-width:900px){
  .nav{position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;
    gap:2px;padding:14px clamp(18px,5vw,40px) 22px;background:var(--header-bg);
    border-bottom:1px solid var(--header-line);
    backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:.28s ease;
    box-shadow:0 24px 50px -28px var(--shadow)}
  .site[data-open] .nav{transform:none;opacity:1;visibility:visible}
  .nav__link{padding:.85em .2em;font-size:1.05rem;border-bottom:1px solid var(--header-line)}
  .nav__link::after{display:none}
  .burger{display:block}
  .site__cta .btn{display:none}
}

/* sections */
.sec{padding:clamp(56px,8vw,108px) 0}
.sec--page-head{padding-top:clamp(48px,7vw,84px);padding-bottom:clamp(20px,3vw,32px)}
.sec__head{max-width:min(640px,100%);margin-bottom:clamp(28px,4vw,52px)}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-size:.8rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1em}
.sec__title{font-size:clamp(1.7rem,1.1rem + 2.4vw,2.7rem);line-height:1.1;letter-spacing:-.02em;
  font-family:var(--display,var(--font))}
.sec__lead{margin-top:.8em;color:var(--muted);font-size:1.08rem;max-width:54ch}

/* generic grids */
.grid{display:grid;gap:clamp(14px,1.6vw,22px)}
.grid--cards{grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr))}
.grid--proj{grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr))}
.grid--posts{grid-template-columns:repeat(auto-fit,minmax(min(100%,270px),1fr))}
.grid--posts-2{grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr))}

/* service card */
.card{position:relative;display:flex;flex-direction:column;gap:.55em;padding:clamp(20px,2.4vw,30px);
  background:var(--panel);border:1px solid var(--line);border-radius:var(--card-r,16px);
  color:var(--ink);overflow:hidden;transition:transform .28s ease,box-shadow .3s ease,border-color .3s ease}
.card__num{font-size:.78rem;font-weight:700;letter-spacing:.1em;color:var(--muted);opacity:.7}
.card__ico{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;
  border-radius:12px;color:var(--accent);background:var(--accent-soft);margin:.1em 0 .2em}
.card__ico .ico{width:24px;height:24px}
.card__h{font-size:1.2rem;letter-spacing:-.01em}
.card__p{color:var(--muted);font-size:.98rem}
.card__go{margin-top:auto;display:inline-flex;align-items:center;gap:.4em;font-weight:600;
  color:var(--accent);font-size:.92rem;padding-top:.6em}
.card__go .ico{transition:transform .25s}
.card:hover{transform:translateY(-4px);border-color:var(--accent)}
.card:hover .card__go .ico{transform:translateX(4px)}

/* process steps */
.steps{display:grid;gap:clamp(10px,1.4vw,16px);counter-reset:s}
@media(min-width:760px){.steps{grid-template-columns:repeat(5,1fr)}}
.step{display:flex;gap:14px;align-items:flex-start;padding:clamp(16px,2vw,22px);
  background:var(--panel);border:1px solid var(--line);border-radius:var(--card-r,16px)}
@media(min-width:760px){.step{flex-direction:column}}
.step__n{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;flex:none;
  border-radius:50%;background:var(--accent);color:var(--on-accent,#fff);font-weight:700}
.step__h{font-size:1.05rem;margin-bottom:.25em}
.step__p{color:var(--muted);font-size:.92rem}

/* proof */
.proof{display:flex;flex-direction:column;gap:clamp(18px,2.4vw,28px)}
.proof__title{font-size:clamp(1.3rem,1rem + 1.4vw,1.9rem);font-family:var(--display,var(--font));letter-spacing:-.01em}
.proof__list{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr))}
.proof__item{display:flex;align-items:center;gap:.6em;padding:.9em 1.1em;background:var(--panel);
  border:1px solid var(--line);border-radius:var(--card-r,14px);font-weight:600;font-size:.98rem}
.proof__dot{width:9px;height:9px;border-radius:50%;background:var(--accent);flex:none;box-shadow:0 0 0 4px var(--accent-soft)}

/* projects */
.proj{display:flex;flex-direction:column;gap:.6em;padding:clamp(22px,2.6vw,30px);
  background:var(--panel);border:1px solid var(--line);border-radius:var(--card-r,16px);
  transition:transform .28s,border-color .3s}
.proj:hover{transform:translateY(-4px);border-color:var(--accent)}
.proj__tag{align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);background:var(--accent-soft);padding:.4em .8em;border-radius:999px}
.proj__h{font-size:1.22rem;letter-spacing:-.01em}
.proj__p{color:var(--muted);font-size:.97rem}

/* posts */
.post{display:flex;flex-direction:column;gap:.5em;padding:clamp(20px,2.4vw,28px);
  background:var(--panel);border:1px solid var(--line);border-radius:var(--card-r,16px);color:var(--ink);
  transition:transform .28s,border-color .3s}
.post:hover{transform:translateY(-4px);border-color:var(--accent)}
.post__kick{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.post__h{font-size:1.2rem;letter-spacing:-.01em}
.post__p{color:var(--muted);font-size:.96rem}
.post__go{margin-top:auto;display:inline-flex;align-items:center;gap:.4em;font-weight:600;color:var(--accent);padding-top:.5em}
.post--mini{min-height:120px;justify-content:center}

/* faq */
.faq{display:grid;gap:clamp(20px,3vw,40px)}
@media(min-width:820px){.faq{grid-template-columns:.7fr 1fr;align-items:start}}
.faq__list{display:flex;flex-direction:column;gap:10px}
.faq__item{background:var(--panel);border:1px solid var(--line);border-radius:var(--card-r,14px);
  padding:2px 18px;overflow:hidden}
.faq__item summary{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:1.05em 0;font-weight:600;cursor:pointer;list-style:none}
.faq__item summary::-webkit-details-marker{display:none}
.faq__plus{position:relative;width:16px;height:16px;flex:none}
.faq__plus::before,.faq__plus::after{content:"";position:absolute;background:var(--accent);border-radius:2px;
  transition:transform .25s}
.faq__plus::before{left:0;right:0;top:7px;height:2px}
.faq__plus::after{top:0;bottom:0;left:7px;width:2px}
.faq__item[open] .faq__plus::after{transform:scaleY(0)}
.faq__item p{padding:0 0 1.1em;color:var(--muted)}

/* CTA band */
.band{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;
  padding:clamp(28px,4vw,48px);background:var(--band-bg);border:1px solid var(--band-line);
  border-radius:calc(var(--card-r,16px) + 6px);overflow:hidden;position:relative}
.band__h{font-size:clamp(1.4rem,1rem + 1.7vw,2.1rem);font-family:var(--display,var(--font));
  letter-spacing:-.01em;color:var(--band-ink,var(--ink));max-width:22ch}
.band__p{margin-top:.5em;color:var(--band-muted,var(--muted));max-width:42ch}
.band .hero__cta{margin-top:0}

/* page head + legal + article */
.page-head{max-width:min(760px,100%)}
.page-head__h1{font-size:clamp(2rem,1.3rem + 3vw,3.4rem);line-height:1.05;letter-spacing:-.025em;
  font-family:var(--display,var(--font));margin:.2em 0 .35em}
.page-head__lead{color:var(--muted);font-size:1.12rem;max-width:60ch}
.legal{display:grid;gap:22px;max-width:min(760px,100%)}
.legal__b h2{font-size:1.2rem;margin-bottom:.4em}
.legal__b p{color:var(--muted)}
.article{max-width:min(720px,100%)}
.back{display:inline-flex;align-items:center;gap:.5em;color:var(--muted);font-weight:600;font-size:.92rem;margin-bottom:1.4em}
.back .ico{transform:rotate(180deg)}
.back:hover{color:var(--accent)}
.article__h1{font-size:clamp(1.9rem,1.3rem + 2.6vw,3rem);line-height:1.08;letter-spacing:-.02em;
  font-family:var(--display,var(--font));margin:.2em 0 .5em}
.article__lead{font-size:1.18rem;color:var(--ink);margin-bottom:1.4em}
.article__body{display:grid;gap:1.1em;color:var(--muted);font-size:1.06rem}
.article__body p{max-width:68ch}

/* contact */
.contact{display:grid;gap:clamp(22px,3vw,40px)}
@media(min-width:860px){.contact{grid-template-columns:1.2fr .8fr;align-items:start}}
.form{display:grid;gap:16px;padding:clamp(22px,3vw,34px);background:var(--panel);
  border:1px solid var(--line);border-radius:calc(var(--card-r,16px) + 4px)}
.field{display:grid;gap:.4em}
.field label{font-weight:600;font-size:.92rem}
.field input,.field textarea{width:100%;padding:.8em 1em;background:var(--input-bg);color:var(--ink);
  border:1px solid var(--line);border-radius:var(--btn-r,10px);font:inherit;transition:border-color .2s,box-shadow .2s}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.form__note{font-size:.86rem;color:var(--muted)}
.form__note.is-sent{color:var(--accent);font-weight:600}
.contact__side{padding:clamp(22px,3vw,34px);background:var(--accent-soft);border:1px solid var(--line);
  border-radius:calc(var(--card-r,16px) + 4px)}
.contact__side h2{font-size:1.3rem;margin-bottom:.4em}
.contact__list{display:grid;gap:.6em;margin:1.1em 0}
.contact__list li{display:flex;align-items:center;gap:.6em;color:var(--ink);font-size:.96rem}
.contact__list .ico{color:var(--accent)}
.contact__confirm{font-size:.84rem;color:var(--muted);border-top:1px solid var(--line);padding-top:1em}

/* hero shared bits */
.hero{position:relative;overflow:hidden}
.hero__copy,.hero__stage,.hero__inner,.hero__grid>*{min-width:0}
.hero__h1,.sec__title,.page-head__h1,.article__h1,.proof__title,.band__h{overflow-wrap:break-word}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:1.6em}
.hero__proof{display:flex;flex-wrap:wrap;gap:.5em 1.4em;margin-top:1.8em}
.hero__proof li{display:inline-flex;align-items:center;gap:.5em;color:var(--muted);font-size:.92rem;font-weight:500}
.hero__proof .ico{color:var(--accent);width:1.05em;height:1.05em}

/* footer */
.foot{background:var(--foot-bg);border-top:1px solid var(--line);color:var(--foot-ink,var(--ink))}
.foot__grid{display:grid;gap:clamp(26px,4vw,48px);padding:clamp(44px,6vw,72px) 0 clamp(28px,3vw,40px)}
@media(min-width:780px){.foot__grid{grid-template-columns:1.4fr .8fr 1fr}}
.foot__tag{color:var(--muted);margin-top:1em;max-width:36ch}
.foot__note{color:var(--muted);opacity:.8;font-size:.84rem;margin-top:1em;max-width:40ch}
.foot__h{font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1em}
.foot__nav ul{display:grid;gap:.6em}
.foot__nav a{color:var(--foot-ink,var(--ink));opacity:.85}
.foot__nav a:hover{opacity:1;color:var(--accent)}
.foot__cta p{color:var(--muted);margin-bottom:1.2em;max-width:34ch}
.foot__bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;
  padding:18px 0 28px;border-top:1px solid var(--line);font-size:.85rem;color:var(--muted)}
.foot__demo{opacity:.8}
.brand--foot{font-size:1.3rem}

/* reveal */
.reveal{opacity:0;transform:translateY(20px);
  transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--i,0)*55ms)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.card:hover,.proj:hover,.post:hover{transform:none}
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
}


:root{
  --font:"Segoe UI",-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
  --display:Georgia,"Times New Roman",ui-serif,serif;
  --maxw:1100px;
  --bg:#f4efe6;--panel:#fbf8f1;--ink:#1a1610;--muted:#6d6256;--line:#ddd2c1;
  --accent:#312e81;--accent-2:#9a3412;--accent-soft:#ece9f6;--on-accent:#fff;
  --header-bg:rgba(246,241,233,.82);--header-line:#ddd2c1;--shadow:rgba(60,45,25,.35);
  --band-bg:#1a1610;--band-line:#1a1610;--band-ink:#f6efe2;--band-muted:#c5b8a4;
  --foot-bg:#efe8db;--foot-ink:#1a1610;--input-bg:#fffdf8;--btn-r:3px;--card-r:5px;
}
body{background:var(--bg)}
.eyebrow{color:var(--accent-2);letter-spacing:.2em;font-weight:700}
.nav__link{font-size:.86rem;letter-spacing:.04em}
.btn--primary{background:var(--accent);color:#fff;border-radius:3px}
.btn--primary:hover{background:#272563}
.btn--ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--bg)}
.btn{font-weight:600;letter-spacing:.01em}

.hero--editorial{padding:clamp(56px,8vw,120px) 0 0}
.hero--editorial .hero__inner{max-width:min(960px,100%)}
.hero--editorial .hero__h1{font-family:var(--display);font-weight:700;
  font-size:clamp(2.7rem,1.4rem + 7vw,6rem);line-height:1.0;letter-spacing:-.025em;margin:.18em 0 0}
.hero--editorial .hero__h1 span{box-shadow:inset 0 -.06em 0 var(--accent-soft)}
.hero__row{display:grid;gap:24px;margin-top:clamp(26px,4vw,46px);align-items:end}
@media(min-width:780px){.hero__row{grid-template-columns:1fr auto}}
.hero--editorial .hero__lead{font-size:clamp(1.15rem,1rem + .8vw,1.5rem);color:var(--ink);max-width:30ch;
  border-left:3px solid var(--accent-2);padding-left:1em}
.hero--editorial .hero__cta{margin-top:0}
.hero__rule{height:1px;background:var(--line);margin-top:clamp(40px,6vw,72px)}
.sec__title,.page-head__h1,.article__h1,.band__h,.proof__title{font-weight:700}
.card{box-shadow:none}
.card__num{font-family:var(--display);font-size:1.5rem;font-weight:700;color:var(--accent);opacity:.5}
.card__ico{background:transparent;color:var(--accent);width:40px;height:40px;
  border:1px solid var(--line);border-radius:50%}
.card:hover{border-color:var(--accent);box-shadow:0 24px 50px -40px var(--shadow)}
.card__h{font-family:var(--display)}
.proj__h,.post__h{font-family:var(--display)}
.proj__tag{background:transparent;border:1px solid var(--line);color:var(--accent-2);border-radius:3px}
.step__n{font-family:var(--display);background:transparent;color:var(--accent);
  border:1px solid var(--accent);width:40px;height:40px;font-size:1.1rem}
.proof__item{border-radius:3px}
.faq__item summary{font-family:var(--display);font-size:1.08rem}
.band__p{color:var(--band-muted)}
.foot__h{color:var(--accent-2)}
.article__body p:first-letter{font-family:var(--display)}
