/* ABC IT Lab — warm, document-like, deliberately plain. Type does the work. */
:root{
  --paper:#f4f1e9; --card:#fcfbf6; --ink:#1c1812; --ink-2:#5b5447;
  --line:#ddd6c5; --line-2:#cfc7b2; --acc:#14524d; --acc-d:#0e3b37;
  --sans:"IBM Plex Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --w:1080px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);
  font:400 17px/1.62 var(--sans);font-feature-settings:"kern","liga"}
a{color:var(--acc);text-decoration:none}
a:hover{color:var(--acc-d);text-decoration:underline;text-underline-offset:3px}
h1,h2,h3{letter-spacing:-.018em;font-weight:600}
hr{border:0;border-top:1px solid var(--line);margin:0}

/* ---- header ---- */
.nav{max-width:var(--w);margin:0 auto;padding:24px 34px;
  display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:inline-flex;align-items:center;gap:9px;
  font:600 17px/1 var(--sans);color:var(--ink);letter-spacing:-.01em}
.brand:hover{text-decoration:none;color:var(--ink)}
.brand .tile{font:500 12.5px/1 var(--mono);letter-spacing:.02em;color:var(--acc);
  border:1.5px solid var(--acc);border-radius:3px;padding:3px 7px}
.nav nav{display:flex;align-items:center;gap:24px}
.nav nav a{font:400 13.5px/1 var(--mono);color:var(--ink-2);letter-spacing:.01em}
.nav nav a:hover{color:var(--ink);text-decoration:none}
.cta{border:1.5px solid var(--ink);padding:8px 13px;color:var(--ink)!important;border-radius:3px}
.cta:hover{background:var(--ink);color:var(--paper)!important}

/* ---- hero ---- */
.hero{max-width:var(--w);margin:0 auto;padding:60px 34px 30px;
  display:grid;grid-template-columns:1.7fr .9fr;gap:52px;align-items:start}
.eyebrow{font:500 12.5px/1.5 var(--mono);letter-spacing:.18em;text-transform:uppercase;
  color:var(--acc);margin:0 0 22px}
.hero h1{font-size:clamp(33px,4.7vw,55px);line-height:1.04;margin:0 0 24px;max-width:15ch}
.lede{font-size:19px;line-height:1.56;color:var(--ink-2);max-width:48ch;margin:0}
.actions{margin-top:30px;display:flex;flex-wrap:wrap;gap:12px}
.btn{display:inline-block;font:500 14px/1 var(--mono);padding:13px 19px;border:1.5px solid var(--ink);
  background:var(--ink);color:var(--paper);border-radius:3px}
.btn:hover{background:transparent;color:var(--ink);text-decoration:none}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}

/* fact-sheet aside */
.facts{margin:6px 0 0;border-top:2px solid var(--ink);font:400 13px/1.45 var(--mono)}
.facts>div{display:grid;grid-template-columns:88px 1fr;gap:14px;padding:11px 0;border-bottom:1px solid var(--line)}
.facts dt{color:var(--ink-2)}
.facts dd{margin:0;color:var(--ink)}

/* ---- numbered sections ---- */
.seclabel{max-width:var(--w);margin:46px auto 0;padding:0 34px;
  font:500 12.5px/1.5 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2)}
.svclist{max-width:var(--w);margin:14px auto 0;padding:0 34px}
.svc{display:grid;grid-template-columns:46px 1fr;gap:20px;padding:24px 0;border-top:1px solid var(--line)}
.svc:last-child{border-bottom:1px solid var(--line)}
.svc .num{font:400 14px/1.6 var(--mono);color:var(--acc)}
.svc h3{margin:0 0 7px;font-size:19px}
.svc p{margin:0;color:var(--ink-2);max-width:64ch}

/* ---- "как мы работаем" two-col note ---- */
.note{max-width:var(--w);margin:54px auto 0;padding:34px 34px;
  display:grid;grid-template-columns:46px 1fr;gap:20px;border-top:1px solid var(--line)}
.note .num{font:400 14px/1.6 var(--mono);color:var(--acc)}
.note h2{margin:0 0 12px;font-size:23px}
.note p{margin:0;color:var(--ink-2);max-width:66ch}

/* ---- inner pages ---- */
.page{max-width:var(--w);margin:0 auto;padding:54px 34px 20px}
.page>.eyebrow{margin-bottom:14px}
.page h1{font-size:clamp(30px,4vw,44px);line-height:1.06;margin:0 0 22px;max-width:18ch}
.page p{color:var(--ink-2);max-width:70ch}
.page p.lead{font-size:19px;color:var(--ink);max-width:62ch}
.page b{color:var(--ink);font-weight:600}
.deflist{list-style:none;margin:30px 0 0;padding:0;max-width:74ch}
.deflist li{padding:20px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:46px 1fr;gap:20px}
.deflist li:last-child{border-bottom:1px solid var(--line)}
.deflist .num{font:400 14px/1.6 var(--mono);color:var(--acc)}
.deflist b{display:block;margin-bottom:5px}
.deflist span{color:var(--ink-2)}

/* ---- contact form ---- */
.form{background:var(--card);border:1px solid var(--line);border-radius:4px;padding:28px;max-width:560px;margin:30px 0 0}
.form h2{margin:0 0 16px;font-size:18px}
.form label{display:block;margin:14px 0;font:500 12px/1.4 var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2)}
.form input,.form textarea{display:block;width:100%;margin-top:7px;padding:11px 13px;
  background:var(--paper);border:1px solid var(--line-2);border-radius:3px;color:var(--ink);
  font:400 16px/1.5 var(--sans)}
.form input:focus,.form textarea:focus{outline:2px solid var(--acc);outline-offset:1px;border-color:var(--acc)}
.form .captcha{text-transform:none;font-family:var(--sans);font-size:14px;letter-spacing:0;color:var(--ink)}
.form .captcha b{font-family:var(--mono)}
.form .captcha input{display:inline-block;width:110px;margin-top:9px}
.form button{margin-top:18px;padding:13px 22px;background:var(--ink);color:var(--paper);
  border:1.5px solid var(--ink);border-radius:3px;font:500 14px/1 var(--mono);cursor:pointer}
.form button:hover{background:transparent;color:var(--ink)}
.formmsg{padding:12px 14px;border-radius:3px;margin:0 0 14px;font-size:14px}
.formmsg.ok{background:#e7efe5;border:1px solid #5f8c63;color:#244a2c}
.formmsg.err{background:#f1e1dc;border:1px solid #b06a58;color:#6c2a1c}
.muted{color:var(--ink-2);font-size:14px}

/* ---- footer ---- */
footer{border-top:1px solid var(--line);margin-top:60px}
.foot{max-width:var(--w);margin:0 auto;padding:38px 34px 70px;
  display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:28px;
  font:400 12.5px/1.7 var(--mono);color:var(--ink-2)}
.foot a{color:var(--ink-2)}.foot a:hover{color:var(--ink)}
.foot h4{margin:0 0 10px;font:500 11px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.foot .col p{margin:0 0 4px}
.foot .status::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;
  background:#3f8c52;margin-right:7px;vertical-align:middle}
.foot .legal{grid-column:1/-1;border-top:1px solid var(--line);padding-top:18px;margin-top:6px;color:var(--line-2)}

/* ---- responsive ---- */
@media (max-width:760px){
  .nav{flex-wrap:wrap;gap:14px;padding:18px 22px}
  .nav nav{width:100%;flex-wrap:wrap;gap:8px 18px}
  .hero{grid-template-columns:1fr;gap:34px;padding:38px 22px 22px}
  .seclabel,.svclist,.note,.page,.foot{padding-left:22px;padding-right:22px}
  .note{grid-template-columns:1fr;gap:8px}
  .note .num{display:none}
  .foot{grid-template-columns:1fr 1fr}
}
@media (max-width:440px){
  .foot{grid-template-columns:1fr}
  .actions .btn{flex:1 1 100%;text-align:center}
}
