/* 24STUDIO - wspolne style */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#07060d;
  --bg2:#0d0a1c;
  --card:rgba(255,255,255,.024);
  --card2:rgba(255,255,255,.05);
  --bdr:rgba(155,89,255,.16);
  --bdr2:rgba(255,255,255,.08);
  --mg:#9b59ff;
  --mg2:#b07aff;
  --mg-deep:#6010c0;
  --white:#f2eeff;
  --muted:#988dba;
  --muted2:#6b5f8e;
  --green:#22dd88;
  --red:#ff5577;
  --yellow:#ffd44d;
  --nav-h:76px;
  --font:'Schibsted Grotesk','Segoe UI',system-ui,sans-serif;
  --mono:'JetBrains Mono','Cascadia Code',monospace;
  --brand:'Manrope',var(--font);
  --display:'Manrope',var(--font);
}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--white);
  font-family:var(--font);
  line-height:1.6;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* globalna poswiata tla - rozchodzi sie plynnie przez cala strone, bez cietych krawedzi */
body::before{
  content:'';position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(1200px 760px at 50% -240px,rgba(124,58,237,.17),transparent 68%),
    radial-gradient(1000px 700px at 88% 22%,rgba(64,28,150,.09),transparent 70%),
    radial-gradient(900px 700px at 6% 80%,rgba(86,40,190,.07),transparent 72%);
}
/* delikatna siatka techniczna - znika ku dolowi */
body::after{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    linear-gradient(rgba(155,120,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(155,120,255,.022) 1px,transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:radial-gradient(900px 540px at 50% 0,#000 30%,transparent 100%);
  mask-image:radial-gradient(900px 540px at 50% 0,#000 30%,transparent 100%);
}
a{color:inherit}
::selection{background:rgba(155,89,255,.35)}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  transition:background .25s,border-color .25s,backdrop-filter .25s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(7,6,13,.84);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom-color:var(--bdr2);
}
.nav-inner{
  max-width:1500px;margin:0 auto;height:100%;
  display:grid;grid-template-columns:minmax(230px,1fr) auto minmax(230px,1fr);
  align-items:center;
  position:relative;
  padding:0 44px;gap:24px;
}
.nav-logo{
  display:flex;align-items:center;gap:13px;text-decoration:none;
  font-weight:800;font-size:17px;letter-spacing:2px;color:var(--white);
  justify-self:center;flex-shrink:0;user-select:none;
}
.nav-logo img{width:38px;height:38px;border-radius:10px;display:block}
.nav-logo span{font-family:var(--brand);font-weight:800;font-size:17px;letter-spacing:.4px}

.nav-pill{
  justify-self:center;
  display:flex;align-items:center;gap:4px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.085);
  border-radius:999px;
  padding:5px 7px;
  box-shadow:0 18px 54px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
}
.nav-pill a{
  position:relative;color:rgba(242,238,255,.82);text-decoration:none;
  font-size:13.5px;font-weight:600;
  padding:8px 14px;border-radius:0;
  transition:color .18s;white-space:nowrap;
}
.nav-pill a::after{
  content:none;
}
.nav-pill a:hover,
.nav-pill a.ac{color:var(--white);background:transparent}

.nav-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;justify-self:end;min-width:230px;flex-shrink:0;transform:translateX(-24px)}
.nav-right{display:flex;align-items:center;justify-content:flex-end;justify-self:end;gap:14px;flex-shrink:0}
.nav-login{
  color:var(--muted);text-decoration:none;font-size:13.5px;font-weight:600;
  transition:color .18s;white-space:nowrap;
}
.nav-login:hover{color:var(--white)}

/* zalogowany uzytkownik */
.user-chip{
  display:flex;align-items:center;gap:10px;cursor:pointer;position:relative;
  background:rgba(255,255,255,.04);border:1px solid var(--bdr2);
  border-radius:999px;padding:6px 14px 6px 8px;user-select:none;
}
.user-chip .uav{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,#a050ff,#5818b8);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:#fff;
}
.user-chip .uname{font-size:13px;font-weight:700;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.plan-badge{
  font-size:9.5px;font-weight:800;letter-spacing:.6px;
  padding:2.5px 8px;border-radius:999px;white-space:nowrap;
  font-family:var(--mono);
}
.plan-FREE{background:rgba(140,140,160,.18);color:#a9a3c4}
.plan-PLUS{background:rgba(0,170,255,.16);color:#4cc3ff}
.plan-PRO{background:rgba(155,89,255,.2);color:var(--mg2)}
.plan-LIFETIME{background:rgba(255,212,77,.16);color:var(--yellow)}
.user-menu{
  position:absolute;top:calc(100% + 10px);right:0;min-width:200px;
  background:#13102a;border:1px solid var(--bdr);border-radius:14px;
  padding:8px;display:none;box-shadow:0 18px 50px rgba(0,0,0,.55);
}
.user-menu.open{display:block}
.user-menu .um-info{padding:8px 12px;border-bottom:1px solid var(--bdr2);margin-bottom:6px}
.user-menu .um-info .e{font-size:11px;color:var(--muted);word-break:break-all}
.user-menu button{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  color:var(--muted);font-family:inherit;font-size:13px;font-weight:600;
  padding:9px 12px;border-radius:9px;transition:background .15s,color .15s;
}
.user-menu button:hover{background:rgba(255,255,255,.06);color:var(--white)}
.user-menu button.um-edit{color:#c9c3d8}
.user-menu button.um-edit:hover{background:rgba(255,255,255,.055);color:#f3efff}
.user-menu button.um-danger{color:var(--red)}
.user-menu button.um-danger:hover{background:rgba(255,85,119,.1);color:var(--red)}
.user-menu .um-sep{height:1px;background:var(--bdr2);margin:6px 0}
.user-menu .um-plan-row{
  padding:8px 12px 4px;font-size:11px;color:var(--muted2);font-family:var(--mono);
  letter-spacing:.4px;text-transform:uppercase;font-weight:700;
}
.user-menu .um-plan-val{
  color:var(--mg2);font-family:var(--mono);font-size:12px;font-weight:700;
  padding:2px 12px 8px;display:block;
}
.user-menu button.um-sub-yearly{color:var(--green)}
.user-menu button.um-sub-yearly:hover{background:rgba(34,221,136,.07);color:var(--green)}
.user-menu button.um-sub-cancel{color:#ff9f4a}
.user-menu button.um-sub-cancel:hover{background:rgba(255,159,74,.07);color:#ff9f4a}
.user-menu button.um-sub-reactivate{color:var(--mg2)}
.user-menu button.um-sub-reactivate:hover{background:rgba(155,89,255,.08);color:var(--mg2)}
.user-menu .um-expire{
  padding:4px 12px 8px;font-size:11px;color:#ff9f4a;line-height:1.5;
}

/* ============ WYBOR JEZYKA ============ */
.lang-switch{position:relative;flex-shrink:0}
.lang-btn{
  display:flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.04);border:1px solid var(--bdr2);border-radius:10px;
  color:var(--muted);font-family:var(--font);font-size:12px;font-weight:750;
  letter-spacing:.15px;padding:8px 12px;cursor:pointer;
  transition:border-color .18s,color .18s;
}
.lang-btn:hover{border-color:rgba(255,255,255,.12);color:var(--white)}
.lang-btn svg{display:block;opacity:.8}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;min-width:160px;
  background:#13102a;border:1px solid var(--bdr);border-radius:14px;
  padding:6px;display:none;box-shadow:0 18px 50px rgba(0,0,0,.55);z-index:120;
}
.lang-menu.open{display:block}
.lang-menu button{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  color:var(--muted);font-family:var(--font);font-size:13px;font-weight:650;
  padding:9px 12px;border-radius:9px;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  transition:background .15s,color .15s;
}
.lang-menu button:hover{background:rgba(255,255,255,.05);color:var(--white)}
.lang-menu button.on{color:var(--white)}
.lang-menu button .lc{font-family:var(--mono);font-size:10px;color:var(--muted2);letter-spacing:1px}
.mm-langs{
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;
  margin-top:16px;padding-top:16px;border-top:1px solid var(--bdr2);
}
.mm-langs button{
  background:rgba(255,255,255,.04);border:1px solid var(--bdr2);border-radius:9px;
  color:var(--muted);font-family:var(--font);font-size:11.5px;font-weight:750;
  letter-spacing:.15px;padding:7px 13px;cursor:pointer;
}
.mm-langs button.on{color:var(--mg2);border-color:rgba(155,89,255,.45)}

/* ============ PRZYCISKI ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  border-radius:11px;font-weight:700;text-decoration:none;cursor:pointer;
  border:none;font-family:inherit;transition:all .18s;white-space:nowrap;
  letter-spacing:.2px;
}
.btn-primary{
  background:linear-gradient(160deg,#9a4dff 0%,#6d28d9 100%);color:#fff;
  box-shadow:0 0 0 1px rgba(190,130,255,.4) inset,0 10px 32px rgba(110,40,215,.32);
}
.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 0 0 1px rgba(200,150,255,.5) inset,0 14px 38px rgba(120,50,225,.4)}
.btn-ghost{
  background:rgba(255,255,255,.04);color:var(--white);
  border:1px solid var(--bdr2);
}
.btn-ghost:hover{border-color:rgba(155,89,255,.45);background:rgba(155,89,255,.08)}
.btn-sm{padding:9px 20px;font-size:13px}
.btn-lg{padding:15px 34px;font-size:15.5px}

/* ============ HAMBURGER + MOBILE ============ */
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.ham span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all .25s}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{
  display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;z-index:99;
  background:rgba(7,6,13,.98);flex-direction:column;align-items:center;
  justify-content:center;gap:26px;padding:40px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--white);text-decoration:none;font-size:19px;font-weight:700}
.mobile-menu a.ac{color:var(--mg2)}
.mobile-menu .mm-auth{display:flex;flex-direction:column;gap:14px;margin-top:14px;width:min(280px,80vw)}
.mobile-menu .mm-auth .btn{width:100%}

/* ============ SEKCJE / NAGLOWKI ============ */
.section{max-width:1180px;margin:0 auto;padding:90px 32px}
.sec-head{text-align:center;margin-bottom:54px}
.sec-head h2{font-size:clamp(26px,4vw,40px);font-weight:800;letter-spacing:-.8px;margin-bottom:12px}
.sec-head p{color:var(--muted);font-size:16px;max-width:560px;margin:0 auto}
.sec-tag{
  display:inline-block;font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--mg2);
  margin-bottom:14px;
}
.grad-text{
  background:linear-gradient(100deg,#c9a0ff 0%,#9b59ff 45%,#6f8fff 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}

/* ============ KARTY ============ */
.card{
  background:var(--card);border:1px solid var(--bdr2);border-radius:18px;
  padding:30px;transition:border-color .22s,transform .22s,background .22s;
}
.card:hover{border-color:rgba(155,89,255,.4);background:var(--card2);transform:translateY(-4px)}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--bdr2);margin-top:40px}
.footer-inner{
  max-width:1180px;margin:0 auto;padding:54px 32px 40px;
  display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;
}
.footer-brand{max-width:280px}
.footer-brand .fb-logo{display:flex;align-items:center;gap:10px;font-family:var(--brand);font-weight:800;font-size:13.5px;letter-spacing:.7px;margin-bottom:12px}
.footer-brand .fb-logo img{width:28px;height:28px;border-radius:7px}
.footer-brand p{color:var(--muted2);font-size:13px;line-height:1.7}
.footer-cols{display:flex;gap:70px;flex-wrap:wrap}
.footer-col h4{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:16px;font-family:var(--mono)}
.footer-col a{display:block;color:var(--muted2);text-decoration:none;font-size:13.5px;margin-bottom:10px;transition:color .18s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{
  max-width:1180px;margin:0 auto;padding:22px 32px;
  border-top:1px solid rgba(255,255,255,.05);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  color:var(--muted2);font-size:12.5px;
}

/* ============ AUTH (logowanie / rejestracja) ============ */
.auth-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:calc(var(--nav-h) + 30px) 20px 60px;
}
.auth-card{
  width:min(420px,100%);
  background:rgba(16,12,32,.78);
  border:1px solid var(--bdr);border-radius:22px;
  padding:42px 38px;
  box-shadow:0 30px 90px rgba(60,20,140,.28);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
.auth-logo{display:flex;justify-content:center;margin-bottom:20px}
.auth-logo img{width:46px;height:46px;border-radius:12px}
.auth-card h1{font-size:23px;font-weight:800;text-align:center;letter-spacing:-.3px;margin-bottom:6px}
.auth-card .auth-sub{text-align:center;color:var(--muted);font-size:13.5px;margin-bottom:26px}
.gbtn{
  display:flex;align-items:center;justify-content:center;gap:11px;width:100%;
  background:rgba(255,255,255,.05);border:1px solid var(--bdr2);border-radius:12px;
  color:var(--white);font-family:inherit;font-size:14px;font-weight:600;
  padding:13px;cursor:pointer;transition:all .18s;
}
.gbtn:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.18)}
.divider{display:flex;align-items:center;gap:14px;margin:22px 0;color:var(--muted2);font-size:12px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--bdr2)}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;letter-spacing:.3px}
.field input{
  width:100%;background:rgba(255,255,255,.045);border:1px solid var(--bdr2);
  border-radius:11px;color:var(--white);font-size:14px;font-family:inherit;
  padding:12px 15px;outline:none;transition:border-color .18s;
}
.field input:focus{border-color:var(--mg)}
.field input::placeholder{color:var(--muted2)}
.auth-row{display:flex;justify-content:flex-end;margin:-6px 0 18px}
.auth-row a{color:var(--muted);font-size:12.5px;text-decoration:none}
.auth-row a:hover{color:var(--mg2)}
.auth-submit{width:100%;padding:13px;font-size:14.5px}
.auth-alt{text-align:center;color:var(--muted);font-size:13px;margin-top:22px}
.auth-alt a{color:var(--mg2);text-decoration:none;font-weight:600}
.auth-msg{font-size:12.5px;text-align:center;margin-top:14px;min-height:18px;line-height:1.5}
.auth-msg.err{color:var(--red)}
.auth-msg.ok{color:var(--green)}
.auth-note{
  background:rgba(155,89,255,.07);border:1px solid var(--bdr);border-radius:12px;
  padding:14px 16px;font-size:12.5px;color:var(--muted);line-height:1.6;margin-top:18px;
}
.auth-success-icon{font-size:44px;text-align:center;margin:8px 0 16px}

/* ============ STRONY "WKROTCE" ============ */
.soon-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:calc(var(--nav-h) + 30px) 24px 60px;text-align:center;
}
.soon-box{max-width:520px}
.soon-icon{
  width:88px;height:88px;margin:0 auto 28px;border-radius:24px;
  background:rgba(155,89,255,.1);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;font-size:38px;
}
.soon-icon img{width:48px;height:48px}
.soon-box h1{font-size:clamp(28px,5vw,42px);font-weight:800;letter-spacing:-.5px;margin-bottom:14px}
.soon-box p{color:var(--muted);font-size:15.5px;margin-bottom:34px;line-height:1.7}
.soon-badge{
  display:inline-block;background:rgba(155,89,255,.1);border:1px solid var(--bdr);
  border-radius:999px;padding:6px 18px;font-size:11px;color:var(--mg2);font-weight:700;
  letter-spacing:2px;margin-bottom:26px;font-family:var(--mono);
}

/* ============ COOKIE / TOAST ============ */
#cookie-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:rgba(12,9,26,.97);border-top:1px solid var(--bdr);
  padding:16px 24px;backdrop-filter:blur(12px);
}
.cookie-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.cookie-text{flex:1;min-width:200px;font-size:13px;color:var(--muted)}
.cookie-text b{color:var(--white)}
.cookie-btns{display:flex;gap:10px;flex-wrap:wrap}
.cbtn{padding:9px 18px;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;border:none;font-family:inherit}
.cbtn-ok{background:linear-gradient(135deg,#a040ff,#6010c0);color:#fff}
.cbtn-no{background:transparent;border:1px solid var(--bdr);color:var(--muted)}
#toast{
  position:fixed;bottom:24px;right:24px;z-index:10000;background:#16122e;
  border:1px solid var(--bdr);border-radius:12px;padding:13px 20px;font-size:13px;
  font-weight:600;transform:translateY(20px);opacity:0;transition:all .3s;
  pointer-events:none;max-width:340px;
}
#toast.show{transform:translateY(0);opacity:1}
#toast.ok{border-color:var(--green);color:var(--green)}
#toast.er{border-color:var(--red);color:var(--red)}
#toast.wr{border-color:var(--yellow);color:var(--yellow)}

/* ============ CENNIK / PLANY ============ */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1080px;margin:0 auto}
.plan-card{
  position:relative;background:var(--card);border:1px solid var(--bdr2);
  border-radius:20px;padding:34px 30px;display:flex;flex-direction:column;
  transition:border-color .22s,transform .22s,background .22s;
}
.plan-card:hover{transform:translateY(-4px);background:var(--card2)}
.plan-card.hot{
  border-color:rgba(155,89,255,.5);
  background:linear-gradient(180deg,rgba(155,89,255,.07),rgba(255,255,255,.02));
  box-shadow:0 24px 70px rgba(100,40,210,.22);
}
.plan-card .pc-pop{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#9a4dff,#6d28d9);color:#fff;
  font-size:10px;font-weight:800;letter-spacing:1.5px;
  border-radius:999px;padding:5px 16px;white-space:nowrap;
  font-family:var(--mono);
}
.plan-card .pc-name{font-size:14px;font-weight:700;letter-spacing:1px;color:var(--muted);text-transform:uppercase;font-family:var(--mono);margin-bottom:14px}
.plan-card .pc-price{font-size:40px;font-weight:800;letter-spacing:-1.5px;line-height:1;margin-bottom:6px}
.plan-card .pc-price small{font-size:15px;font-weight:600;color:var(--muted);letter-spacing:0}
.plan-card .pc-sub{color:var(--muted2);font-size:12.5px;margin-bottom:24px}
.plan-card ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:28px;flex:1}
.plan-card li{display:flex;gap:10px;font-size:13.5px;color:var(--muted);line-height:1.5;align-items:flex-start}
.plan-card li .ok{color:var(--green);flex-shrink:0;font-weight:800}
.plan-card li .no{color:var(--muted2);flex-shrink:0}
.plan-card li.off{opacity:.45}
.plan-card li b{color:var(--white);font-weight:600}
.plan-card .btn{width:100%;padding:13px 20px;font-size:14px}
@media(max-width:900px){.plans-grid{grid-template-columns:1fr;max-width:440px}}

/* ============ RESPONSIVE ============ */
@media(max-width:1020px){
  .nav-inner{display:flex;justify-content:space-between}
  .nav-pill{display:none}
  .nav-actions{display:none}
  .nav-right{display:none}
  .lang-switch{display:none}
  .ham{display:flex}
}
@media(max-width:768px){
  .nav-inner{padding:0 20px}
  .section{padding:64px 20px}
  .footer-inner{flex-direction:column;gap:34px}
  .footer-cols{gap:40px}
  .auth-card{padding:34px 24px}
}

/* ============ MODAL PROFILU ============ */
.prof-overlay{
  position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,.72);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.prof-modal{
  background:#0f0d26;border:1px solid rgba(155,89,255,.22);
  border-radius:22px;padding:32px 28px;width:min(400px,100%);
  position:relative;max-height:90vh;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:#2a1f50 transparent;
}
.prof-close{
  position:absolute;top:14px;right:14px;
  background:rgba(255,255,255,.06);border:none;
  color:#8877aa;width:28px;height:28px;border-radius:50%;
  cursor:pointer;font-size:16px;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;
}
.prof-close:hover{background:rgba(255,255,255,.14);color:#f0ecff}
.prof-header{
  font-size:16px;font-weight:700;color:#f0ecff;
  text-align:center;margin-bottom:22px;
}
.prof-av-wrap{display:flex;justify-content:center;margin-bottom:22px}
.prof-av{
  width:76px;height:76px;border-radius:50%;cursor:pointer;
  background:linear-gradient(135deg,#9b59ff,#5a18c0);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:700;color:#fff;
  position:relative;overflow:hidden;
  border:2px solid rgba(155,89,255,.35);transition:border-color .2s;
}
.prof-av:hover{border-color:#9b59ff}
.prof-av-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.56);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;color:#fff;letter-spacing:.5px;
  opacity:0;transition:opacity .2s;
}
.prof-av:hover .prof-av-overlay{opacity:1}
.prof-field{margin-bottom:16px}
.prof-label{
  display:block;font-size:10px;font-weight:700;
  color:rgba(155,89,255,.65);letter-spacing:1.5px;
  text-transform:uppercase;margin-bottom:6px;
}
.prof-row{display:flex;gap:8px;align-items:stretch}
.prof-input{
  width:100%;height:44px;padding:0 13px;
  background:rgba(255,255,255,.04);
  border:1.5px solid rgba(155,89,255,.18);
  border-radius:10px;color:#f0ecff;font-size:14px;
  outline:none;font-family:inherit;
  transition:border-color .2s,background .2s;
}
.prof-input:focus{border-color:#9b59ff;background:rgba(155,89,255,.06)}
.prof-input:disabled{opacity:.4;pointer-events:none}
.prof-row .prof-input{flex:1}
.prof-btn{
  height:44px;padding:0 16px;border:none;cursor:pointer;
  background:linear-gradient(135deg,#a040ff,#5a18c0);
  color:#fff;border-radius:10px;
  font-size:13px;font-weight:700;font-family:inherit;
  white-space:nowrap;flex-shrink:0;transition:opacity .18s;
}
.prof-btn:hover{opacity:.88}
.prof-btn:disabled{opacity:.45;cursor:not-allowed}
.prof-pw-save{width:100%;margin-top:4px}
.prof-msg{min-height:16px;font-size:12px;margin-top:5px;line-height:1.5}
.prof-msg.ok{color:#22dd88}
.prof-msg.er{color:#ff5577}
.prof-pw-section{border-top:1px solid rgba(155,89,255,.1);padding-top:14px;margin-top:4px}
.prof-pw-toggle{
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;color:#9b59ff;font-size:14px;font-weight:600;
  padding-bottom:4px;user-select:none;
}
.prof-pw-arrow{font-size:20px;line-height:1;transition:transform .25s}
.prof-pw-form{
  max-height:0;overflow:hidden;
  transition:max-height .3s ease,padding-top .3s ease;
  display:flex;flex-direction:column;gap:8px;padding-top:0;
}
.prof-pw-form.open{max-height:400px;padding-top:14px}
.prof-note{
  font-size:12px;color:#8877aa;padding:8px 11px;
  background:rgba(155,89,255,.07);border-radius:8px;
  line-height:1.5;margin-bottom:0;
}

/* ============ MODAL USTAWIEN ============ */
.set-overlay{
  position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,.72);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.set-modal{
  background:#0f0d26;border:1px solid rgba(155,89,255,.22);
  border-radius:22px;width:min(680px,100%);
  position:relative;max-height:88vh;overflow:hidden;
  display:flex;
}
.set-close{
  position:absolute;top:14px;right:14px;z-index:2;
  background:rgba(255,255,255,.06);border:none;
  color:#8877aa;width:28px;height:28px;border-radius:50%;
  cursor:pointer;font-size:16px;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;
}
.set-close:hover{background:rgba(255,255,255,.14);color:#f0ecff}
.set-side{
  width:172px;flex-shrink:0;padding:22px 10px;
  border-right:1px solid rgba(155,89,255,.12);
  background:rgba(255,255,255,.015);
  display:flex;flex-direction:column;gap:4px;
}
.set-side-title{
  font-size:10px;font-weight:700;letter-spacing:2px;color:var(--muted2);
  text-transform:uppercase;font-family:var(--mono);padding:0 12px 10px;
}
.set-tab{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  color:var(--muted);font-family:inherit;font-size:13.5px;font-weight:600;
  padding:10px 12px;border-radius:10px;transition:background .15s,color .15s;
}
.set-tab:hover{background:rgba(255,255,255,.05);color:var(--white)}
.set-tab.on{background:rgba(155,89,255,.13);color:#cdb3ff}
.set-body{
  flex:1;padding:26px 26px 30px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:#2a1f50 transparent;
}
.set-title{font-size:16px;font-weight:700;color:#f0ecff;margin-bottom:20px}

/* karta billing */
.bill-card{
  background:rgba(255,255,255,.03);border:1px solid rgba(155,89,255,.16);
  border-radius:14px;padding:18px;margin-bottom:14px;
}
.bill-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 0;gap:12px;
}
.bill-row + .bill-row{border-top:1px solid rgba(255,255,255,.045)}
.bill-label{font-size:12.5px;color:var(--muted);font-weight:600}
.bill-val{font-size:13.5px;color:#f0ecff;font-weight:700;text-align:right}
.bill-chip{
  display:inline-block;padding:3px 10px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.4px;
}
.bill-chip.active{background:rgba(34,221,136,.14);color:#22dd88}
.bill-chip.warn{background:rgba(255,159,74,.14);color:#ff9f4a}
.bill-chip.bad{background:rgba(255,85,119,.14);color:#ff5577}
.bill-chip.manual{background:rgba(155,89,255,.16);color:#cdb3ff}
.bill-chip.free{background:rgba(255,255,255,.08);color:var(--muted)}
.bill-note{
  font-size:12.5px;line-height:1.6;border-radius:10px;
  padding:11px 13px;margin-bottom:14px;
}
.bill-note.info{background:rgba(155,89,255,.08);color:#b9a6e0;border:1px solid rgba(155,89,255,.14)}
.bill-note.warn{background:rgba(255,159,74,.09);color:#ffb877;border:1px solid rgba(255,159,74,.18)}
.bill-note.bad{background:rgba(255,85,119,.09);color:#ff8aa3;border:1px solid rgba(255,85,119,.18)}
.bill-actions{display:flex;flex-direction:column;gap:8px}
.bill-btn{
  width:100%;height:42px;border-radius:10px;cursor:pointer;
  font-family:inherit;font-size:13px;font-weight:700;
  transition:opacity .15s,background .15s,color .15s;
  display:flex;align-items:center;justify-content:center;
}
.bill-btn:disabled{opacity:.45;cursor:not-allowed}
.bill-btn.primary{
  background:linear-gradient(135deg,#a040ff,#5a18c0);
  color:#fff;border:none;
}
.bill-btn.primary:hover{opacity:.88}
.bill-btn.ghost{
  background:rgba(255,255,255,.04);color:#c9c3d8;
  border:1.5px solid rgba(155,89,255,.22);
}
.bill-btn.ghost:hover{background:rgba(155,89,255,.09);color:#f0ecff}
.bill-btn.danger{
  background:transparent;color:#ff5577;
  border:1.5px solid rgba(255,85,119,.28);
}
.bill-btn.danger:hover{background:rgba(255,85,119,.09)}
.bill-loading{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:34px 0;color:var(--muted);font-size:13px;
}
.bill-spin{
  width:18px;height:18px;border-radius:50%;
  border:2px solid rgba(155,89,255,.25);border-top-color:#9b59ff;
  animation:billspin .8s linear infinite;
}
@keyframes billspin{to{transform:rotate(360deg)}}

/* personalizacja */
.set-lang-grid{display:flex;flex-wrap:wrap;gap:8px}
.set-lang-btn{
  padding:9px 14px;border-radius:10px;cursor:pointer;
  background:rgba(255,255,255,.04);border:1.5px solid rgba(155,89,255,.16);
  color:var(--muted);font-family:inherit;font-size:13px;font-weight:600;
  transition:border-color .15s,color .15s;
}
.set-lang-btn:hover{color:#f0ecff;border-color:rgba(155,89,255,.4)}
.set-lang-btn.on{color:#cdb3ff;border-color:#9b59ff;background:rgba(155,89,255,.1)}

/* pomoc */
.set-help-link{
  display:block;padding:13px 15px;margin-bottom:8px;border-radius:11px;
  background:rgba(255,255,255,.03);border:1px solid rgba(155,89,255,.14);
  color:#c9c3d8;text-decoration:none;font-size:13.5px;font-weight:600;
  transition:background .15s,border-color .15s;
}
.set-help-link:hover{background:rgba(155,89,255,.08);border-color:rgba(155,89,255,.35)}
.set-help-link .d{font-size:11.5px;color:var(--muted2);font-weight:500;margin-top:3px}

/* ============ MODAL POTWIERDZENIA ============ */
.cf-overlay{
  position:fixed;inset:0;z-index:9500;
  background:rgba(0,0,0,.74);backdrop-filter:blur(5px);
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.cf-modal{
  background:#13102a;border:1px solid rgba(155,89,255,.25);
  border-radius:18px;padding:26px 24px;width:min(400px,100%);
}
.cf-title{font-size:15.5px;font-weight:700;color:#f0ecff;margin-bottom:10px}
.cf-body{font-size:13.5px;color:var(--muted);line-height:1.65;margin-bottom:22px}
.cf-actions{display:flex;gap:10px;justify-content:flex-end}
.cf-btn{
  padding:10px 18px;border-radius:10px;cursor:pointer;
  font-family:inherit;font-size:13px;font-weight:700;
  transition:opacity .15s,background .15s;
}
.cf-btn.cancel{background:rgba(255,255,255,.05);border:1px solid var(--bdr);color:var(--muted)}
.cf-btn.cancel:hover{color:#f0ecff}
.cf-btn.ok{background:linear-gradient(135deg,#a040ff,#5a18c0);border:none;color:#fff}
.cf-btn.ok:hover{opacity:.88}
.cf-btn.ok.danger{background:linear-gradient(135deg,#ff5577,#c0184a)}

@media(max-width:640px){
  .set-modal{flex-direction:column;max-height:92vh}
  .set-side{
    width:100%;flex-direction:row;overflow-x:auto;
    border-right:none;border-bottom:1px solid rgba(155,89,255,.12);
    padding:14px 12px;gap:6px;
  }
  .set-side-title{display:none}
  .set-tab{width:auto;white-space:nowrap;padding:8px 13px;font-size:12.5px}
  .set-body{padding:20px 18px 26px}
}
