/* ═══════════════════════════════════════════
   LINEAR STYLE — Dark, clean, purple accent
   ═══════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

::selection{background:var(--accent);color:var(--bg)}
::-moz-selection{background:var(--accent);color:var(--bg)}

:root{
    --bg:#0a0a0a;
    --bg2:#0f0f0f;
    --bg3:#161616;
    --bg4:#1c1c1c;
    --border:#ffffff0a;
    --border2:#ffffff12;
    --t1:#ffffffed;
    --t2:#ffffffa0;
    --t3:#ffffff60;
    --t4:#ffffff30;
    --accent:#D4C5A9;
    --accent2:#BBA98A;
    --accent3:#E8DFD0;
    --grad:linear-gradient(135deg,#D4C5A9,#BBA98A,#E8DFD0);
    --glow:rgba(212,197,169,.06);
    --glow2:rgba(212,197,169,.12);
    --f:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
    --ease:cubic-bezier(.25,1,.5,1);
    --r:12px;--r2:16px;
    --wrap:1080px;
    --pad:clamp(80px,12vw,160px)
}

html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--f);background:var(--bg);color:var(--t1);line-height:1.6;overflow-x:hidden;cursor:none}
*{cursor:none!important}
a{color:inherit;text-decoration:none}img,video{display:block;max-width:100%}


/* ── Background Tech Grid & Ambient Glows ── */
.bg-grid {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: 0.6;
    background-image: 
        linear-gradient(to right, rgba(255, 255, 255, 0.015) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 255, 255, 0.015) 1px, transparent 1px);
    background-size: 50px 50px;
    mask-image: radial-gradient(circle at 50% 50%, black 40%, transparent 90%);
    animation: gridScroll 4s linear infinite;
    -webkit-mask-image: radial-gradient(circle at 50% 50%, black 40%, transparent 90%);
    animation: gridScroll 4s linear infinite;
}

.work, .case, .features, .faq, .contact {
    position: relative;
    z-index: 1;
}

.work::before {
    content: '';
    position: absolute;
    top: 15%;
    left: -10%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(212,197,169,0.03) 0%, transparent 70%);
    pointer-events: none;
    z-index: -1;
    animation: floatGlow 12s ease-in-out infinite;
}

.case::before {
    animation-delay: -3s;
    content: '';
    position: absolute;
    bottom: 5%;
    right: -15%;
    width: 700px;
    height: 700px;
    background: radial-gradient(circle, rgba(187,169,138,0.02) 0%, transparent 70%);
    pointer-events: none;
    z-index: -1;
    animation: floatGlow 12s ease-in-out infinite;
}

.features::before {
    animation-delay: -6s;
    content: '';
    position: absolute;
    top: 5%;
    left: 20%;
    width: 800px;
    height: 500px;
    background: radial-gradient(circle, rgba(212,197,169,0.02) 0%, transparent 70%);
    pointer-events: none;
    z-index: -1;
    animation: floatGlow 12s ease-in-out infinite;
}

.faq::before {
    animation-delay: -9s;
    content: '';
    position: absolute;
    bottom: -10%;
    left: -5%;
    width: 550px;
    height: 550px;
    background: radial-gradient(circle, rgba(212,197,169,0.025) 0%, transparent 70%);
    pointer-events: none;
    z-index: -1;
    animation: floatGlow 12s ease-in-out infinite;
}

/* ── Custom cursor ── */
.cursor{position:fixed;top:0;left:0;width:16px;height:16px;border:1.5px solid var(--accent);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:width .25s ease,height .25s ease,border-color .25s ease,background .25s ease,opacity .25s ease;opacity:0}
.cursor.visible{opacity:1}
.cursor.hover{width:48px;height:48px;border-color:var(--accent);background:rgba(212,197,169,.08)}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.wrap--lg{max-width:1200px}
.desk{display:inline}

/* ── Grain (animated) ── */
.grain{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
background-repeat:repeat;background-size:128px 128px;
animation:grain-shift .08s steps(1) infinite}
@keyframes grain-shift{
0%{background-position:0 0}
20%{background-position:-32px 16px}
40%{background-position:16px -48px}
60%{background-position:-48px 32px}
80%{background-position:32px -16px}
100%{background-position:-16px 48px}
}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;border-bottom:1px solid transparent;transition:background .3s,border-color .3s}
.nav.scrolled{background:rgba(10,10,10,.8);-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-color:var(--border)}
.nav__inner{max-width:var(--wrap);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:72px}
.nav__logo{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;letter-spacing:-.02em}
.nav__logo--sm{font-size:13px}
.nav__icon{flex-shrink:0}
.nav__links{display:flex;align-items:center;gap:24px}
.nav__links a{font-size:13px;color:var(--t3);transition:color .2s}
.nav__links a:hover{color:var(--t1)}
.nav__btn{background:var(--accent)!important;color:var(--bg)!important;padding:8px 18px;border-radius:8px;font-weight:600;font-size:13px!important;transition:all .2s}
.nav__btn:hover{opacity:.85}
.nav__lang{background:0;border:1px solid var(--border2);color:var(--t3);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--f);letter-spacing:.03em;transition:all .2s}
.nav__lang:hover{color:var(--t1);border-color:var(--t4)}
.nav__mob{display:none;background:0;border:0;cursor:pointer;padding:6px;flex-direction:column;gap:5px}
.nav__mob span{width:20px;height:1.5px;background:var(--t2);transition:transform .3s,opacity .2s}
.nav__mob.on span:first-child{transform:rotate(45deg) translate(2px,2px)}
.nav__mob.on span:last-child{transform:rotate(-45deg) translate(2px,-2px)}

.mob{position:fixed;inset:0;background:rgba(10,10,10,.97);z-index:99;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:0;pointer-events:none;transition:opacity .3s}
.mob.on{opacity:1;pointer-events:all}
.mob a{font-size:24px;font-weight:500;color:var(--t2);transition:color .2s}
.mob a:hover{color:var(--t1)}
.mob__cta{color:var(--accent)!important}

/* ── HERO ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;overflow:hidden}
.hero__glow{position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:600px;background:radial-gradient(ellipse at center,rgba(212,197,169,.08) 0%,rgba(187,169,138,.04) 40%,transparent 70%);pointer-events:none;z-index:0}
.hero__content{position:relative;z-index:5;max-width:720px}

/* Big TRIUMPH display */
.hero__big{
    display:block;
    font-family:'Bebas Neue',Impact,sans-serif;
    font-size:clamp(80px,16vw,200px);
    letter-spacing:.15em;
    line-height:.85;
    color:transparent;
    -webkit-text-stroke:1px rgba(255,255,255,.25);
    margin-bottom:-10px;
    user-select:none;
    background:linear-gradient(180deg,rgba(255,255,255,.32) 0%,rgba(212,197,169,.15) 100%);
    -webkit-background-clip:text;
    background-clip:text;
    transition:opacity 2.5s ease,transform 2.5s ease!important
}
.hero__big.in{transform:translateY(0)!important}

.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px 4px 8px;border-radius:99px;border:1px solid var(--border2);background:var(--bg2);font-size:12px;font-weight:500;color:var(--t2);margin-bottom:28px}
.pill__dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px rgba(74,222,128,.5)}

.hero__h{font-size:clamp(36px,6vw,64px);font-weight:700;letter-spacing:-.04em;line-height:1.08;margin-bottom:20px;background:linear-gradient(180deg,var(--t1) 40%,var(--t3) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero__p{font-size:clamp(15px,1.6vw,17px);color:var(--t3);max-width:500px;margin:0 auto 32px;line-height:1.7}
.hero__btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;border:0;transition:all .3s ease;cursor:pointer;font-family:var(--f)}

/* Default styles */
.btn--main{background:var(--accent);color:var(--bg)}
.btn--main:hover{opacity:.85;transform:translateY(-1px)}
.btn--sec{background:var(--bg3);color:var(--t2);border:1px solid var(--border2)}
.btn--sec:hover{background:var(--bg4);color:var(--t1);border-color:var(--border2)}

/* Hero Buttons - Apple Liquid Glass */
.hero__btns .btn {
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    color: #fff;
    box-shadow: 0 8px 32px -4px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.1);
    text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
.hero__btns .btn:hover {
    box-shadow: 0 12px 40px -4px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
.hero__btns .btn--main {
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.2);
}
.hero__btns .btn--main:hover {
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.3);
}
.hero__btns .btn--sec {
    background: rgba(20, 20, 20, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.08);
}
.hero__btns .btn--sec:hover {
    background: rgba(40, 40, 40, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.15);
}

/* ── STATS (Obsession Metrics & Тонкие прогресс-бары) ── */
.stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:48px 0;background:var(--bg)}
.stats__grid{display:flex;align-items:stretch;justify-content:center;gap:0}

.stats__item {
    flex: 1;
    text-align: center;
    padding: 0 24px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.stats__num{display:block;font-size:clamp(24px,3vw,32px);font-weight:700;letter-spacing:-.03em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* Тонкие горизонтальные шкалы загрузки процессора/рендера */
.stats__track {
    width: 100%;
    max-width: 110px;
    height: 1px;
    background: rgba(255, 255, 255, 0.06);
    margin: 8px auto 6px;
    position: relative;
    overflow: hidden;
}
.stats__bar {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0%;
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent);
}

/* Мерцающие статусы вычислительных процессов */
.stats__status {
    font-family: monospace;
    font-size: 8px;
    letter-spacing: 0.12em;
    color: var(--t4);
    text-transform: uppercase;
    margin-bottom: 8px;
    white-space: nowrap;
    transition: color 0.3s;
}
.stats__status.active {
    color: var(--accent);
    animation: techFlicker 0.3s steps(2, start) infinite;
}

@keyframes techFlicker {
    0%, 100% { opacity: 0.2; }
    50% { opacity: 1; }
}

.stats__label{font-size:12px;color:var(--t4);text-transform:uppercase;letter-spacing:.06em}
.stats__sep{width:1px;background:var(--border2);flex-shrink:0}

/* ── Section shared (КРИТИЧЕСКОЕ ИСПРАВЛЕНИЕ: Восстановление стилей заголовков!) ── */
.section-top{text-align:center;margin-bottom:clamp(40px,5vw,64px)}
.section-label{font-size:clamp(14px,1.2vw,18px);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent2);margin-bottom:12px}
.section-h{font-size:clamp(28px,4.5vw,44px);font-weight:700;letter-spacing:-.035em;line-height:1.15;margin-bottom:14px;background:linear-gradient(180deg,var(--t1) 30%,var(--t3) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.section-p{font-size:15px;color:var(--t3);max-width:440px;margin:0 auto}

/* ── PROJECTS (Взлетающие карточки с многослойными мягкими тенями парения) ── */
.work{padding:var(--pad) 0}
.grid-916{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}

.vcard{position:relative;aspect-ratio:9/16;border-radius:var(--r2);overflow:hidden;border:1px solid var(--border);background:var(--bg2);transition:border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease); will-change: transform, box-shadow; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);}
.vcard:hover{border-color:var(--border2); transform: scale3d(1.03, 1.03, 1.03) translateY(-12px); box-shadow: 0 35px 75px rgba(0, 0, 0, 0.85), 0 10px 30px rgba(0, 0, 0, 0.5);}
.vcard::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .4s;pointer-events:none;z-index:2;background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),var(--glow),transparent 50%)}
.vcard:hover::before{opacity:1}
.vcard__vid{position:absolute;inset:0}
.vcard__vid video{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.vcard:hover .vcard__vid video{transform:scale(1.04)}
.vcard__over{position:absolute;bottom:0;left:0;right:0;padding:clamp(16px,2vw,28px);background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%);z-index:3}
.vcard__h{font-size:clamp(15px,1.6vw,20px);font-weight:600;letter-spacing:-.01em;margin-bottom:6px;line-height:1.3}

.proj__badge{display:inline-block;padding:3px 10px;border-radius:6px;background:rgba(212,197,169,.08);border:1px solid rgba(212,197,169,.12);font-size:11px;font-weight:600;color:var(--accent);margin-bottom:10px}
.proj__meta{display:flex;gap:14px;font-size:11px;color:var(--t4);margin-top:2px}

.grid-sq{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sqcard{position:relative;aspect-ratio:1/1;border-radius:var(--r2);overflow:hidden;border:1px solid var(--border);background:var(--bg2);transition:border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease); will-change: transform, box-shadow; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);}
.sqcard:hover{border-color:var(--border2); transform: scale3d(1.03, 1.03, 1.03) translateY(-12px); box-shadow: 0 35px 75px rgba(0, 0, 0, 0.85), 0 10px 30px rgba(0, 0, 0, 0.5);}
.sqcard::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .4s;pointer-events:none;z-index:2;background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),var(--glow),transparent 50%)}
.sqcard:hover::before{opacity:1}
.sqcard__vid{position:absolute;inset:0}
.sqcard__vid video{width:100%;height:100%;object-fit: cover;transition:transform .6s var(--ease)}
.sqcard:hover .sqcard__vid video{transform:scale(1.04)}

/* ── ASYMMETRIC GRID (BENTO) ── */
.grid-asym {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 16px;
}
.grid-asym-left {
    aspect-ratio: auto;
    height: 100%;
}
.grid-asym-right {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.grid-asym-right .sqcard {
    flex: 1;
}

/* ── CASE BENTO (Парящие карточки) ── */
.case{padding:clamp(80px,10vw,140px) 0;border-top:1px solid var(--border)}
.bento{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px}
.bento__card{padding:clamp(28px,3vw,44px);border-radius:var(--r2);border:1px solid var(--border);background:var(--bg2);transition:border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease); display:flex;flex-direction:column;justify-content:space-between;min-height:180px; position:relative; overflow:hidden; will-change: transform, box-shadow; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);}
.bento__card:hover{border-color:var(--border2); transform: scale3d(1.03, 1.03, 1.03) translateY(-12px); box-shadow: 0 35px 75px rgba(0, 0, 0, 0.85), 0 10px 30px rgba(0, 0, 0, 0.5);}
.bento__card--lg{grid-column:span 2;flex-direction:row;gap:clamp(24px,3vw,48px);align-items:center}
.bento__card--wide{grid-column:span 2}

.bento__num{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;font-size:clamp(48px,6vw,80px);letter-spacing:.02em;line-height:1;margin-bottom:16px;color:var(--accent)}
.bento__num--long{font-size:clamp(32px,4vw,56px)}
.bento__num--text{font-size:clamp(36px,5vw,64px);color:var(--accent);letter-spacing:.04em}
.bento__text{font-size:clamp(14px,1.2vw,16px);color:var(--t3);line-height:1.6;max-width:540px}
.bento__text strong{color:var(--t1);font-weight:600}
.bento__side{flex:1;min-width:0}

/* ── Instagram mockup ── */
.ig-mock{flex:0 0 280px;padding:20px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid var(--border)}
.ig-mock__header{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.ig-mock__logo{color:var(--t3)}
.ig-mock__handle{font-size:13px;font-weight:600;color:var(--t1)}
.ig-mock__badge{margin-left:auto;font-size:10px;padding:2px 8px;border-radius:4px;background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff;font-weight:600;letter-spacing:.02em}
.ig-mock__profile{display:flex;align-items:center;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.ig-mock__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#f09433,#dc2743);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:18px;color:#fff;letter-spacing:.05em;flex-shrink:0}
.ig-mock__stats{display:flex;gap:16px;flex:1}
.ig-mock__stat{text-align:center;flex:1}
.ig-mock__stat-num{display:block;font-size:15px;font-weight:700;color:var(--t1);line-height:1.2}
.ig-mock__stat-label{display:block;font-size:10px;color:var(--t4);margin-top:2px}
.ig-mock__reels{display:flex;gap:6px}
.ig-mock__reel{flex:1;border-radius:6px;overflow:hidden}
.ig-mock__reel-thumb{aspect-ratio:9/16;background-color:rgba(0,0,0,.6);background-size:cover;background-position:center;filter:brightness(.45) saturate(.6);position:relative}
.ig-mock__reel-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.5) 100%)}
.ig-mock__reel-info{display:flex;align-items:center;gap:4px;padding:4px 0 0;font-size:11px;color:var(--t3);font-weight:600}
.ig-mock__avatar--gww{background:linear-gradient(135deg,#2563eb,#3b82f6)}
.ig-mock__avatar--img{background-size:cover;background-position:center;background-color:var(--bg);filter:brightness(.7) saturate(.5)}
.ig-mock__reel-thumb--gww{background:linear-gradient(180deg,rgba(37,99,235,.15) 0%,rgba(0,0,0,.3) 100%)}
.bento__num--range{font-size:clamp(40px,5vw,68px);color:var(--accent)}

/* ── FEATURES (Чистый темный фон раздела возможностей) ── */
.features{padding:var(--pad) 0;background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.feat{padding:clamp(24px,3vw,36px);border-radius:var(--r2);border:1px solid var(--border);background:var(--bg2);transition:border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease);position:relative;overflow:hidden; will-change: transform, box-shadow; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);}
.feat::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .4s;pointer-events:none;background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),var(--glow),transparent 50%)}
.feat:hover::before{opacity:1}
.feat:hover{border-color:var(--border2); transform: scale3d(1.03, 1.03, 1.03) translateY(-12px); box-shadow: 0 35px 75px rgba(0, 0, 0, 0.85), 0 10px 30px rgba(0, 0, 0, 0.5);}
.feat--hero{grid-column:1/-1}
.feat__icon{width:36px;height:36px;border-radius:10px;background:rgba(212,197,169,.08);border:1px solid rgba(212,197,169,.1);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:16px}
.feat__h{font-size:17px;font-weight:600;letter-spacing:-.01em;margin-bottom:8px}
.feat__p{font-size:14px;color:var(--t3);line-height:1.7;max-width:500px;margin-bottom:14px}
.feat__tags{display:flex;flex-wrap:wrap;gap:6px}
.feat__tags span{padding:3px 10px;border-radius:6px;border:1px solid var(--border2);font-size:11px;color:var(--t4);transition:color .2s,border-color .2s}
.feat:hover .feat__tags span{color:var(--t3);border-color:rgba(212,197,169,.15)}

/* ── CLEAN SIDE WATERMARK (Пасхалка) ── */
.side-watermark {
    position: absolute;
    top: 0;
    left: clamp(16px, 3vw, 48px);
    right: auto;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-around;
    padding-top: 0px; /* Опустит весь блок ниже шапки */
    padding-bottom: 400px; /* Отступ от подвала */
    pointer-events: none;
    z-index: 2;
    opacity: 0.11;
    color: var(--t1);
    user-select: none;
}
.watermark-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.38em;
    text-transform: uppercase;
    white-space: nowrap;
}
.watermark-item svg {
    transform: rotate(180deg);
}

/* ── CLIENTS ── */
.clients{padding:clamp(60px,8vw,100px) 0;border-top:1px solid var(--border)}
.clients__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px}
.client-card{padding:clamp(20px,2.5vw,32px);border:1px solid var(--border);border-radius:var(--r2);background:var(--bg2);transition:border-color .4s var(--ease),transform .4s var(--ease), box-shadow .4s var(--ease);text-align:center; position:relative; overflow:hidden; will-change: transform, box-shadow; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);}
.client-card:hover{border-color:var(--border2); transform: scale3d(1.03, 1.03, 1.03) translateY(-12px); box-shadow: 0 35px 75px rgba(0, 0, 0, 0.85), 0 10px 30px rgba(0, 0, 0, 0.5);}
.client-card__icon{width:52px;height:52px;border-radius:14px;background:rgba(212,197,169,.06);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;color:var(--accent);margin:0 auto 14px}
.client-card__name{display:block;font-size:16px;font-weight:700;letter-spacing:-.01em;margin-bottom:4px}
.client-card__desc{display:block;font-size:12px;color:var(--t4)}

/* Glow hover helper */
.bento__card::before, .client-card::before, .faq-card::before {
    content:'';
    position:absolute;
    inset:0;
    opacity:0;
    transition:opacity .4s;
    pointer-events:none;
    background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),var(--glow),transparent 50%);
}
.bento__card:hover::before, .client-card:hover::before, .faq-card:hover::before { opacity:1; }

/* ── FAQ ── */
.faq { padding: var(--pad) 0; border-top: 1px solid var(--border); background: var(--bg); }
.faq-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.faq-card { padding: clamp(24px, 3vw, 36px); border-radius: var(--r2); border: 1px solid var(--border); background: var(--bg2); transition: border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease); display: flex; flex-direction: column; position:relative; overflow:hidden; will-change: transform, box-shadow; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);}
.faq-card:hover { border-color: var(--border2); transform: scale3d(1.03, 1.03, 1.03) translateY(-12px); box-shadow: 0 35px 75px rgba(0, 0, 0, 0.85), 0 10px 30px rgba(0, 0, 0, 0.5);}
.faq-card__icon { width: 40px; height: 40px; border-radius: 10px; background: rgba(212,197,169,.06); border: 1px solid var(--border2); display: flex; align-items: center; justify-content: center; color: var(--accent); margin-bottom: 20px; }
.faq-card__q { font-size: 16px; font-weight: 600; letter-spacing: -0.01em; margin-bottom: 12px; color: var(--t1); line-height: 1.4; }
.faq-card__a { font-size: 14px; color: var(--t3); line-height: 1.6; }

@media(max-width: 768px) {
    .faq-grid { grid-template-columns: 1fr; }
    .side-watermark { display: none !important; }
    .vcard, .sqcard, .bento__card, .feat, .client-card, .faq-card { transform: none !important; box-shadow: none !important; }
}

/* ── CONTACT ── */
.contact{padding:clamp(100px,14vw,200px) 0;text-align:center}
.contact__body{position:relative}
.contact__label{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;font-size:clamp(28px,4vw,48px);letter-spacing:.08em;margin-bottom:28px;color:var(--t2)}
.contact__sub{font-size:clamp(14px,1.5vw,17px);color:var(--t3);line-height:1.7;margin-bottom:40px}
.contact__big{display:block;font-size:clamp(32px,7vw,80px);font-weight:700;letter-spacing:-.03em;margin-bottom:48px;color:var(--t1);transition:color .3s;line-height:1.1}
.contact__big:hover{color:var(--accent)}
.contact__pills{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cpill{padding:10px 28px;border:1px solid var(--t4);border-radius:99px;font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--t2);transition:all .3s}
.cpill:hover{border-color:var(--t1);color:var(--t1)}

/* ── FOOTER ── */
.foot{padding:24px 0;border-top:1px solid var(--border)}
.foot__row{display:flex;justify-content:space-between;align-items:center}
.foot__left{display:flex;align-items:center;gap:16px}
.foot__copy{font-size:12px;color:var(--t4)}
.foot__right a{font-size:12px;color:var(--t4);transition:color .2s}
.foot__right a:hover{color:var(--t2)}

/* ── SPLIT WORD ── */
[data-a="word"] .word{display:inline-block;opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-a="word"].in .word{opacity:1;transform:none}
.hero__h,.section-h{transition:opacity 2s ease!important;transform:none!important;transition-delay:.3s!important}

/* ── ANIMATIONS ── */
[data-a]{opacity:0;transform:translateY(40px);transition:opacity 1.2s var(--ease),transform 1.2s var(--ease)}
[data-a].in{opacity:1;transform:none}
.section-top [data-a],.hero__content [data-a]{transition-delay:0s}

/* ── RESPONSIVE ── */
@media(max-width:900px){ .grid-916{grid-template-columns:repeat(3,1fr)} }
@media(max-width:768px){
    .nav__links{display:none}.nav__mob{display:flex}
    .desk{display:none}
    .stats__grid{flex-wrap:wrap;gap:24px}
    .stats__sep{display:none}
    .grid-916{grid-template-columns:1fr 1fr 1fr}
    .grid-sq{grid-template-columns:1fr 1fr}
    .feat-grid{grid-template-columns:1fr}.feat--hero{grid-column:auto}
    .clients__grid{grid-template-columns:1fr 1fr}
    .bento{grid-template-columns:1fr}
    .bento__card--lg,.bento__card--wide{grid-column:auto}
    .bento__card--lg{flex-direction:column}
    .ig-mock{flex:none;width:100%}
    .bento__num{font-size:clamp(40px,10vw,56px)}
}
@media(max-width:580px){
    .grid-916{grid-template-columns:1fr;max-width:320px;margin-left:auto;margin-right:auto}
    .grid-sq{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}
}
@media(max-width:480px){
    .hero__btns,.cta__btns{flex-direction:column;align-items:stretch}
    .btn{justify-content:center}
    .foot__row{flex-direction:column;gap:12px;text-align:center}
    .foot__left{flex-direction:column;gap:8px}
}

/* ── Soft Video Merge ── */
.vid-overlay {
    position: absolute;
    inset: -1px;
    background: radial-gradient(circle at center, transparent 30%, rgba(15,15,15,0.85) 100%);
    pointer-events: none;
    z-index: 2;
}
/* 1. Переносим маску на обертку (Фикс бага Safari с обрезкой 1/2 видео) */
.vcard__vid, .sqcard__vid {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    mask-image: linear-gradient(to bottom, black 80%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, black 80%, transparent 100%);
    z-index: 0;
}

/* 2. Заставляем видео заполнять контейнер чисто и без конфликтов */
.vcard__vid video, .sqcard__vid video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* ── 3D Tilt ── */
.tilt-card {
    will-change: transform;
    transform-style: preserve-3d;
    transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1), border-color 0.3s;
}

/* ── Magnetic Buttons ── */
.magnetic {
    transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.3s, background 0.3s, border-color 0.3s !important;
    will-change: transform;
}

/* ── Idea 10: Sticky Layouts ── */
@media(min-width: 992px) {
    .sticky-layout { display: flex; align-items: flex-start; gap: 80px; position: relative; }
    .sticky-sidebar { flex: 0 0 300px; position: sticky; top: 140px; }
    .sticky-sidebar .section-top { text-align: left; margin: 0; max-width: 100%; }
    .sticky-content { flex: 1; min-width: 0; }
}

/* ── Idea 17: Shutter Footer Reveal ── */
@media(min-width: 769px) {
    body { background: #050505; }
    .site-wrapper {
        position: relative;
        z-index: 5;
        background: var(--bg);
        box-shadow: 0 30px 60px rgba(0,0,0,0.7);
        margin-bottom: 240px;
    overflow-x: clip;
    }
    .foot {
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        z-index: 1;
        height: auto;
    }
}

/* ── Idea 5: Cinematic Video Grain overlay ── */
.vcard__vid, .sqcard__vid { position: relative; }
.vcard__vid::after, .sqcard__vid::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 3;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.15'/%3E%3C/svg%3E");
    mix-blend-mode: overlay;
}

/* ── Ultimate Mobile Fixes ── */
html, body {
    max-width: 100vw;
    overflow-x: clip;
    overscroll-behavior-x: none;
}
.site-wrapper {
    overflow-x: clip !important;
    max-width: 100vw;
}


@media(max-width: 768px) {
    /* ── Hide the Vertical Video on Mobile ── */
    .grid-asym-left {
        display: none !important;
    }
    
    /* ── Place two squares side-by-side on mobile ── */
    .grid-asym {
        display: block !important;
        margin-top: 16px;
    }
    .grid-asym-right {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
    
    /* Делаем шрифт чуть меньше, чтобы карточки красиво влезли в два столбца на телефоне */
    .grid-asym-right .vcard__h {
        font-size: 14px;
        line-height: 1.1;
    }
    .grid-asym-right .proj__badge {
        font-size: 8px;
        padding: 4px 6px;
    }
  
}
