/* ============================================================
   TakumiDevelopment — 匠
   Японская эстетика · две темы (бело-розовая / черно-розовая)
   ============================================================ */

/* ---------- ТОКЕНЫ ТЕМ ---------- */
:root[data-theme="paper"]{
  --bg:        #f8eef0;
  --bg-2:      #f1e1e4;
  --panel:     #fffafb;
  --ink:       #1a1115;
  --ink-soft:  rgba(26,17,21,.60);
  --ink-faint: rgba(26,17,21,.30);
  --line:      rgba(26,17,21,.14);
  --line-2:    rgba(26,17,21,.28);
  --pink:      #de5c89;
  --pink-2:    #f29bb8;
  --seal:      #cf3457;
  --shadow:    rgba(26,17,21,.92);
  --petal-a:   #f6b8cd;
  --petal-b:   #ec88ab;
  --canvas-op: .9;
  --photo-op:  .30;
}
:root[data-theme="ink"]{
  --bg:        #0e090c;
  --bg-2:      #150d11;
  --panel:     #170f13;
  --ink:       #f7e9ef;
  --ink-soft:  rgba(247,233,239,.62);
  --ink-faint: rgba(247,233,239,.28);
  --line:      rgba(247,233,239,.14);
  --line-2:    rgba(247,233,239,.30);
  --pink:      #ff7bac;
  --pink-2:    #ff9ec3;
  --seal:      #ff5c8a;
  --shadow:    rgba(0,0,0,.85);
  --petal-a:   #ff9cc1;
  --petal-b:   #ff6fa6;
  --canvas-op: .85;
  --photo-op:  .24;
}

:root{
  --font-display:'Shippori Mincho B1', serif;
  --font-body:'Zen Kaku Gothic Antique', system-ui, sans-serif;
  --font-brush:'Yuji Syuku', serif;
  --maxw: 1180px;
  --pad: clamp(20px, 5vw, 64px);
  --seigaiha: color-mix(in srgb, var(--pink) 14%, transparent);
}

/* ---------- БАЗА ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .6s ease, color .6s ease;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
strong{font-weight:700;color:var(--pink)}
em{font-style:normal}
::selection{background:var(--pink);color:#fff}

/* ---------- ФОН: канвас сакуры + зерно ---------- */
#sakura{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:0; pointer-events:none; opacity:var(--canvas-op);
  transition:opacity .6s ease;
}
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.05; mix-blend-mode:multiply;
  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)'/%3E%3C/svg%3E");
}
:root[data-theme="ink"] .grain{mix-blend-mode:screen;opacity:.04}

/* всё содержимое над фоном */
.site-head, main, .site-foot{position:relative; z-index:2}

/* ---------- ШАПКА ---------- */
.site-head{
  position:fixed; top:0; left:0; right:0;
  display:flex; align-items:center; gap:24px;
  padding:16px var(--pad);
  z-index:50;
  background:color-mix(in srgb, var(--bg) 72%, transparent);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
  transition:background .6s ease, border-color .6s ease;
}
.brand{display:flex; align-items:center; gap:12px; margin-right:auto}
.brand__seal{
  display:grid; place-items:center;
  width:40px; height:40px; flex:none;
  font-family:var(--font-display); font-weight:800; font-size:22px;
  color:#fff; background:var(--seal);
  clip-path:polygon(0 0,100% 0,100% 78%,78% 100%,0 100%);
  box-shadow:3px 3px 0 var(--ink);
}
.brand__name{display:flex; flex-direction:column; line-height:1}
.brand__name-main{
  font-family:var(--font-display); font-weight:800;
  font-size:20px; letter-spacing:.18em;
}
.brand__name-sub{
  font-size:9.5px; letter-spacing:.42em;
  color:var(--ink-soft); margin-top:3px; padding-left:2px;
}

.nav{display:flex; gap:30px}
.nav a{
  font-size:13.5px; letter-spacing:.04em; color:var(--ink-soft);
  display:inline-flex; align-items:center; gap:7px;
  padding:6px 0; position:relative; transition:color .3s;
}
.nav__num{font-family:var(--font-display); color:var(--pink); font-size:12px}
.nav a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--pink); transition:width .35s ease;
}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:100%}

.theme-toggle{
  flex:none; width:42px; height:42px; cursor:pointer;
  display:grid; place-items:center; color:var(--ink);
  background:transparent; border:1px solid var(--line-2);
  clip-path:polygon(16% 0,100% 0,100% 84%,84% 100%,0 100%,0 16%);
  transition:transform .3s, color .3s, border-color .3s;
}
.theme-toggle:hover{color:var(--pink); border-color:var(--pink); transform:rotate(8deg)}
.ico-moon{display:none}
:root[data-theme="ink"] .ico-sun{display:none}
:root[data-theme="ink"] .ico-moon{display:block}

/* ---------- HERO ---------- */
.hero{
  min-height:100svh;
  display:flex; flex-direction:column; justify-content:center;
  padding:140px var(--pad) 90px;
  position:relative; overflow:hidden; isolation:isolate;
}
/* фоновое фото Японии (дуотон, лепестки просвечивают сквозь него) */
.hero__photo{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:url("assets/jp-hero.jpg") center 28%/cover no-repeat;
  filter:grayscale(.35) saturate(1.05) contrast(1.02);
  opacity:var(--photo-op);
}
.hero::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(72% 60% at 80% 20%, color-mix(in srgb, var(--pink) 32%, transparent), transparent 72%),
    linear-gradient(to bottom, transparent 0 36%, var(--bg) 90%),
    linear-gradient(to right, var(--bg), transparent 46%);
}
.hero__kanji{
  position:absolute; right:-4vw; top:46%; transform:translateY(-50%); z-index:2;
  font-family:var(--font-display); font-weight:800;
  font-size:min(72vh,640px); line-height:.8;
  color:var(--pink); opacity:.10; pointer-events:none; user-select:none;
  mix-blend-mode:multiply;
}
:root[data-theme="ink"] .hero__kanji{mix-blend-mode:screen}
.hero__inner{max-width:var(--maxw); width:100%; margin:0 auto; position:relative; z-index:3}

.kicker{
  display:flex; align-items:center; gap:16px;
  font-size:12px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--ink-soft); margin:0 0 26px;
}
.kicker__line{width:46px; height:1px; background:var(--pink)}
.brush{
  font-family:var(--font-brush); letter-spacing:.1em; text-transform:none;
  color:var(--pink); font-size:17px;
}

.hero__title{
  font-family:var(--font-display); font-weight:800;
  font-size:clamp(52px, 13.5vw, 188px);
  line-height:.92; letter-spacing:-.01em; margin:0;
}
.hero__title-row{display:block}
.hero__title-row--outline{
  color:transparent;
  -webkit-text-stroke:1.5px var(--ink);
  text-stroke:1.5px var(--ink);
  letter-spacing:.02em;
  font-size:clamp(30px, 7.6vw, 104px);
}

.hero__lead{
  max-width:540px; font-size:clamp(15px,1.7vw,19px);
  color:var(--ink-soft); margin:30px 0 38px; line-height:1.75;
}
.hero__cta{display:flex; flex-wrap:wrap; gap:16px}

.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-weight:700; font-size:15px;
  letter-spacing:.02em; padding:15px 30px; cursor:pointer;
  transition:transform .25s, box-shadow .25s, background .3s, color .3s;
}
.btn--solid{
  background:var(--pink); color:#fff;
  clip-path:polygon(0 0,100% 0,100% 70%,93% 100%,0 100%);
  box-shadow:5px 5px 0 var(--ink);
}
.btn--solid:hover{transform:translate(-2px,-2px); box-shadow:8px 8px 0 var(--ink)}
.btn--solid svg{transition:transform .25s}
.btn--solid:hover svg{transform:translateX(4px)}
.btn--ghost{
  border:1px solid var(--line-2); color:var(--ink);
  clip-path:polygon(7% 0,100% 0,100% 100%,0 100%,0 30%);
}
.btn--ghost:hover{border-color:var(--pink); color:var(--pink); transform:translateY(-2px)}

.scroll-cue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:var(--font-brush); font-size:13px; letter-spacing:.2em;
  color:var(--ink-soft);
}
.scroll-cue__line{width:1px; height:46px; background:linear-gradient(var(--pink),transparent); animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- ОБЩЕЕ ДЛЯ СЕКЦИЙ ---------- */
.band{
  position:relative; max-width:var(--maxw);
  margin:0 auto; padding:clamp(80px,11vw,150px) var(--pad);
}
.band + .band{border-top:1px solid var(--line)}
/* фоновый паттерн «сэйгайха» (волны) — лёгкая текстура секций */
.band::before{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background-image:
    radial-gradient(circle at 50% 50%, transparent 24%, var(--seigaiha) 24% 26.5%, transparent 26.5% 48%, var(--seigaiha) 48% 50.5%, transparent 50.5% 72%, var(--seigaiha) 72% 74.5%, transparent 74.5%),
    radial-gradient(circle at 50% 50%, transparent 24%, var(--seigaiha) 24% 26.5%, transparent 26.5% 48%, var(--seigaiha) 48% 50.5%, transparent 50.5% 72%, var(--seigaiha) 72% 74.5%, transparent 74.5%);
  background-position:0 0, 33px 33px;
  background-size:66px 66px;
  -webkit-mask-image:linear-gradient(to bottom, transparent, #000 16%, #000 84%, transparent);
          mask-image:linear-gradient(to bottom, transparent, #000 16%, #000 84%, transparent);
}

.vlabel{
  position:absolute; top:clamp(80px,11vw,150px); left:8px;
  writing-mode:vertical-rl; text-orientation:mixed;
  font-size:11px; letter-spacing:.4em; color:var(--ink-faint);
  font-weight:700;
}
@media(max-width:1320px){.vlabel{display:none}}

.band__head{display:flex; align-items:flex-end; gap:22px; margin-bottom:54px}
.sec-num{
  font-family:var(--font-display); font-weight:800;
  font-size:clamp(46px,7vw,84px); line-height:.8; color:var(--pink);
  opacity:.85;
}
.sec-kicker{
  font-size:12px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--ink-soft); margin:0 0 8px;
}
.sec-title{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(30px,5vw,56px); line-height:1.05; margin:0;
  letter-spacing:.01em;
}
.ink-brush{color:var(--pink); font-family:var(--font-display)}

/* ---------- ФИЛОСОФИЯ ---------- */
.philosophy__grid{display:block}
.philosophy__lead{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(20px,2.6vw,30px); line-height:1.6; margin:0 0 64px; max-width:780px;
}
.philosophy__lead em{color:var(--pink); font-family:var(--font-brush)}
.dropcap{
  float:left; font-family:var(--font-display); font-weight:800;
  font-size:88px; line-height:.72; color:var(--seal);
  margin:6px 18px 0 0;
}

/* три принципа — угловатые карточки «лесенкой» */
.tenets{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.tenet{
  position:relative; padding:36px 30px 32px; background:var(--panel);
  border:1px solid var(--line-2); overflow:hidden;
  clip-path:polygon(0 22px,22px 0,100% 0,100% calc(100% - 22px),calc(100% - 22px) 100%,0 100%);
}
.tenet:nth-child(2){margin-top:38px}
.tenet:nth-child(3){margin-top:76px}
/* спец. селектор перебивает transition из [data-reveal], чтобы ховер был плавным */
.philosophy .tenet{transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1), border-color .4s, box-shadow .4s, color .4s}
.tenet:hover{border-color:var(--pink); box-shadow:12px 12px 0 var(--shadow)}
.tenet__no{
  position:absolute; top:-14px; right:8px; pointer-events:none;
  font-family:var(--font-display); font-weight:800; font-size:96px; line-height:1;
  color:var(--pink); opacity:.10;
}
.tenet__icon{display:block; width:46px; height:46px; color:var(--pink); margin-bottom:20px}
.tenet__icon svg{width:100%; height:100%}
.tenet:hover .tenet__icon{color:var(--seal)}
.tenet__bar{display:block; width:30px; height:3px; background:var(--pink); margin-bottom:18px; transition:width .6s cubic-bezier(.2,.7,.2,1) .15s}
.tenet.is-visible .tenet__bar{width:62px}
.tenet h3{font-family:var(--font-display); font-weight:700; font-size:23px; margin:0 0 10px}
.tenet p{margin:0; color:var(--ink-soft); font-size:14.5px; line-height:1.6}

/* ---------- ПАНЕЛИ УСЛУГ ---------- */
.panels{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.panel{
  position:relative; padding:36px 30px 34px;
  background:var(--panel); border:1px solid var(--line-2);
  clip-path:polygon(0 0, calc(100% - 26px) 0, 100% 26px, 100% 100%, 0 100%);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s;
  overflow:hidden;
}
.panel:hover{transform:translateY(-6px); border-color:var(--pink)}
.panel__corner{
  position:absolute; top:0; right:0; width:26px; height:26px;
  background:var(--pink); clip-path:polygon(0 0,100% 0,100% 100%);
  opacity:.9;
}
.panel__icon{
  width:60px; height:60px; color:var(--pink); margin-bottom:22px;
  transition:transform .5s cubic-bezier(.2,.7,.2,1), color .4s;
}
.panel__icon svg{width:100%; height:100%; overflow:visible}
.panel:hover .panel__icon{transform:translateY(-4px) scale(1.08) rotate(-3deg); color:var(--seal)}
.panel h3{font-family:var(--font-display); font-weight:700; font-size:21px; margin:0 0 12px}
.panel__desc{margin:0; color:var(--ink-soft); font-size:14.5px}

/* ---------- ПОЧЕМУ МЫ ---------- */
.why{display:grid; grid-template-columns:repeat(2,1fr); gap:0; margin-top:56px; border-top:1px solid var(--line)}
.why__item{
  display:flex; gap:18px; padding:30px 26px;
  border-bottom:1px solid var(--line);
}
.why__item:nth-child(odd){border-right:1px solid var(--line)}
.why__ico{
  flex:none; width:44px; height:44px; display:grid; place-items:center;
  color:var(--seal); border:1px solid var(--line-2);
  clip-path:polygon(14% 0,100% 0,100% 86%,86% 100%,0 100%,0 14%);
}
.why__item h4{font-family:var(--font-display); font-weight:700; font-size:17px; margin:0 0 5px}
.why__item p{margin:0; color:var(--ink-soft); font-size:14px; line-height:1.6}

/* ---------- ГАЛЕРЕЯ РАБОТ ---------- */
.work__hint{margin:-28px 0 40px; font-size:13.5px; letter-spacing:.04em; color:var(--ink-soft)}
.gallery{display:grid; grid-template-columns:repeat(auto-fill, minmax(290px, 1fr)); gap:22px}
.shot{
  position:relative; display:block; margin:0; padding:0; overflow:hidden;
  width:100%; cursor:pointer; font:inherit; color:inherit; text-align:left;
  -webkit-appearance:none; appearance:none;
  border:1px solid var(--line-2); background:var(--bg-2);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 28px),calc(100% - 28px) 100%,0 100%);
  transition:border-color .4s;
}
.shot:hover,.shot:focus-visible{border-color:var(--pink); outline:none}
.shot img{
  width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; display:block;
  transition:transform .7s cubic-bezier(.2,.7,.2,1), filter .5s;
}
.shot:hover img{transform:scale(1.05)}
.shot__cap{
  position:absolute; left:0; bottom:0; right:0;
  display:flex; flex-direction:column; gap:4px;
  padding:24px; pointer-events:none;
  background:linear-gradient(transparent, color-mix(in srgb, var(--bg) 90%, transparent) 60%);
}
.shot__idx{font-family:var(--font-display); font-size:12px; letter-spacing:.3em; color:var(--pink)}
.shot__name{font-family:var(--font-display); font-weight:700; font-size:25px; line-height:1}
.shot__tag{font-size:12.5px; letter-spacing:.08em; color:var(--ink-soft)}
.shot__more{
  display:inline-flex; align-items:center; gap:6px; margin-top:8px;
  font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:var(--pink);
  opacity:0; transform:translateY(8px); transition:opacity .4s, transform .4s;
}
.shot:hover .shot__more,.shot:focus-visible .shot__more{opacity:1; transform:none}

/* ---------- КОНТАКТЫ ---------- */
.contact__grid{display:grid; grid-template-columns:300px 1fr; gap:clamp(30px,5vw,64px); align-items:start}
.contact__art{
  margin:0; position:relative; padding:10px; background:var(--panel);
  border:1px solid var(--line-2);
  clip-path:polygon(0 0,calc(100% - 22px) 0,100% 22px,100% 100%,0 100%);
  box-shadow:10px 10px 0 var(--shadow);
}
.contact__art img{display:block; width:100%; height:auto}
.contact__art figcaption{
  margin-top:10px; text-align:center; font-size:10.5px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft);
}
.contact__lead{max-width:560px; font-size:18px; color:var(--ink-soft); margin:0 0 44px; line-height:1.7}
.contact__rows{display:flex; flex-direction:column; border-top:1px solid var(--line-2)}
.crow{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center; gap:22px;
  padding:24px 8px; border-bottom:1px solid var(--line-2);
  transition:padding .35s, background .35s;
}
.crow:hover{padding-left:24px; padding-right:0; background:color-mix(in srgb, var(--pink) 8%, transparent)}
.crow__ico{
  width:48px; height:48px; display:grid; place-items:center; color:var(--pink);
  border:1px solid var(--line-2);
  clip-path:polygon(16% 0,100% 0,100% 84%,84% 100%,0 100%,0 16%);
  transition:background .35s, color .35s, border-color .35s;
}
.crow:hover .crow__ico{background:var(--pink); color:#fff; border-color:var(--pink)}
.crow__label{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft)}
.crow__val{font-family:var(--font-display); font-weight:700; font-size:clamp(17px,2.4vw,26px)}
.crow__arr{font-size:22px; color:var(--ink-faint); transition:transform .35s, color .35s}
.crow:hover .crow__arr{color:var(--pink); transform:translate(4px,-4px)}

/* ---------- ПОДВАЛ ---------- */
.site-foot{
  display:flex; align-items:center; gap:24px; flex-wrap:wrap;
  max-width:var(--maxw); margin:0 auto;
  padding:40px var(--pad) 56px; border-top:1px solid var(--line);
}
.site-foot__mark{display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-weight:700; font-size:17px}
.site-foot__mark .brand__seal{width:34px; height:34px; font-size:18px; box-shadow:2px 2px 0 var(--ink)}
.site-foot__copy{margin:0 auto 0 0; font-size:13px; color:var(--ink-soft)}
.site-foot__up{font-family:var(--font-display); font-size:15px; color:var(--pink); letter-spacing:.1em}

/* ---------- МОДАЛКА ПРОЕКТА ---------- */
.modal{position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; padding:24px}
.modal.is-open{display:flex}
.modal__backdrop{position:absolute; inset:0; background:rgba(10,6,9,.62); backdrop-filter:blur(6px)}
:root[data-theme="paper"] .modal__backdrop{background:rgba(26,17,21,.5)}
.modal__panel{
  position:relative; z-index:1; width:100%; max-width:900px; max-height:88vh; overflow:auto;
  display:grid; grid-template-columns:1.05fr 1fr;
  background:var(--panel); border:1px solid var(--line-2);
  clip-path:polygon(0 0,calc(100% - 30px) 0,100% 30px,100% 100%,0 100%);
  animation:modalIn .45s cubic-bezier(.2,.7,.2,1);
}
@keyframes modalIn{from{opacity:0; transform:translateY(26px)}to{opacity:1; transform:none}}
.modal__media{background:var(--bg-2); min-height:300px}
.modal__media img{width:100%; height:100%; object-fit:cover; display:block}
.modal__body{padding:38px 36px 40px}
.modal__close{
  position:absolute; top:14px; right:14px; z-index:3; width:42px; height:42px; cursor:pointer;
  display:grid; place-items:center; color:var(--ink);
  background:color-mix(in srgb, var(--panel) 80%, transparent); border:1px solid var(--line-2);
  clip-path:polygon(18% 0,100% 0,100% 82%,82% 100%,0 100%,0 18%); transition:color .3s, border-color .3s, transform .3s;
}
.modal__close:hover{color:var(--pink); border-color:var(--pink); transform:rotate(90deg)}
.modal__idx{font-family:var(--font-display); font-size:12px; letter-spacing:.32em; color:var(--pink); margin:0 0 10px}
.modal__body h3{font-family:var(--font-display); font-weight:800; font-size:clamp(26px,4vw,38px); line-height:1.05; margin:0 0 8px}
.modal__cat{font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); margin:0 0 20px}
.modal__desc{font-size:15px; line-height:1.7; color:var(--ink-soft); margin:0 0 24px}
.modal__tech{list-style:none; display:flex; flex-wrap:wrap; gap:8px; padding:0; margin:0 0 28px}
.modal__tech li{font-size:11.5px; letter-spacing:.05em; padding:6px 13px; color:var(--ink-soft); border:1px solid var(--line-2)}
.modal__links{display:flex; flex-wrap:wrap; gap:14px}
.store{
  display:inline-flex; align-items:center; gap:11px; padding:12px 20px;
  color:var(--ink); border:1px solid var(--line-2); background:transparent;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,0 100%);
  transition:transform .3s, color .3s, border-color .3s;
}
.store:hover{color:var(--pink); border-color:var(--pink); transform:translateY(-3px)}
.store--soon{opacity:.5; cursor:default}
.store--soon:hover{color:var(--ink); border-color:var(--line-2); transform:none}
.store svg{width:24px; height:24px; flex:none}
.store span{display:flex; flex-direction:column; line-height:1.15}
.store small{font-size:9.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft)}
.store b{font-family:var(--font-display); font-weight:700; font-size:15px}

/* ---------- АНИМАЦИЯ ПОЯВЛЕНИЯ ---------- */
.reveal,[data-reveal]{opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.is-visible,[data-reveal].is-visible{opacity:1; transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}

/* ---------- АДАПТИВ ---------- */
@media(max-width:900px){
  .nav{display:none}
  .tenets{grid-template-columns:1fr}
  .tenet:nth-child(2),.tenet:nth-child(3){margin-top:0}
  .panels{grid-template-columns:1fr}
  .why{grid-template-columns:1fr}
  .why__item:nth-child(odd){border-right:none}
  .contact__grid{grid-template-columns:1fr}
  .contact__art{max-width:300px; margin:0 0 10px; box-shadow:7px 7px 0 var(--shadow)}
  .modal__panel{grid-template-columns:1fr; max-height:90vh}
  .modal__media{min-height:200px; max-height:38vh}
  .modal__body{padding:28px 24px 32px}
}
@media(max-width:560px){
  .crow{grid-template-columns:auto 1fr auto; gap:14px}
  .crow__label{display:none}
  .band__head{gap:14px}
  .site-foot__copy{order:3; flex-basis:100%}
}

/* ---------- ДОСТУПНОСТЬ ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important}
  .reveal,[data-reveal]{opacity:1; transform:none}
  html{scroll-behavior:auto}
}
