﻿@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Sora:wght@400;500;600;700;800&display=swap");

:root{
  --font-ui:"Plus Jakarta Sans","Sora","Manrope","Segoe UI Variable","Segoe UI",sans-serif;
  --font-title:"Sora","Plus Jakarta Sans","Manrope","Segoe UI Variable","Segoe UI",sans-serif;

  --bg:#eaf0f8;
  --bg-soft:#f4f7fc;
  --panel:rgba(255,255,255,.82);
  --panel-solid:#ffffff;
  --line:#d5e2f0;
  --line-strong:#bed2e8;

  --ink:#0f2138;
  --muted:#5c7691;

  --brand:#0d6cf2;
  --brand-2:#06a5ff;
  --brand-3:#2cc8ad;

  --ok:#159767;
  --warn:#c18200;
  --danger:#c13b35;

  --radius-xs:10px;
  --radius-sm:14px;
  --radius:20px;
  --radius-lg:28px;

  --shadow-xs:0 6px 14px rgba(11,36,68,.08);
  --shadow-sm:0 14px 32px rgba(11,36,68,.10);
  --shadow:0 20px 48px rgba(11,36,68,.14);
  --shadow-lg:0 30px 72px rgba(9,28,54,.20);

  --ease:cubic-bezier(.22,.74,.22,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  min-height:100vh;
  font-family:var(--font-ui);
  color:var(--ink);
  line-height:1.45;
  background:
    radial-gradient(1100px 520px at 90% -10%, rgba(13,108,242,.20) 0%, transparent 58%),
    radial-gradient(900px 460px at -8% 10%, rgba(44,200,173,.16) 0%, transparent 56%),
    linear-gradient(180deg,#eef3fa 0%, #e6edf7 55%, #dde7f3 100%);
  position:relative;
  overflow-x:hidden;
}

body::before,
body::after{
  content:"";
  position:fixed;
  z-index:-1;
  pointer-events:none;
  filter:blur(44px);
  opacity:.42;
}

body::before{
  width:420px;
  height:420px;
  border-radius:48% 52% 58% 42% / 48% 41% 59% 52%;
  background:linear-gradient(145deg, rgba(13,108,242,.44), rgba(6,165,255,.20));
  top:-170px;
  right:-130px;
  animation:ambientFloatA 16s ease-in-out infinite;
}

body::after{
  width:380px;
  height:380px;
  border-radius:52% 48% 42% 58% / 56% 46% 54% 44%;
  background:linear-gradient(145deg, rgba(44,200,173,.34), rgba(13,108,242,.16));
  bottom:-150px;
  left:-110px;
  animation:ambientFloatB 19s ease-in-out infinite;
}

a{color:inherit}
.link{
  color:var(--brand);
  font-weight:800;
  text-decoration:none;
}
.link:hover{text-decoration:underline}
.muted{color:var(--muted)}
.right{text-align:right}

.topbar{
  position:sticky;
  top:0;
  z-index:140;
  isolation:isolate;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  padding:14px 22px;
  color:#f1f8ff;
  background:
    linear-gradient(116deg, rgba(5,24,46,.94) 0%, rgba(8,57,101,.86) 52%, rgba(9,88,145,.82) 100%);
  border-bottom:1px solid rgba(178,214,247,.28);
  box-shadow:0 16px 42px rgba(5,18,35,.30);
  backdrop-filter:blur(14px) saturate(132%);
  transition:padding .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}

.topbar::before,
.topbar::after{
  content:"";
  position:absolute;
  pointer-events:none;
}

.topbar::before{
  z-index:-2;
  left:0;
  right:0;
  bottom:-42px;
  height:92px;
  background:
    radial-gradient(520px 84px at 12% 0%, rgba(68,150,244,.32), transparent 72%),
    radial-gradient(460px 76px at 82% 0%, rgba(44,200,173,.28), transparent 70%);
  opacity:.95;
}

.topbar::after{
  z-index:-1;
  left:20px;
  right:20px;
  top:0;
  height:1px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.58), rgba(255,255,255,.08));
}

.topbar.scrolled{
  padding:10px 18px 11px;
  background:linear-gradient(116deg, rgba(5,22,42,.96), rgba(8,50,90,.90));
  border-bottom-color:rgba(190,222,252,.34);
  box-shadow:0 18px 44px rgba(4,14,29,.34);
}

.brand{
  min-width:230px;
  display:flex;
  align-items:center;
  gap:12px;
}

.brand-badge{
  position:relative;
  width:42px;
  height:42px;
  border-radius:13px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-title);
  font-weight:800;
  color:#0b4e84;
  background:linear-gradient(148deg,#fbfdff 0%, #d9ecff 54%, #c5f0ea 100%);
  border:1px solid rgba(255,255,255,.70);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.82), 0 12px 26px rgba(2,26,50,.32);
}

.brand-badge::after{
  content:"";
  position:absolute;
  inset:-5px;
  border-radius:16px;
  border:1px solid rgba(146,203,255,.46);
  opacity:.78;
  pointer-events:none;
}

.brand-title{
  font-family:var(--font-title);
  font-size:14px;
  font-weight:800;
  letter-spacing:.30px;
  text-transform:none;
}

.brand-sub{
  margin-top:1px;
  font-size:11px;
  opacity:.90;
}

.nav{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  padding:6px;
  border-radius:16px;
  border:1px solid rgba(190,224,255,.18);
  background:linear-gradient(180deg, rgba(8,28,52,.34), rgba(8,28,52,.18));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 10px 24px rgba(4,14,29,.20);
}

.nav a,
.nav-dd summary{
  position:relative;
  isolation:isolate;
  list-style:none;
  text-decoration:none;
  border:1px solid transparent;
  border-radius:12px;
  color:#edf7ff;
  background:rgba(255,255,255,.04);
  font-size:12px;
  font-weight:700;
  letter-spacing:.18px;
  padding:8px 12px;
  cursor:pointer;
  transition:transform .22s var(--ease), background .22s var(--ease), border-color .22s var(--ease), box-shadow .22s var(--ease), color .22s var(--ease);
}

.nav a::before,
.nav-dd summary::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  border-radius:inherit;
  opacity:0;
  background:linear-gradient(135deg, rgba(84,156,245,.34), rgba(44,200,173,.28));
  transition:opacity .22s var(--ease);
}

.nav a:hover,
.nav-dd summary:hover,
.nav a.active,
.nav-dd summary.active,
.nav-dd[open] summary{
  transform:translateY(-1px);
  background:rgba(255,255,255,.16);
  border-color:rgba(173,220,255,.58);
  box-shadow:0 10px 22px rgba(2,16,29,.24);
}

.nav a:hover::before,
.nav-dd summary:hover::before,
.nav a.active::before,
.nav-dd summary.active::before,
.nav-dd[open] summary::before{
  opacity:1;
}

.nav a.active,
.nav-dd summary.active,
.nav-dd[open] summary{
  color:#ffffff;
  border-color:rgba(196,233,255,.74);
  box-shadow:0 12px 24px rgba(2,16,29,.30);
}

.nav a.active::after,
.nav-dd summary.active::after,
.nav-dd[open] summary::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:3px;
  width:16px;
  height:3px;
  border-radius:999px;
  transform:translateX(-50%);
  background:rgba(255,255,255,.94);
}

.nav-dd{
  position:relative;
}

.nav-dd summary::-webkit-details-marker{display:none}

.nav-dd-menu{
  position:absolute;
  top:46px;
  left:0;
  min-width:230px;
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:6px;
  border-radius:15px;
  border:1px solid rgba(184,208,233,.78);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,250,255,.96));
  box-shadow:0 18px 34px rgba(7,22,41,.26);
  backdrop-filter:blur(10px);
}

.nav-dd-menu a{
  color:var(--ink);
  background:transparent;
  border-radius:10px;
  border:1px solid transparent;
  font-size:12px;
  font-weight:700;
  padding:8px 10px;
}

.nav-dd-menu a:hover,
.nav-dd-menu a.active{
  background:linear-gradient(135deg, #e9f4ff, #ecf8ff);
  border-color:#cddff3;
}

.nav-search{
  margin-left:2px;
  display:flex;
  align-items:center;
  gap:6px;
  padding:2px;
  border-radius:999px;
  border:1px solid rgba(177,219,255,.34);
  background:rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14);
}

.nav-search input,
.nav-search button{
  height:34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.26);
  color:#f5faff;
  background:rgba(255,255,255,.10);
  font-size:12px;
}

.nav-search input{
  width:194px;
  padding:8px 12px;
  border-color:transparent;
  background:rgba(255,255,255,.12);
}

.nav-search input::placeholder{color:rgba(240,248,255,.88)}

.nav-search button{
  font-weight:700;
  padding:0 13px;
  cursor:pointer;
  background:linear-gradient(135deg, rgba(94,167,250,.86), rgba(56,203,180,.78));
  border-color:rgba(196,236,255,.64);
  box-shadow:0 8px 16px rgba(4,18,35,.20);
}

.nav-user{
  display:inline-flex;
  align-items:center;
  font-size:12px;
  font-weight:700;
  opacity:.95;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(183,224,255,.34);
  background:rgba(255,255,255,.10);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14);
}

.container{
  width:min(1420px,100%);
  margin:0 auto;
  padding:20px;
  position:relative;
}

.page-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:14px;
}

.h1{
  margin:0;
  font-family:var(--font-title);
  font-size:clamp(28px,4vw,40px);
  font-weight:800;
  letter-spacing:-.55px;
  line-height:1.04;
  color:#0e2138;
}

.lead{
  margin-top:6px;
  color:var(--muted);
  font-size:13px;
  max-width:860px;
}

.row{
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:space-between;
  flex-wrap:wrap;
}

.card{
  position:relative;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  backdrop-filter:blur(10px) saturate(118%);
  padding:15px;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), border-color .28s var(--ease), background .28s var(--ease);
  overflow:hidden;
}

.card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:2px;
  background:linear-gradient(90deg, rgba(13,108,242,.0), rgba(13,108,242,.48), rgba(44,200,173,.42), rgba(13,108,242,.0));
  opacity:.65;
}

.card:hover{
  transform:translateY(-3px);
  border-color:var(--line-strong);
  box-shadow:var(--shadow);
}

.card + .card{margin-top:12px}

.card-t{
  font-family:var(--font-title);
  font-size:17px;
  font-weight:700;
  letter-spacing:.08px;
}

.card-s{
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
}

.card-h{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.btn{
  position:relative;
  overflow:hidden;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:none;
  border-radius:12px;
  padding:10px 14px;
  font-family:var(--font-title);
  font-size:12px;
  font-weight:700;
  letter-spacing:.2px;
  text-decoration:none;
  color:#f6fbff;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  box-shadow:0 10px 20px rgba(13,108,242,.28);
  cursor:pointer;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), filter .2s var(--ease);
}

.btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(112deg, transparent 20%, rgba(255,255,255,.36) 50%, transparent 80%);
  transform:translateX(-120%);
  transition:transform .62s var(--ease);
}

.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(13,108,242,.34);
  filter:saturate(108%);
}

.btn:hover::after{transform:translateX(120%)}

.btn:active{transform:translateY(0)}

.btn.ghost{
  color:var(--ink);
  background:rgba(255,255,255,.72);
  border:1px solid var(--line-strong);
  box-shadow:var(--shadow-xs);
}

.btn.ghost::after{display:none}

.btn.ghost.dark{
  color:var(--ink);
  background:linear-gradient(180deg,#ffffff,#f2f7ff);
  border:1px solid var(--line);
}

.topbar .btn.ghost{
  color:#f1f8ff;
  background:rgba(255,255,255,.12);
  border-color:rgba(176,220,255,.42);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14);
}

.topbar .btn.ghost:hover{
  background:rgba(255,255,255,.20);
  border-color:rgba(214,239,255,.58);
}

.btn.danger{
  color:#fff;
  background:linear-gradient(135deg,#d14b43,#ac2d2a);
  box-shadow:0 10px 22px rgba(168,36,31,.34);
}

.grid2,.grid3,.grid4{display:grid;grid-template-columns:1fr;gap:12px}

@media (min-width:920px){
  .grid2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .grid4{grid-template-columns:repeat(4,minmax(0,1fr))}
}

label{
  display:block;
  margin-bottom:6px;
  color:#2e516f;
  font-size:12px;
  font-weight:700;
}

input,select,textarea{
  width:100%;
  border:1px solid var(--line-strong);
  border-radius:12px;
  background:linear-gradient(180deg,#ffffff,#f8fbff);
  color:var(--ink);
  font-family:inherit;
  font-size:13px;
  padding:10px 11px;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}

textarea{resize:vertical;min-height:90px}

input::placeholder,textarea::placeholder{color:#6d859d}

input:focus,select:focus,textarea:focus,
input:focus-visible,select:focus-visible,textarea:focus-visible,
button:focus-visible,a:focus-visible,summary:focus-visible{
  outline:none;
  border-color:#84b7ff;
  box-shadow:0 0 0 4px rgba(13,108,242,.14);
}

.table-wrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(255,255,255,.64);
}

.grid-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  min-width:640px;
}

.grid-table th,
.grid-table td{
  border-bottom:1px solid var(--line);
  padding:10px 9px;
  text-align:left;
  vertical-align:top;
  font-size:12px;
}

.grid-table th{
  position:sticky;
  top:0;
  z-index:2;
  font-family:var(--font-title);
  color:#2f5576;
  font-weight:700;
  letter-spacing:.12px;
  background:linear-gradient(180deg,#f6faff,#eef5ff);
}

.grid-table tbody tr:nth-child(even) td{background:rgba(252,254,255,.58)}

.grid-table tbody tr:hover td{
  background:rgba(230,242,255,.58);
}

.grid-table tr:last-child td{border-bottom:none}

.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border-radius:999px;
  padding:4px 10px;
  font-size:11px;
  font-weight:700;
  border:1px solid transparent;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65);
}

.pill.ok{background:#ddf7ee;color:#0e7c52;border-color:#b6e8d0}
.pill.warn{background:#fff1d7;color:#9b6700;border-color:#f3d79c}
.pill.bad{background:#ffe1df;color:#ab2e2b;border-color:#f1bcba}
.pill.info{background:#e5f1ff;color:#0e5fa8;border-color:#c9dffa}

.flash{
  border-radius:13px;
  padding:11px 12px;
  margin-bottom:12px;
  font-size:12px;
  font-weight:700;
  border:1px solid transparent;
  box-shadow:var(--shadow-xs);
}

.flash.ok{background:#ddf7ea;color:#0f774d;border-color:#afe3c9}
.flash.error{background:#ffe3e3;color:#ac2d2d;border-color:#efb7b7}

.log-item{
  border:1px solid var(--line);
  border-radius:12px;
  background:linear-gradient(180deg,#ffffff,#f7fbff);
  padding:10px;
  font-size:12px;
  margin-bottom:8px;
  box-shadow:var(--shadow-xs);
}

.empty{color:var(--muted);padding:12px}

.kanban{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding:6px 2px 2px;
}

.kcol{
  min-width:300px;
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.90),rgba(246,251,255,.88));
  box-shadow:var(--shadow-sm);
  padding:11px;
}

.kcol-h{display:flex;justify-content:space-between;align-items:center;gap:8px}

.kcol-t{
  font-family:var(--font-title);
  font-size:13px;
  font-weight:700;
}

.kcol-n{
  min-width:26px;
  text-align:center;
  border-radius:999px;
  background:#e5f1ff;
  color:#0c5fa6;
  border:1px solid #c9dcf4;
  font-size:11px;
  font-weight:700;
  padding:3px 8px;
}

.kcard{
  display:block;
  margin-top:8px;
  border:1px solid var(--line);
  border-radius:12px;
  background:linear-gradient(180deg,#ffffff,#f7fbff);
  box-shadow:var(--shadow-xs);
  padding:10px;
  text-decoration:none;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease);
}

.kcard:hover{
  transform:translateY(-2px);
  border-color:var(--line-strong);
  box-shadow:var(--shadow-sm);
}

.k-title{font-weight:700;font-family:var(--font-title)}
.k-sub,.k-meta{font-size:12px;color:#37566f}

.columns .card{
  background:linear-gradient(180deg,rgba(255,255,255,.90),rgba(247,252,255,.86));
}

.list{display:grid;gap:8px}

.ticket{
  border-left:3px solid rgba(13,108,242,.55);
  transition:transform .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease);
}

.ticket:hover{
  transform:translateY(-1px);
  border-left-color:rgba(44,200,173,.72);
}

.count,
.macroCount{
  font-family:var(--font-title);
  font-weight:700;
}

.warn{color:var(--danger);font-weight:700}

canvas{
  width:100%;
  border:1px solid var(--line);
  border-radius:12px;
  background:linear-gradient(180deg,#ffffff,#f6faff);
}

.reveal{
  opacity:0;
  transform:translateY(14px) scale(.995);
  filter:blur(1.5px);
  transition:opacity .55s var(--ease), transform .55s var(--ease), filter .55s var(--ease);
}

.reveal.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
  filter:none;
}

.mt-8{margin-top:8px}
.mt-10{margin-top:10px}
.mt-12{margin-top:12px}
.mt-14{margin-top:14px}
.mt-16{margin-top:16px}

::-webkit-scrollbar{height:10px;width:10px}
::-webkit-scrollbar-track{background:rgba(220,232,246,.66)}
::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,#91b4da,#6f97c2);
  border-radius:999px;
  border:2px solid rgba(220,232,246,.66);
}

@media (max-width:1200px){
  .container{padding:16px}
  .grid-table{min-width:580px}
}

@media (max-width:980px){
  .topbar{padding:12px}
  .brand{min-width:auto}
  .brand-sub{display:none}
  .nav{
    width:100%;
    justify-content:flex-start;
    gap:6px;
  }
  .nav a,
  .nav-dd summary{
    padding:7px 10px;
    font-size:11.5px;
  }
  .nav-search{
    margin-left:auto;
  }
  .nav-search input{width:146px}
}

@media (max-width:760px){
  .container{padding:12px}
  .card{padding:12px}
  .btn{padding:9px 12px}
  .grid-table th,.grid-table td{padding:9px 7px;font-size:11.5px}
  .h1{font-size:30px}
  .nav-user{display:none}
  .nav{padding:5px}
  .nav-search input{width:124px}
  .brand-badge{
    width:38px;
    height:38px;
    border-radius:11px;
    font-size:12px;
  }
}

@media (prefers-reduced-motion:reduce){
  *{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{opacity:1;transform:none;filter:none}
}

@keyframes ambientFloatA{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(-20px,18px,0) rotate(7deg)}
}

@keyframes ambientFloatB{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg)}
  50%{transform:translate3d(18px,-16px,0) rotate(-6deg)}
}
