:root{
  --kw-bg0:#070A12;
  --kw-bg1:#0B1022;
  --kw-card:transparent;
  --kw-card-solid:#0D1533;
  --kw-text:#EAF0FF;
  --kw-muted:#AAB6E6;
  --kw-border:#25306A;
  --kw-shadow: 0 24px 60px rgba(0,0,0,.45);
  --kw-radius: 16px;

  --kw-accent1:#7C3AED; /* purple */
  --kw-accent2:#22D3EE; /* cyan */
  --kw-accent3:#F97316; /* orange */
  --kw-danger:#FB7185;

  --kw-font: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --kw-font-display: Orbitron, var(--kw-font);
}

/* Accent variants */
.kw-accent-blue{ --kw-accent1:#2563EB; --kw-accent2:#22D3EE; --kw-accent3:#60A5FA; }
.kw-accent-red{ --kw-accent1:#EF4444; --kw-accent2:#FB7185; --kw-accent3:#F97316; }

*{box-sizing:border-box;}
html,body{height:100%;}
body.kw-body{
  margin:0;
  color:var(--kw-text);
  background: radial-gradient(1200px 800px at 20% 10%, rgba(124,58,237,.18), transparent 60%),
              radial-gradient(1000px 700px at 80% 30%, rgba(34,211,238,.15), transparent 55%),
              linear-gradient(180deg, var(--kw-bg0), var(--kw-bg1));
  font-family:var(--kw-font);
}

a{color:inherit;}
a:hover{opacity:.9;}
img{max-width:100%;height:auto;display:block;}

.kw-skip{
  position:absolute;left:-9999px;top:8px;
  padding:10px 14px;border-radius:10px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  color:var(--kw-text); z-index:9999;
}
.kw-skip:focus{left:8px;}

.kw-bg{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background: url('../images/kasafuture.png') center / cover no-repeat fixed;
}
.kw-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(6, 10, 25, .74);
}
.kw-bg__grid{
  position:absolute;inset:-40px;
  z-index:1;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 44px 44px;
  transform: perspective(800px) rotateX(60deg);
  transform-origin: top;
  opacity:.35;
  filter: blur(.2px);
}
.kw-bg__glow{
  position:absolute;inset:-20%;
  z-index:1;
  background: radial-gradient(500px 300px at 40% 20%, rgba(124,58,237,.18), transparent 60%),
              radial-gradient(500px 320px at 70% 40%, rgba(34,211,238,.16), transparent 65%),
              radial-gradient(420px 280px at 60% 85%, rgba(249,115,22,.12), transparent 70%);
}

/* App layout */
.kw-app{
  min-height:100vh;
  display:grid;
  grid-template-columns: 320px 1fr;
  gap:18px;
  padding:18px;
}

.kw-sidebar{
  position:sticky; top:18px;
  height: calc(100vh - 36px);
  border-radius: var(--kw-radius);
  background: linear-gradient(180deg, rgba(13,21,51,.82), rgba(13,21,51,.62));
  border:1px solid rgba(37,48,106,.85);
  box-shadow: var(--kw-shadow);
  overflow:hidden;
  display:flex;flex-direction:column;
}

.kw-sidebar__brand{
  padding:14px 14px 10px;
  display:flex; align-items:center; gap:12px;
  border-bottom: 1px solid rgba(37,48,106,.65);
}
.kw-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex:1;}
.kw-brand__logo{
  width:250px;height:72px;border-radius:0;
  object-fit:contain;
  box-shadow: 0 0 0 1px rgba(255,255,255,.10), 0 0 20px rgba(34,211,238,.12);
}
.kw-sidebar__toggle{
  margin-left:auto;
  width:42px;height:42px;border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  cursor:pointer;
  display:none;
}
.kw-sidebar__toggle span{display:block;height:2px;margin:6px 10px;background:rgba(255,255,255,.55);border-radius:999px;}

/* Brand adjustments */
@media (max-width: 460px){
  .kw-brand__logo{width:200px;height:58px;}
}


.kw-nav{
  padding:14px;
  overflow:auto;
  flex:1;
}
.kw-sidebar__footer{
  padding:14px;
  border-top: 1px solid rgba(37,48,106,.65);
}
.kw-mini{display:flex;align-items:center;gap:10px;color:var(--kw-muted);font-size:12px;}
.kw-mini__dot{width:10px;height:10px;border-radius:50%;
  background: radial-gradient(circle at 30% 30%, #fff, var(--kw-accent2));
  box-shadow: 0 0 18px rgba(34,211,238,.35);
}

.kw-content{
  border-radius: var(--kw-radius);
  overflow:hidden;
  background: linear-gradient(180deg, rgba(11,16,34,.55), rgba(11,16,34,.35));
  border:1px solid rgba(37,48,106,.55);
  box-shadow: var(--kw-shadow);
  min-height: calc(100vh - 36px);
  display:flex;flex-direction:column;
}

/* Topbar */
.kw-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;
  border-bottom: 1px solid rgba(37,48,106,.55);
  background: rgba(8,10,18,.25);
  backdrop-filter: blur(10px);
}
.kw-topbar__left,.kw-topbar__right{display:flex;align-items:center;gap:12px;}
.kw-topbar .moduletable{margin:0;}
.kw-topbar .moduletable > h3{display:none;}

/* Hero */
.kw-hero{
  position:relative;
  padding:18px 18px 10px;
  border-bottom: 1px solid rgba(37,48,106,.55);
}
.kw-hero__media{
  position:absolute; inset:0;
  overflow:hidden;
  opacity:.18;
}
.kw-hero__media img{
  width:100%;height:100%;
  object-fit:cover;
  filter: saturate(1.2) contrast(1.05);
  transform: scale(1.05);
}
.kw-hero__inner{
  position:relative;
  border-radius: var(--kw-radius);
  background: linear-gradient(135deg, rgba(13,21,51,.66), rgba(13,21,51,.28));
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 0 0 1px rgba(37,48,106,.35) inset;
  padding:18px;
  overflow:hidden;
}
.kw-hero__inner:before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(600px 220px at 18% 15%, rgba(34,211,238,.18), transparent 60%),
              radial-gradient(620px 260px at 75% 35%, rgba(124,58,237,.18), transparent 62%),
              radial-gradient(500px 240px at 55% 95%, rgba(249,115,22,.12), transparent 70%);
  pointer-events:none;
}
.kw-hero__badge{
  position:relative;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:999px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:var(--kw-muted);
  font-size:12px;
}

.kw-hero__nav{
  position:relative;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}
.kw-pill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:8px 10px;
  border-radius:999px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color: var(--kw-muted);
  font-size:12px;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
}
.kw-pill:hover{
  background: rgba(255,255,255,.10);
  border-color: rgba(34,211,238,.28);
  color: var(--kw-text);
  transform: translateY(-1px);
}
.kw-pill--primary{
  color: var(--kw-text);
  border-color: rgba(34,211,238,.30);
  background: linear-gradient(135deg, rgba(124,58,237,.55), rgba(34,211,238,.45));
  box-shadow: 0 10px 22px rgba(34,211,238,.10);
}

.kw-hero__title{
  position:relative;
  margin:14px 0 8px;
  font-family:var(--kw-font-display);
  letter-spacing:.10em;
  font-size:40px;
  line-height:1.08;
}
.kw-hero__subtitle{
  position:relative;
  margin:0;
  color:var(--kw-muted);
  font-size:15px;
  max-width: 72ch;
}
.kw-hero__cta{position:relative;display:flex;gap:12px;flex-wrap:wrap;margin-top:16px;}

.kw-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;
  border-radius: 14px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--kw-text);
  font-weight:600;
}
.kw-btn--primary{
  border-color: rgba(34,211,238,.30);
  background: linear-gradient(135deg, rgba(124,58,237,.55), rgba(34,211,238,.45));
  box-shadow: 0 12px 28px rgba(34,211,238,.12);
}
.kw-btn--ghost{
  background: rgba(255,255,255,.03);
}

.kw-hero__stats{
  position:relative;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
  margin-top:16px;
}
.kw-stat{
  padding:12px;border-radius:14px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.kw-stat__num{font-family:var(--kw-font-display);letter-spacing:.08em;font-weight:700;}
.kw-stat__label{color:var(--kw-muted);font-size:12px;margin-top:6px;}

/* Zones & cards */
.kw-main{padding:18px;}
.kw-component{
  padding:0;
  border-radius: var(--kw-radius);
  background: rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
.kw-zone{padding:18px;}
.kw-zone--grid{
  display:grid;
  grid-template-columns: repeat(12, minmax(0,1fr));
  gap:14px;
}
.kw-zone--grid > *{grid-column: span 6;}
@media (max-width: 1100px){
  .kw-app{grid-template-columns: 1fr; padding:12px; gap:12px;}
  .kw-sidebar{position:relative; height:auto;}
  .kw-sidebar__toggle{display:inline-flex;align-items:center;justify-content:center;}
  .kw-sidebar{transform: translateX(0); transition: transform .2s ease;}
  body.kw-sidebar-collapsed .kw-sidebar{transform: translateX(-105%); position:fixed; left:12px; top:12px; width: 320px; height: calc(100vh - 24px); z-index:1000;}
  body.kw-sidebar-collapsed .kw-content{grid-column:1/-1;}
}
@media (max-width: 760px){
  .kw-hero__title{font-size:30px;}
  .kw-hero__stats{grid-template-columns: 1fr;}
  .kw-zone--grid > *{grid-column: 1 / -1;}
}

.kw-card{
  border-radius: var(--kw-radius);
  background: var(--kw-card);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 0 0 1px rgba(37,48,106,.35) inset;
  backdrop-filter: blur(10px);
}
.kw-card__header{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);}
.kw-card__title{
  margin:0;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--kw-muted);
}
.kw-card__body{padding:14px;}

/* Breadcrumbs */
.kw-breadcrumbs{padding:10px 18px 0;color:var(--kw-muted);font-size:12px;}
.kw-breadcrumbs .breadcrumb{margin:0;background:transparent;padding:0;}

/* Joomla content tweaks */
.kw-component .page-header{padding:14px;border-bottom:1px solid rgba(255,255,255,.06);}
.kw-component .page-header h1,
.kw-component .page-header h2{margin:0;font-family:var(--kw-font-display);letter-spacing:.06em;}
.kw-component .item-page{padding:14px;}
.kw-component .items-leading, .kw-component .items-row{padding:14px;}
.kw-component .btn, .kw-component input[type="submit"], .kw-component button{
  border-radius:14px !important;
}
.kw-component input, .kw-component textarea, .kw-component select{
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  color:var(--kw-text);
}
.kw-component input:focus, .kw-component textarea:focus, .kw-component select:focus{
  outline:none;
  border-color: rgba(34,211,238,.35);
  box-shadow: 0 0 0 3px rgba(34,211,238,.12);
}

/* Footer */
.kw-footer{
  margin-top:auto;
  border-top: 1px solid rgba(37,48,106,.55);
  padding:14px 18px;
  color:var(--kw-muted);
  font-size:12px;
  background: rgba(8,10,18,.22);
  backdrop-filter: blur(10px);
}
.kw-footer__inner{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.kw-footer__copy a{color:var(--kw-text);text-decoration:none;border-bottom:1px dashed rgba(255,255,255,.25);}

/* Error page */
.kw-error{
  min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px;
}
.kw-error__card{
  width:min(520px, 100%);
  border-radius: var(--kw-radius);
  background: rgba(13,21,51,.70);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--kw-shadow);
  padding:18px;
  text-align:center;
}
.kw-error__logo{width:88px;height:88px;border-radius:22px;object-fit:cover;margin:0 auto 14px;}
.kw-error__title{margin:0;font-family:var(--kw-font-display);letter-spacing:.10em;font-size:46px;}
.kw-error__msg{color:var(--kw-muted);margin:10px 0 0;}
.kw-error__hint{margin:18px 0 0;}

/* Basic menu styling inside sidebar modules */
.kw-sidebar ul.menu,
.kw-sidebar ul.nav,
.kw-sidebar ul.mod-menu{
  list-style:none;margin:0;padding:0;
}
.kw-sidebar ul.menu li,
.kw-sidebar ul.mod-menu li{margin:6px 0;}
.kw-sidebar ul.menu a,
.kw-sidebar ul.mod-menu a{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  border-radius: 14px;
  text-decoration:none;
  color:var(--kw-text);
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
}
.kw-sidebar ul.menu a:hover,
.kw-sidebar ul.mod-menu a:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(34,211,238,.18);
}
.kw-sidebar li.active > a{
  background: linear-gradient(135deg, rgba(124,58,237,.40), rgba(34,211,238,.22));
  border-color: rgba(34,211,238,.25);
  box-shadow: 0 0 0 1px rgba(34,211,238,.12) inset;
}


/* Back to home button on subpages */
.kw-backhome{
  display:flex;
  justify-content:center;
  margin: 22px 0 10px;
}
.kw-backhome .kw-btn{
  padding: 12px 18px;
  border-radius: 16px;
}

.kw-hero__logo{
  max-width: 520px; /* dopasuj */
  width: 100%;
  height: auto;
  display: block;
}