/* ══════════════════════════════════════════════════════════
   styles.css — DevOps Family Site
   ══════════════════════════════════════════════════════════ */

:root {
  --bg:#09101f; --bg2:#060a14;
  --card:rgba(255,255,255,.065);
  --text:rgba(255,255,255,.95); --muted:rgba(255,255,255,.68); --muted2:rgba(255,255,255,.46);
  --stroke:rgba(255,255,255,.11); --stroke2:rgba(255,255,255,.18);
  --accent:#8b5cf6; --accent2:#22d3ee; --accent3:#fb7185;
  --ok:#34d399; --warn:#fbbf24;
  --r-xl:28px; --r-lg:20px; --r-md:14px; --r-sm:10px;
  --sh-xl:0 24px 80px rgba(0,0,0,.4); --sh-lg:0 12px 36px rgba(0,0,0,.24); --sh-sm:0 4px 16px rgba(0,0,0,.16);
  --max:1180px;
}
[data-theme="light"] {
  --bg:#f3f6fb; --bg2:#fff;
  --card:rgba(17,24,39,.05);
  --text:rgba(17,24,39,.95); --muted:rgba(17,24,39,.68); --muted2:rgba(17,24,39,.46);
  --stroke:rgba(17,24,39,.10); --stroke2:rgba(17,24,39,.18);
  --sh-xl:0 20px 60px rgba(17,24,39,.10); --sh-lg:0 10px 28px rgba(17,24,39,.08); --sh-sm:0 4px 14px rgba(17,24,39,.06);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Manrope",system-ui,-apple-system,sans-serif;color:var(--text);min-height:100vh;overflow-x:hidden;
  background:radial-gradient(900px 500px at 12% 4%,rgba(139,92,246,.26),transparent 56%),
    radial-gradient(800px 480px at 88% 12%,rgba(34,211,238,.16),transparent 52%),
    radial-gradient(700px 460px at 65% 96%,rgba(251,113,133,.12),transparent 56%),
    linear-gradient(180deg,var(--bg),var(--bg2));}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input{font:inherit}

.grain{pointer-events:none;position:fixed;inset:-40%;opacity:.06;mix-blend-mode:overlay;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E");}

.wrap{width:min(var(--max),calc(100vw - 32px));margin:0 auto}
.hidden{display:none!important}
.svg-defs{position:absolute;width:0;height:0;overflow:hidden}
.ico{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:none}
.ico svg{width:18px;height:18px;display:block;flex:none;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.reveal.show{opacity:1;transform:none}
.skip{position:absolute;left:12px;top:-48px;z-index:999;padding:10px 16px;border-radius:12px;background:#111827;color:#fff;transition:top .2s}
.skip:focus{top:12px}

/* ТОПБАР */
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(18px) saturate(1.5);border-bottom:1px solid var(--stroke);background:linear-gradient(180deg,rgba(0,0,0,.22),rgba(0,0,0,.04))}
[data-theme="light"] .topbar{background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(255,255,255,.62))}
.topbar-inner{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.logo-wrap{width:42px;height:42px;flex:none;border-radius:14px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.14);background:linear-gradient(145deg,#0d1626,#12203a);box-shadow:0 4px 16px rgba(0,0,0,.35),0 0 0 1px rgba(139,92,246,.18);position:relative;overflow:hidden}
.logo-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 25%,rgba(139,92,246,.35),transparent 60%);pointer-events:none}
.logo-svg{width:24px;height:24px;position:relative;z-index:1;flex:none}
.brand-text strong{display:block;font-size:15px;line-height:1.1}
.brand-text span{display:block;font-size:11px;color:var(--muted2);margin-top:2px}
.nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center}
.nav a{color:var(--muted);padding:9px 13px;border-radius:11px;font-size:14px;transition:.18s ease}
.nav a:hover{background:var(--card);color:var(--text)}
.actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}

/* КНОПКИ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 16px;border-radius:13px;border:1px solid var(--stroke);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));color:var(--text);cursor:pointer;font-size:13px;font-weight:600;transition:transform .15s,border-color .15s,background .15s,box-shadow .15s;box-shadow:var(--sh-sm);white-space:nowrap}
.btn:hover{transform:translateY(-1px);border-color:var(--stroke2)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}
.btn.sm{min-height:38px;padding:0 13px;font-size:12px;border-radius:10px}
.btn.primary{color:#fff;border-color:rgba(255,255,255,.15);background:linear-gradient(135deg,rgba(139,92,246,.95),rgba(34,211,238,.88));box-shadow:0 8px 28px rgba(139,92,246,.28)}
.btn.primary:hover{background:linear-gradient(135deg,#9d6fff,#32e8ff)}

/* LANG */
.lang-sw{display:inline-flex;gap:2px;border-radius:11px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);overflow:hidden;padding:3px}
.lang-btn{padding:4px 10px;border-radius:8px;border:none;background:none;color:var(--muted2);font-size:11px;font-weight:700;cursor:pointer;transition:.15s;letter-spacing:.04em}
.lang-btn.active{background:linear-gradient(135deg,rgba(139,92,246,.35),rgba(34,211,238,.25));color:var(--text)}
.lang-btn:hover:not(.active){color:var(--muted);background:rgba(255,255,255,.07)}

/* ЭЛЕМЕНТЫ */
.pill{display:inline-flex;align-items:center;gap:7px;min-height:34px;padding:7px 13px;border-radius:999px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);color:var(--muted);font-size:13px;line-height:1;white-space:nowrap}
.card{position:relative;overflow:hidden;border-radius:var(--r-xl);border:1px solid var(--stroke);background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.03));box-shadow:var(--sh-xl);backdrop-filter:blur(16px)}
[data-theme="light"] .card{background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(255,255,255,.72))}
.panel{padding:20px}
.panel h3{margin:0 0 12px;font-size:17px;letter-spacing:-.01em}

/* СЕКЦИИ */
section{padding:28px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px;flex-wrap:wrap}
h1{margin:0 0 14px;font-size:clamp(32px,5vw,56px);line-height:.98;letter-spacing:-.04em;max-width:14ch}
h2{margin:0 0 4px;font-size:22px;letter-spacing:-.02em}
.hint{color:var(--muted);font-size:14px;line-height:1.6;max-width:70ch}

/* ГЕРОЙ */
.hero{padding-top:40px;padding-bottom:28px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(330px,.8fr);gap:22px;align-items:stretch}
.hero-left{padding:28px;min-height:400px;display:flex;flex-direction:column;justify-content:space-between}
.hero-right{display:flex;flex-direction:column}
.hero-art{flex:1;padding:18px;background:radial-gradient(440px 240px at 20% 10%,rgba(139,92,246,.14),transparent 58%),radial-gradient(500px 220px at 86% 18%,rgba(34,211,238,.10),transparent 56%)}
.hero-media{flex:1;border-radius:18px;border:1px solid var(--stroke);overflow:hidden;background:#070d1a;min-height:250px}
.hero-media svg{display:block;width:100%;height:100%}
.kicker{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.lead{margin:0;color:var(--muted);font-size:17px;line-height:1.76;max-width:60ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;align-items:center}
.stats{margin-top:22px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.stat{padding:13px;border-radius:var(--r-lg);border:1px solid var(--stroke);background:rgba(255,255,255,.04)}
.stat b{display:block;font-size:14px;margin-bottom:3px}
.stat span{color:var(--muted2);font-size:11px;line-height:1.4}
.mini-row{padding:0 16px 16px;display:flex;gap:10px;flex-wrap:wrap}
.mini{flex:1 1 160px;min-height:76px;display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r-lg);border:1px solid var(--stroke);background:rgba(255,255,255,.05)}
.dot{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 5px rgba(52,211,153,.12);flex:none}
.dot.warn{background:var(--warn);box-shadow:0 0 0 5px rgba(251,191,36,.12)}
.mini b{display:block;font-size:13px;margin-bottom:2px}
.mini span{color:var(--muted2);font-size:11px;line-height:1.4}

/* СЕТКИ */
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}

/* СПИСКИ */
.list{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.li{display:flex;align-items:flex-start;gap:11px;padding:11px;border-radius:var(--r-md);border:1px solid var(--stroke);background:rgba(255,255,255,.034)}
.chip{width:34px;height:34px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex:none;border:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,rgba(139,92,246,.22),rgba(34,211,238,.12))}
.li b{display:block;font-size:14px;margin-bottom:3px}
.li span{display:block;color:var(--muted2);font-size:13px;line-height:1.55}
.ref-link{color:var(--accent2);font-size:12px;font-weight:600;text-decoration:none;transition:.15s}
.ref-link:hover{color:#fff}

/* МЕТРИКИ */
.metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.metric-card{padding:18px 16px;border-radius:var(--r-lg);border:1px solid var(--stroke);background:rgba(255,255,255,.04);display:flex;flex-direction:column;gap:5px}
.metric-val{font-size:26px;font-weight:800;letter-spacing:-.03em}
.metric-label{font-size:12px;color:var(--muted2);line-height:1.4}
.metric-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600}
.metric-badge.ok{background:rgba(52,211,153,.15);color:var(--ok)}
.metric-badge.warn{background:rgba(251,191,36,.15);color:var(--warn)}

/* ИНСТРУМЕНТЫ */
.tools-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.tool-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);font-size:13px;color:var(--muted);white-space:nowrap;transition:.18s ease;text-decoration:none;cursor:pointer}
.tool-tag:hover{background:rgba(139,92,246,.12);border-color:rgba(139,92,246,.3);color:var(--text)}
.tool-dot{width:8px;height:8px;border-radius:50%;flex:none}

/* PIPELINE */
.pipeline{display:flex;align-items:stretch;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--stroke);margin-bottom:16px}
.pipe-step{flex:1;padding:16px 10px;display:flex;flex-direction:column;align-items:center;gap:7px;border-right:1px solid var(--stroke);background:rgba(255,255,255,.03);text-align:center;cursor:pointer;text-decoration:none;color:inherit;transition:background .18s}
.pipe-step:last-child{border-right:none}
.pipe-step:hover{background:rgba(139,92,246,.08)}
.ps-icon{width:40px;height:40px;border-radius:13px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.11);font-size:18px;background:linear-gradient(135deg,rgba(139,92,246,.18),rgba(34,211,238,.10))}
.pipe-step b{font-size:13px;font-weight:700}
.pipe-step span{font-size:11px;color:var(--muted2);line-height:1.4}

/* CI/CD */
.cicd-tabs{display:flex;gap:3px;flex-wrap:wrap;border-bottom:1px solid var(--stroke);padding-bottom:0}
.cicd-tab{display:inline-flex;align-items:center;gap:7px;padding:10px 16px;border-radius:12px 12px 0 0;border:1px solid transparent;border-bottom:none;background:none;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:.15s;position:relative;bottom:-1px}
.cicd-tab:hover{color:var(--text);background:rgba(255,255,255,.04)}
.cicd-tab.active{color:var(--text);background:rgba(139,92,246,.09);border-color:var(--stroke)}
.cicd-content{border:1px solid var(--stroke);border-top:none;border-radius:0 0 var(--r-xl) var(--r-xl);background:rgba(255,255,255,.03);backdrop-filter:blur(12px);overflow:hidden}
.cicd-panel{display:none;padding:20px}
.cicd-panel.active{display:block}
.cicd-desc{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
.cicd-badge{padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}

/* КОД */
.code-block{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--stroke)}
.code-header{display:flex;align-items:center;justify-content:space-between;padding:9px 16px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--stroke)}
.code-filename{font-family:monospace;font-size:12px;color:var(--muted)}
.code-copy{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;border:1px solid var(--stroke);background:none;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:.15s}
.code-copy:hover{border-color:var(--accent);color:var(--accent)}
.code-copy.copied{color:var(--ok);border-color:rgba(52,211,153,.3)}
.code-pre{margin:0;padding:16px;overflow-x:auto;background:#060a14;font-family:"JetBrains Mono","Fira Code",monospace;font-size:12px;line-height:1.72;max-height:460px}
[data-theme="light"] .code-pre{background:#0d1626}
.cy{color:#82aaff}.cp{color:rgba(255,255,255,.42)}.cs{color:#c3e88d}
.cm{color:#89ddff}.cc{color:rgba(255,255,255,.3);font-style:italic}.ck{color:#c792ea}.cn{color:#f78c6c}

/* ГАЛЕРЕЯ */
.gallery{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}
.tile{grid-column:span 4;padding:12px;border-radius:var(--r-xl);border:1px solid var(--stroke);background:rgba(255,255,255,.05);display:flex;flex-direction:column;gap:10px;overflow:hidden;min-height:200px}
.tile.big{grid-column:span 8;min-height:220px}
.cap{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.cap b{font-size:13px;line-height:1.4}
.cap span{font-size:11px;color:var(--muted2)}
.media-box{flex:1;min-height:120px;border-radius:14px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);overflow:hidden;cursor:pointer;position:relative}
.media-box img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.media-box:hover img{transform:scale(1.04)}
/* оверлей при hover */
.gal-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;background:rgba(6,10,20,.82);backdrop-filter:blur(4px);opacity:0;transition:opacity .22s ease;padding:16px;text-align:center}
.media-box:hover .gal-overlay,.media-box:focus .gal-overlay{opacity:1}
.gal-ov-icon{width:42px;height:42px;border-radius:13px;border:1px solid rgba(255,255,255,.18);background:linear-gradient(135deg,rgba(139,92,246,.3),rgba(34,211,238,.2));display:flex;align-items:center;justify-content:center}
.gal-ov-icon svg{width:21px;height:21px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.gal-ov-text{font-size:12px;font-weight:600;color:rgba(255,255,255,.9);line-height:1.5}
.gal-ov-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;border:none;background:linear-gradient(135deg,rgba(139,92,246,.9),rgba(34,211,238,.8));color:#fff;font-size:12px;font-weight:700;cursor:pointer;transition:.15s}
.gal-ov-btn:hover{background:linear-gradient(135deg,#9d6fff,#32e8ff)}
.gal-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:36px;color:var(--muted);font-size:14px;grid-column:1/-1}
.gal-spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);animation:galSpin .7s linear infinite;flex:none}
.gal-empty{grid-column:1/-1;text-align:center;padding:36px;color:var(--muted2);font-size:14px}
@keyframes galSpin{to{transform:rotate(360deg)}}

/* РЕСУРСЫ */
.res-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
a.res-link{display:flex;flex-direction:column;gap:9px;padding:17px;border-radius:var(--r-lg);border:1px solid var(--stroke);background:rgba(255,255,255,.04);transition:background .18s,border-color .18s,transform .18s;text-decoration:none}
a.res-link:hover{background:rgba(139,92,246,.10);border-color:rgba(139,92,246,.28);transform:translateY(-2px)}
.res-icon{font-size:22px;line-height:1}
.res-title{font-size:14px;font-weight:700;color:var(--text)}
.res-desc{font-size:12px;color:var(--muted2);line-height:1.55;flex:1}
.res-url{font-size:11px;color:var(--accent);opacity:.8}

/* КОНТАКТЫ */
.contact-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.contact-copy strong{display:block;font-size:16px;margin-bottom:8px}
.contact-copy p{margin:0;color:var(--muted);font-size:14px;line-height:1.7}
.contact-badges{display:flex;flex-wrap:wrap;gap:8px}
.contact-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:13px;border:1px solid var(--stroke);background:rgba(255,255,255,.05);font-size:13px;font-weight:600;color:var(--muted)}
.contact-badge svg{width:16px;height:16px;flex:none}

/* ФУТЕР */
footer{padding:22px 0 32px}
.footer-card{padding:18px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:14px;color:var(--muted)}

/* МОДАЛКА */
#loginModal{display:none;position:fixed;inset:0;z-index:200;align-items:center;justify-content:center;background:rgba(0,0,0,.72);backdrop-filter:blur(7px);padding:16px}
#loginModal.open{display:flex}
#modalBox{width:100%;max-width:420px;padding:32px 28px;border-radius:var(--r-xl);border:1px solid var(--stroke2);background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));box-shadow:0 32px 100px rgba(0,0,0,.55);backdrop-filter:blur(24px)}
[data-theme="light"] #modalBox{background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(255,255,255,.88))}
#modalBox.shake{animation:shake .35s ease}
@keyframes shake{0%,100%{transform:translateX(0)}15%{transform:translateX(-7px)}35%{transform:translateX(7px)}55%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.modal-icon{width:50px;height:50px;border-radius:17px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.13);background:linear-gradient(135deg,rgba(139,92,246,.28),rgba(34,211,238,.18))}
.modal-icon svg{width:24px;height:24px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.modal-title{margin:0 0 6px;font-size:20px;letter-spacing:-.02em}
.modal-text{margin:0 0 20px;color:var(--muted);font-size:14px;line-height:1.6}
.field{display:grid;gap:6px;margin-bottom:13px}
.field label{font-size:13px;font-weight:600;color:var(--muted)}
.input{width:100%;padding:11px 14px;border-radius:var(--r-md);border:1px solid var(--stroke);background:rgba(255,255,255,.06);color:var(--text);outline:none;font-size:14px;transition:border-color .2s,box-shadow .2s}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,92,246,.18)}
.input-row{display:flex;gap:8px}
.input-row .input{flex:1}
.error-msg{min-height:20px;font-size:13px;color:var(--accent3);margin-bottom:12px}
.modal-actions{display:flex;gap:10px}
.modal-actions .btn{flex:1;min-height:44px}
.spinner{width:15px;height:15px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:galSpin .7s linear infinite;display:none}

/* АДАПТИВ */
@media(max-width:960px){.hero-grid{grid-template-columns:1fr}.hero-right{display:none}.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:680px){.nav{display:none}.grid-2,.grid-3{grid-template-columns:1fr}.gallery{grid-template-columns:1fr}.tile,.tile.big{grid-column:span 1}.stats{grid-template-columns:1fr}.metrics{grid-template-columns:1fr}.pipeline{flex-direction:column}.pipe-step{border-right:none;border-bottom:1px solid var(--stroke)}.pipe-step:last-child{border-bottom:none}.res-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cicd-tab span:not(svg){display:none}.cicd-tab{padding:10px 12px}}
@media(max-width:480px){.topbar-inner{min-height:60px;flex-wrap:wrap;padding:10px 0}.actions{width:100%;justify-content:flex-start}.res-grid{grid-template-columns:1fr}}
