@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--g:#8ace00;--k:#2c251d;--muted:#8c8279;--border:rgba(44,37,29,0.15);--card-bg:rgba(250,247,242,0.95);--shadow:0 12px 35px rgba(44,37,29,0.06);--r:0px;--bg:#eaddcf}
body{font-family:'Space Grotesk',sans-serif;letter-spacing:-0.5px;background:var(--bg);color:var(--k);min-height:100vh;-webkit-font-smoothing:antialiased}
.rippleHost{position:relative;overflow:hidden}
#authScreen{position:fixed;inset:0;background:var(--k);z-index:9999;display:flex;flex-direction:column;align-items:center;padding:40px 20px;overflow-y:auto}
.authSub{font-size:0.7rem;font-weight:900;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:24px;text-align:center}
.authTabs{display:flex;gap:5px;background:var(--bg);padding:5px;margin-bottom:20px;border:1px solid var(--k)}
.authTab{flex:1;padding:10px;border:1px solid transparent;background:transparent;color:var(--muted);font-family:'Space Grotesk',sans-serif;font-size:0.8rem;font-weight:900;cursor:pointer;transition:all 0.15s;text-transform:uppercase}
.authTab.active{background:var(--g);color:var(--k);border:1px solid var(--k)}
.authLogo {
    font-size: 5rem !important; font-weight: 900 !important; color: var(--g) !important;
    text-transform: uppercase; margin-bottom: 20px; text-align: center; letter-spacing: -4px;
    /* Gruby czarny obrys logo */
    text-shadow: -3px -3px 0 var(--k), 3px -3px 0 var(--k), -3px 3px 0 var(--k), 3px 3px 0 var(--k), 8px 8px 0 var(--k) !important;
}.authBox{width:100%;max-width:340px;background:var(--bg);border-radius:0px;padding:30px 24px;border:1px solid var(--k);box-shadow:10px 10px 0 var(--g)}
.field{margin-bottom:15px}
.field label{display:block;font-size:0.75rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--k);margin-bottom:6px;text-align:left}
.field input{width:100%;padding:14px;background:#fff;border:1px solid var(--k);color:var(--k);font-family:'Space Grotesk',sans-serif;font-size:0.95rem;outline:none;transition:0.2s}
.field input:focus{background:#fff;box-shadow:inset 3px 3px 0 rgba(138,206,0,0.4)}
.btnPrimary{width:100%;padding:16px;background:var(--g);color:var(--k);border:1px solid var(--k);font-family:'Space Grotesk',sans-serif;font-size:0.9rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;margin-top:10px;transition:0.2s}
.btnPrimary:hover{background:var(--k);color:var(--g)}
.authSkip{margin-top:18px;text-align:center;font-size:0.8rem;font-weight:400;color:var(--muted);cursor:pointer;transition:0.2s}
.authSkip:hover{color:var(--k)}
header{background:rgba(250,247,242,0.98);backdrop-filter:blur(10px);position:sticky;top:0;z-index:1000;border-bottom:1px solid var(--k)}
.headerBar{display:flex;align-items:center;justify-content:center;position:relative;padding:16px 20px}
.mobileMenuBtn{display:none;background:none;border:none;font-size:1.8rem;color:var(--k);cursor:pointer;position:absolute;left:16px}
.logo{font-size:2.5rem;font-weight:700;letter-spacing:-2px;color:var(--g);text-align:center}
.userPill{
position:absolute;
right:16px;

display:flex;
align-items:center;
gap:8px;

padding:4px 12px 4px 4px;

background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.18),
    rgba(255, 255, 255, 0.06)
) !important;

backdrop-filter: blur(24px) saturate(180%) brightness(1.1) !important;
-webkit-backdrop-filter: blur(24px) saturate(180%) brightness(1.1) !important;

border: 1px solid rgba(255, 255, 255, 0.25) !important;

box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.35),
    inset 0 -1px 1px rgba(255, 255, 255, 0.08),
    0 8px 32px rgba(0, 0, 0, 0.18) !important;

cursor: pointer;
    transition: all 0.25s ease;
}  transition:.25s;
}
.userPill:hover{
background:rgba(255,255,255,0.18);
transform:translateY(-1px);
}
.userPill:hover{background:var(--g)}
.userAvatar{width:28px;height:28px;background:var(--k);display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:600;color:var(--bg);border-radius:50%;object-fit:cover}
.userName{font-size:0.75rem;font-weight:400;color:var(--k);display:none}
nav.tabs{display:flex;overflow-x:auto;scrollbar-width:none;background:var(--card-bg);padding:0;border-bottom:1px solid var(--k)}
nav.tabs::-webkit-scrollbar{display:none}
.tabBtn{flex:1;min-width:70px;padding:16px 15px;background:transparent;border:none;border-right:1px solid var(--border);color:var(--muted);font-family:'Space Grotesk',sans-serif;font-size:0.8rem;font-weight:400;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:0.2s;white-space:nowrap;margin:0}
.tabBtn.active{color:var(--k);background:var(--g);border-right:1px solid var(--k);border-left:1px solid var(--k);font-weight:600}
.mobileNav{display:none;flex-direction:column;background:var(--card-bg);border-bottom:1px solid var(--k);width:100%}
.mobileNav.open{display:flex}
.mobileNav .tabBtn{text-align:left;padding:15px 20px;border-bottom:1px solid var(--border);font-size:0.8rem;border-right:none;border-left:none}
.mobileNav .tabBtn.active{background:var(--g);border-left:none;border-right:none}
.panel{display:none}
.panel.active{display:block;animation:fadeScale 0.3s ease-out both}
@keyframes fadeScale{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.sp{padding:60px 24px 80px;max-width:1000px;margin:0 auto}
.secLabel{font-size:2.8rem;font-weight:400;letter-spacing:-2px;color:var(--k);margin-bottom:40px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--k);padding-bottom:15px}
.card{background:var(--card-bg);border:1px solid var(--k);padding:24px;margin-bottom:20px;position:relative;overflow:hidden;transition:all 0.2s;cursor:pointer;box-shadow:4px 4px 0 rgba(44,37,29,0.05)}
.card:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--g)}
.cardEy{font-size:0.7rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--g);background:var(--k);padding:6px 12px;display:inline-block;margin-bottom:15px}
.cardTitle{font-size:1.6rem;font-weight:600;margin-bottom:15px;color:var(--k);letter-spacing:-1px}
.addBtnSmall{background:var(--k);color:var(--bg);border:1px solid var(--k);border-radius:0px;padding:14px 24px;font-family:'Space Grotesk',sans-serif;font-size:0.8rem;font-weight:600;cursor:pointer;transition:all 0.2s;text-transform:uppercase;letter-spacing:1px}
.addBtnSmall.danger{background:#d44040;color:white;border-color:#d44040}
.addBtnSmall:hover{background:var(--g);color:var(--k)}
.addBtnSmall.adminOnly{background:rgba(44,37,29,0.8);backdrop-filter:blur(8px);color:var(--bg);border:1px solid rgba(255,255,255,0.1);font-family:'Space Grotesk',sans-serif}
.addBtnSmall.adminOnly:hover{background:var(--k)}
.heroSection{position:relative;height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;background:var(--k);border-bottom:1px solid var(--k)}
.heroBg{position:absolute;top:-20%;left:-10%;width:120%;height:140%;background-size:cover;background-position:center;z-index:0;opacity:0.65;will-change:transform;transition:opacity 0.8s ease}
.heroOverlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(44,37,29,0.1) 0%,rgba(44,37,29,0.85) 100%);z-index:1}
.heroContent{position:relative;z-index:2;text-align:center;padding:20px;color:var(--bg);margin-top:20px;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.heroTitle{font-size:5.5rem;font-weight:400;letter-spacing:-4px;margin-bottom:5px;text-shadow:0 10px 30px rgba(0,0,0,0.4)}
.introLayout{max-width:1100px;margin:0 auto;padding:80px 24px 60px;display:flex;gap:60px;align-items:stretch;text-align:left}
.introText{flex:1 1 55%;display:flex;flex-direction:column;justify-content:center}
.introMedia{flex:1 1 45%;display:flex;flex-direction:column;gap:20px;position:relative}
.countdownWrapper{background:var(--g);border:1px solid var(--k);padding:30px 20px;text-align:center;box-shadow:8px 8px 0 rgba(44,37,29,0.15)}
.countdownLabel{font-size:0.8rem;font-weight:600;letter-spacing:3px;color:var(--k);text-transform:uppercase;margin-bottom:10px}
.countdownTimer{font-size:3rem;font-weight:400;color:var(--k);letter-spacing:-2px}
.spotifyLabel{font-size:0.75rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--k);margin-bottom:5px;margin-top:10px}
.spotifyWidget{width:100%;border:1px solid var(--k);overflow:hidden;background:var(--k);position:relative;box-shadow:8px 8px 0 var(--g)}
.marqueeContainer{width:100%;overflow:hidden;background:var(--card-bg);padding:0;border-top:1px solid var(--k);display:flex;height:240px}
.marqueeTrack{display:flex;width:max-content;animation:scrollLeft 1280s linear infinite}
.marqueeContainer:hover .marqueeTrack{animation-play-state:paused}
.marqueeImg{width:240px;height:240px;object-fit:cover;margin:0;padding:0;border-right:1px solid var(--k);flex-shrink:0}
@keyframes scrollLeft{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.txtMarq{width:100%;overflow:hidden;background:var(--g);border-top:1px solid var(--k);border-bottom:1px solid var(--k);padding:8px 0;white-space:nowrap;display:flex}
.txtMarqIn{display:inline-flex;animation:scrollTxt 250s linear infinite;font-weight:700;font-size:0.9rem;color:var(--k);letter-spacing:10px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
@keyframes scrollTxt{to{transform:translateX(-50%)}}
.carGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-top:15px}
.carTable{background:var(--card-bg);color:var(--k);padding:24px;border:1px solid var(--k);box-shadow:4px 4px 0 rgba(44,37,29,0.05)}
.carHeader{font-size:1.6rem;font-weight:400;color:var(--k);border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center;letter-spacing:-1px}
.carRow{font-size:0.95rem;margin-bottom:10px;color:var(--muted);display:flex;justify-content:space-between;align-items:center}
.carRow strong{color:var(--k);text-align:right;max-width:65%;font-weight:600}
.carPassBox{background:var(--bg);padding:15px;margin-top:15px;font-size:0.9rem;color:var(--k);min-height:50px;border:1px solid var(--k);line-height:1.8}
#mapaPanel{height:calc(100vh - 115px);position:relative;background:var(--k);overflow:hidden;border-bottom:1px solid var(--k)}
.croppedMapContainer{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;background:var(--bg)}
.croppedMapContainer iframe {
    position: absolute;
    top: -65px; /* Wysuwa górny pasek mapy poza ekran */
    left: 0;
    width: 100%; /* Zostawia boki w spokoju (0 obcięcia po bokach) */
    height: calc(100% + 150px); /* Dokłada wysunięte 55px z góry i 65px z dołu, żeby schować przyciski */
    border: none;
}

.accMapWrap iframe {
    position: absolute;
    top: -55px;
    left: 0;
    width: 100%;
    height: calc(100% + 120px);
    border: none;
}
.adminMapControls{display:none;position:absolute;bottom:20px;right:20px;background:rgba(250,247,242,0.95);backdrop-filter:blur(10px);padding:24px;border:1px solid var(--k);box-shadow:10px 10px 0 rgba(44,37,29,0.2);z-index:500;color:var(--k);width:340px}
.routeMetrics{display:flex;gap:15px;margin-bottom:20px}
.metricItem{border:1px solid var(--k);padding:12px 15px;flex:1;background:var(--card-bg);text-align:center;box-shadow:3px 3px 0 var(--g)}
.metricItem div{font-size:0.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-weight:600}
.metricItem strong{font-size:1.2rem;color:var(--k);font-weight:600;letter-spacing:-0.5px}
.routeDescriptionBlock{background:rgba(44,37,29,0.04);border-left:4px solid var(--g);padding:15px;font-size:1.05rem;line-height:1.7;color:var(--k);font-weight:500}
.listRow{display:flex;justify-content:space-between;align-items:center;background:var(--card-bg);color:var(--k);padding:15px 20px;margin-bottom:12px;cursor:pointer;transition:0.2s;border:1px solid var(--k);box-shadow:4px 4px 0 rgba(44,37,29,0.05)}
.listRow:hover{transform:translateY(-2px);background:var(--k);color:var(--bg)}
.listRowTitle{font-size:1.2rem;font-weight:600;letter-spacing:-0.5px}
.listRowCount{font-size:0.8rem;color:var(--muted);margin-top:4px}
.listDeleteCb{appearance:none;width:24px;height:24px;border:1px solid #d44040;cursor:pointer;margin-right:15px;display:none;position:relative}
.listDeleteCb:checked{background:#d44040}
.listDeleteCb:checked::after{content:'+';position:absolute;top:-2px;left:6px;color:white;font-size:1.1rem;font-weight:bold;transform:rotate(45deg)}
.editModeActive .listDeleteCb{display:inline-block}
#activeListItems{display:flex;flex-wrap:wrap;gap:10px}
.checkItem{display:inline-flex;align-items:center;padding:12px 18px;background:var(--card-bg);border:1px solid var(--k);transition:0.2s;cursor:pointer;flex:0 1 auto;white-space:nowrap}
.checkItem:hover{background:var(--g)}
.cb{appearance:none;min-width:20px;width:20px;height:20px;border:1px solid var(--k);cursor:pointer;position:relative;margin-right:12px;background:var(--bg)}
.cb:checked{background:var(--k);border-color:var(--k)}
.cb:checked::after{content:'';position:absolute;top:3px;left:7px;width:4px;height:10px;border-right:2px solid var(--g);border-bottom:2px solid var(--g);transform:rotate(45deg)}
.cb:disabled{opacity:0.4;cursor:not-allowed}
.checkItem label{font-size:0.95rem;font-weight:400;cursor:pointer;color:var(--k)}
.checkItem.done label{text-decoration:line-through;color:var(--muted)}
.galleryGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:15px}
.galleryItem{aspect-ratio:1;overflow:hidden;background:#eee;position:relative;border:1px solid var(--k)}
.galleryItem img{width:100%;height:100%;object-fit:cover;transition:0.4s;cursor:pointer}
.galleryItem:hover img{transform:scale(1.05)}
.uploadBtn{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--card-bg);border:1px dashed var(--k);cursor:pointer;font-weight:600;color:var(--muted);font-size:0.9rem;aspect-ratio:1;transition:0.2s}
.uploadBtn:hover{background:var(--g);color:var(--k);border-style:solid}
.modPillWrap {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
}

.modPillWrap > div {
    flex: 1 1 0 !important; /* To wymusi identyczną szerokość dla wszystkich trzech */
    padding: 12px 2px !important; /* Mniejszy padding poziomy */
    font-size: 0.9rem !important; /* Nieco mniejszy font, żeby nie łamało słowa "Prysznic" */
    font-weight: 800 !important;
    text-align: center !important;
    border: 2px solid var(--k) !important;
    white-space: nowrap !important; /* Blokuje łamanie linii */
    overflow: hidden !important;
    text-overflow: ellipsis !important; /* Jeśli będzie za wąsko, doda kropki */
}
.swal2-popup{border-radius:0px!important;border:1px solid var(--k)!important;padding:2.5em!important;box-shadow:15px 15px 0 rgba(44,37,29,0.15)!important;background:var(--card-bg)!important;font-family:'Space Grotesk',sans-serif!important;letter-spacing:-0.5px!important;position:relative}
.swal2-close{color:#d44040!important;font-size:2.5rem!important;border:none!important;outline:none!important;position:absolute;top:10px;right:15px}
.swal2-close:hover{background:transparent!important;color:var(--k)!important}
.swal2-title{color:var(--k)!important;font-size:2.2rem!important;font-weight:400!important;letter-spacing:-1.5px!important;margin-bottom:25px!important}
.swal2-html-container{color:var(--k)!important}
.adminLabel{font-size:0.75rem;color:var(--muted);font-weight:600;text-transform:uppercase;display:block;text-align:left;margin-bottom:8px;margin-top:15px;letter-spacing:1px}
.swal2-input,.swal2-textarea{background:var(--bg)!important;border:1px solid var(--k)!important;color:var(--k)!important;border-radius:0px!important;font-size:1rem!important;width:100%!important;margin:0 0 10px 0!important;box-sizing:border-box!important;transition:0.2s!important;box-shadow:none!important}
.swal2-input:focus,.swal2-textarea:focus,.swal2-select.passSel:focus{background:#fff!important;box-shadow:inset 3px 3px 0 rgba(138,206,0,0.4)!important}
.swal2-textarea{min-height:120px!important;padding:15px!important}
.swal2-confirm{background-color:var(--g)!important;color:var(--k)!important;border:1px solid var(--k)!important;border-radius:0px!important;font-weight:600!important;padding:14px 30px!important;text-transform:uppercase!important;letter-spacing:1px!important}
.swal2-deny{background-color:#d44040!important;color:white!important;border:1px solid var(--k)!important;border-radius:0px!important;font-weight:600!important;padding:14px 30px!important;text-transform:uppercase!important;letter-spacing:1px!important;margin-left:10px!important}
.swal2-cancel{background-color:#d44040!important;color:white!important;border:1px solid var(--k)!important;border-radius:0px!important;font-weight:600!important;padding:14px 30px!important;text-transform:uppercase!important;letter-spacing:1px!important;margin-left:10px!important}
.swal2-select.passSel{width:100%!important;margin:0 0 20px 0!important;padding:14px!important;border-radius:0px!important;border:1px solid var(--k)!important;background:var(--bg)!important;font-size:1rem!important;outline:none!important;color:var(--k)!important}
.compact-popup{width:500px!important;padding:1.5em!important}
.compact-popup .swal2-select.passSel{margin:0 0 8px 0!important;padding:10px!important;font-size:0.9rem!important}
.compact-popup hr{margin:15px 0 10px 0!important}
.compact-popup .adminLabel{margin-top:5px!important;margin-bottom:4px!important}
.accPopupGrid{display:grid;grid-template-columns:1fr 1fr;gap:30px;text-align:left}
.accLeft{display:flex;flex-direction:column;gap:15px}
.accRight{position:relative;border:1px solid var(--k);overflow:hidden;background:var(--bg);min-height:300px}
.accRight img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:0;transition:opacity 0.8s ease}
.accRight img.active{opacity:1}
.accMapWrap{width:100%;height:200px;overflow:hidden;border:1px solid var(--k);position:relative}
.accMapWrap iframe{position:absolute;top:-100px;left:-80px;width:calc(100% + 160px);height:calc(100% + 200px);border:none}
.accCardBanner{width:calc(100% + 48px);height:180px;object-fit:cover;margin:-24px -24px 20px -24px;border-bottom:1px solid var(--k);display:block}
#onlinePanel{display:none;position:fixed;bottom:24px;left:24px;background:var(--k);padding:15px 20px;border:1px solid #444;z-index:2000;box-shadow:8px 8px 0 rgba(138,206,0,0.2)}
.onlineHeader{font-size:0.65rem;font-weight:600;letter-spacing:2px;color:var(--g);margin-bottom:12px;text-transform:uppercase}
#chatWidget{position:fixed;bottom:24px;right:24px;z-index:9000;display:none}
.chat-toast{background:var(--g);color:var(--k);padding:15px 20px;font-weight:700;cursor:pointer;display:none;box-shadow:6px 6px 0 var(--k);border:1px solid var(--k);max-width:300px;word-wrap:break-word;font-size:0.9rem;opacity:0;transition:opacity 0.3s;margin-bottom:10px}
.chat-toast.show{display:block;opacity:1}
.chat-launcher{background:var(--k);color:var(--g);padding:14px 24px;font-weight:600;cursor:pointer;border:1px solid var(--k);box-shadow:6px 6px 0 rgba(44,37,29,0.3);font-size:0.85rem;text-transform:uppercase;letter-spacing:1px;font-family:'Space Grotesk',sans-serif;transition:transform 0.15s;width:100%;display:block}
.chat-launcher:hover{transform:translateY(-2px)}
.chat-window{display:none;width:340px;background:var(--card-bg);border:1px solid var(--k);box-shadow:10px 10px 0 rgba(44,37,29,0.2);flex-direction:column;height:500px}
#chatWidget.expanded .chat-launcher{display:none}
#chatWidget.expanded .chat-window{display:flex;animation:chatOpen .3s ease}
@keyframes chatOpen{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.chat-header{background:var(--k);color:var(--g);padding:16px 20px;font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:0.85rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--k)}
.chat-tabs{display:flex;background:var(--bg);border-bottom:1px solid var(--k);overflow-x:auto;scrollbar-width:none}
.chat-tabs::-webkit-scrollbar{display:none}
.chat-tab{padding:12px 15px;font-size:0.75rem;font-weight:600;color:var(--muted);cursor:pointer;white-space:nowrap;border-right:1px solid var(--k);text-transform:uppercase}
.chat-tab.active{background:var(--g);color:var(--k);font-weight:700}
.chatMessagesBox{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:15px;background:var(--bg)}
.chatMsg{background:white;padding:12px 16px;max-width:85%;align-self:flex-start;font-size:0.95rem;line-height:1.4;word-break:break-word;color:#111;border:1px solid var(--k)}
.chatMsg.own{background:var(--g);align-self:flex-end}
.chatAuthor{font-size:0.7rem;font-weight:600;color:var(--muted);margin-bottom:4px;text-transform:uppercase}
.chatMsg.own .chatAuthor{color:var(--k);opacity:0.8}
.chatInputArea{display:flex;padding:15px;background:var(--card-bg);border-top:1px solid var(--k)}
.chatInputArea input{flex:1;padding:12px 15px;border:1px solid var(--k);outline:none;font-size:0.95rem;background:#fff;transition:0.2s;font-family:'Space Grotesk',sans-serif}
.chatInputArea input:focus{box-shadow:inset 2px 2px 0 var(--k)}
.chatInputArea button{padding:0 20px;margin-left:10px;background:var(--k);color:var(--g);border:1px solid var(--k);font-weight:600;cursor:pointer;transition:0.2s;text-transform:uppercase;font-family:'Space Grotesk',sans-serif}
.tentBanner{background:var(--g);color:var(--k);padding:20px;border:1px solid var(--k);margin-bottom:25px;box-shadow:6px 6px 0 rgba(44,37,29,0.1);display:flex;justify-content:space-between;align-items:center}
.tentBannerText{font-size:1.1rem;font-weight:600;line-height:1.4}
.profileCard{text-align:center;padding:30px 20px}
.avatarLarge{width:90px;height:90px;border-radius:50%;border:2px solid var(--k);object-fit:cover;margin:0 auto 15px;display:block;background:var(--k)}
.rankBadge{background:var(--k);color:var(--g);font-weight:700;font-size:0.75rem;text-transform:uppercase;padding:4px 8px;display:inline-block;margin-bottom:10px;letter-spacing:1px}
#graPanel{background-color:#2b2722;color:#d4c4a8}
#gameTitleScreen{text-align:center;padding:90px 20px;max-width:900px;margin:0 auto 20px;background:linear-gradient(270deg,#4ca8d1,#2980b9,#154360,#1f618d);background-size:400% 400%;animation:waveBgAnim 8s ease infinite;border:4px solid #111;box-shadow:10px 10px 0 rgba(0,0,0,0.5);position:relative;overflow:hidden}
.vhs-wrapper{position:relative;display:inline-block;width:100%;max-width:900px;box-shadow:10px 10px 0 rgba(0,0,0,0.7);margin:0 auto}
#gameCanvas{display:block;width:100%;background:#4ca8d1;border:4px solid #111;filter:contrast(1.2) brightness(0.95) saturate(1.1) sepia(0.15);outline:none}
.vhs-overlay{position:absolute;inset:0;background:linear-gradient(rgba(18,16,16,0) 50%,rgba(0,0,0,0.15) 50%),linear-gradient(90deg,rgba(255,0,0,0.03),rgba(0,255,0,0.01),rgba(0,0,255,0.03));background-size:100% 4px,6px 100%;pointer-events:none;z-index:10}
.gameSetupBox{background:#3e362e;border:1px solid #111;padding:20px;max-width:900px;margin:0 auto 20px;box-shadow:6px 6px 0 rgba(0,0,0,0.5);color:#eaddcf}
.gameLeaderboard{background:#2c251d;border:1px solid #111;padding:20px;margin-top:20px;max-width:900px;margin:0 auto;color:#eaddcf}
.glRow{display:flex;justify-content:space-between;padding:10px;border-bottom:1px solid rgba(255,255,255,0.1);font-weight:600}
.glRow:nth-child(even){background:rgba(0,0,0,0.2)}
#previewCanvas{width:180px;height:180px;background:#4ca8d1;border:4px solid #111;display:block;margin:0 auto;max-width:100%}
.levelOverlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.4) 30%,rgba(0,0,0,0.4) 70%,rgba(0,0,0,0.85) 100%);z-index:20;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:40px 20px;color:white}
@keyframes waveBgAnim{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@media(min-width:601px){.userName{display:block}}
@media(max-width:768px){.introLayout{flex-direction:column;padding:40px 24px}.introMedia{order:1}.introText{order:2;text-align:center}.accPopupGrid{grid-template-columns:1fr}.accRight{height:250px}.gameSetupBox{flex-direction:column}}
@media(max-width:600px){.authLogo{font-size:4rem}.logo {
    font-size: 3.4rem !important;
    font-weight: 900 !important;
    letter-spacing: -3px !important;
    color: var(--g) !important;
    text-shadow: 4px 4px 0 var(--k), 1px 1px 0 var(--k) !important;
    transition: 0.2s !important;
}.secLabel{font-size:2.2rem;flex-direction:column;align-items:flex-start;gap:15px}.secLabel div{align-self:flex-end;width:100%}.secLabel .addBtnSmall{width:100%;text-align:center;padding:14px}.carGrid{grid-template-columns:1fr}.heroTitle{font-size:4rem}.adminMapControls{right:10px;left:10px;bottom:10px;width:auto}.swal2-popup{width:95%!important;padding:1.5em!important}#chatWidget{right:10px;bottom:10px}#onlinePanel{left:10px;bottom:10px;padding:10px}.tentBanner{flex-direction:column;text-align:center;gap:15px}}
.gameCustomInput {
    width: 100%;
    height: 45px;
    padding: 5px 10px;
    cursor: pointer;
    border: 2px solid #111;
    background: #2c251d;
    color: #eaddcf;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    outline: none;
    transition: 0.2s;
    border-radius: 0;
    appearance: none;
}
.gameCustomInput:focus, .gameCustomInput:hover {
    background: #3e362e;
    border-color: var(--g);
}
input[type="color"].gameCustomInput {
    padding: 2px;
}
input[type="color"].gameCustomInput::-webkit-color-swatch-wrapper {
    padding: 0;
}
input[type="color"].gameCustomInput::-webkit-color-swatch {
    border: 1px solid #111;
}
.logo,
.authLogo,
.heroTitle,
.secLabel,
.cardTitle,
.cardEy,
.btnPrimary,
.addBtnSmall,
.tabBtn,
.authTab,
.swal2-title,
.swal2-html-container,
#gameTitleScreen > div,
.chat-header,
.chat-tab,
.chat-launcher,
.countdownLabel,
.countdownTimer,
.spotifyLabel,
.onlineHeader,
.adminLabel,
.rankBadge,
.gameSetupBox,
.gameLeaderboard,
.tentBannerText {
  font-family: var(--heading-font) !important;
  letter-spacing: -0.04em;
}

.logo,
.authLogo,
.heroTitle,
.secLabel,
#gameTitleScreen > div {
font-family: monospace;
  font-weight: 450 !important;
  text-transform: uppercase;
}

.secLabel {
  line-height: 0.95;
}

.heroTitle {
  font-size: clamp(4.2rem, 8vw, 7rem) !important;
  line-height: 0.9 !important;
}

#gameTitleScreen > div {
  font-size: clamp(4.5rem, 8vw, 7.5rem) !important;
  line-height: 0.9 !important;
}

.logo {
  font-size: 3rem !important;
}

/* === ULEPSZENIA UI / MOBILE / ESTETYKA === */
.headerBar{padding:18px 20px;background:linear-gradient(180deg, rgba(250,247,242,0.98) 0%, rgba(245,238,229,0.98) 100%);box-shadow:0 8px 30px rgba(44,37,29,0.08)}
.logo{font-size:2.8rem;font-weight:700;letter-spacing:-3px;color:var(--g);text-shadow:0 3px 0 rgba(44,37,29,0.14)}
.userPill{border-radius:999px;padding:5px 14px 5px 5px;box-shadow:0 6px 18px rgba(44,37,29,0.10)}
.userPill:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(44,37,29,0.14)}
.userDropdownMenu{background:linear-gradient(180deg,#fff 0%, #f4efe7 100%) !important;border:1px solid var(--k) !important;border-radius:14px !important;box-shadow:0 18px 40px rgba(44,37,29,0.22) !important;overflow:hidden}
.userDropdownBtn{padding:12px 16px !important;color:#b42318 !important;cursor:pointer !important;font-weight:700 !important;font-size:0.92rem !important;transition:all .2s !important}
.userDropdownBtn:hover{background:#fff1f1 !important}
.heroContent{padding:28px 20px 40px}
.heroTitle{font-size:6.2rem;font-weight:700;letter-spacing:-5px;line-height:0.92;text-shadow:0 14px 40px rgba(0,0,0,0.42), 0 3px 0 rgba(138,206,0,0.25)}
.introText h2#mHead{font-weight:700 !important;letter-spacing:-2.5px !important;line-height:1.02 !important;position:relative}
.introText h2#mHead::after{content:'';display:block;width:88px;height:6px;background:linear-gradient(90deg,var(--g),transparent);margin-top:16px}
.spotifyLabel{font-size:0.95rem;font-weight:800;letter-spacing:3px;margin-top:18px;margin-bottom:10px;transform:translateY(8px)}
.card,.carTable{border-radius:18px;box-shadow:0 12px 30px rgba(44,37,29,0.08);position:relative;overflow:hidden}
.card::before,.carTable::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--g),rgba(44,37,29,0.65));opacity:.9}
.card:hover,.carTable:hover{transform:translateY(-3px);box-shadow:0 18px 35px rgba(44,37,29,0.14)}
.carHeader{font-weight:700;letter-spacing:-1.4px}
.carPassBox{border-radius:14px;background:rgba(255,255,255,0.65)}
#mapaPanel{background:radial-gradient(circle at top, rgba(138,206,0,0.16), transparent 38%), linear-gradient(180deg,#2c251d 0%, #201b15 100%)}
#mapaPanel::before{content:'';position:absolute;inset:14px;border:1px solid rgba(255,255,255,0.10);pointer-events:none;z-index:1;border-radius:22px}
.croppedMapContainer{border-radius:24px;inset:14px !important;width:auto !important;height:auto !important;box-shadow:0 20px 50px rgba(0,0,0,0.28)}
.secLabel{font-weight:700;letter-spacing:-2.5px;position:relative;padding-bottom:18px}
.secLabel::after{content:'';position:absolute;left:0;bottom:-1px;width:120px;height:5px;background:linear-gradient(90deg,var(--g),transparent)}
@media(max-width:768px){
  .headerBar{padding:14px 14px 14px 56px}
  .logo{font-size:2.2rem;letter-spacing:-2px}
  .userPill{right:10px;padding:6px 10px 6px 6px;max-width:44px;overflow:hidden;justify-content:center}
  .heroTitle{font-size:4.6rem;letter-spacing:-3px}
  .introText h2#mHead{font-size:2.8rem !important}
  .spotifyLabel{font-size:1rem;letter-spacing:2.4px;transform:translateY(4px)}
  .secLabel{font-size:2.3rem}
  .card,.carTable{border-radius:16px}
}
@media(max-width:600px){
  .mobileMenuBtn{left:12px;font-size:1.65rem;background:#fff;border:1px solid var(--k);width:38px;height:38px;display:flex;align-items:center;justify-content:center;box-shadow:4px 4px 0 rgba(138,206,0,0.55)}
  .headerBar{min-height:68px;padding:14px 12px 14px 58px}
  .logo{font-size:1.95rem}
  .userPill{padding:5px;border-radius:999px;right:8px;box-shadow:0 8px 18px rgba(44,37,29,0.14)}
  .userName{display:none !important}
  .heroSection{min-height:88svh;height:88svh}
  .heroTitle{font-size:3.7rem;line-height:.94;max-width:92vw}
  .introText h2#mHead{font-size:2.25rem !important;margin-bottom:16px !important}
  .spotifyLabel{font-size:1.05rem;letter-spacing:2px;margin-top:20px;margin-bottom:12px;transform:translateY(10px)}
  .secLabel{font-size:1.95rem;gap:12px}
  .userDropdownMenu{min-width:150px !important;right:8px !important}
  .card,.carTable{padding:20px}
  .carHeader{font-size:1.28rem}
  .carRow{flex-direction:column;align-items:flex-start;gap:5px}
  .carRow strong{max-width:100%;text-align:left}
}

/* Pasek przewijania w klimacie strony */
::-webkit-scrollbar { width: 14px; }
::-webkit-scrollbar-track { background: var(--k); border-left: 2px solid var(--g); }
::-webkit-scrollbar-thumb { background: var(--g); border: 2px solid var(--k); }
::-webkit-scrollbar-thumb:hover { background: #fff; }

/* Wymuszenie globalnej kanciastosci w calym kodzie */
* { border-radius: 0 !important; }

/* Efekt szkla dla wszystkich ciemnych przyciskow */
.btnPrimary, .addBtnSmall {
    background: rgba(44, 37, 29, 0.65) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    color: #fff !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}
.btnPrimary:hover, .addBtnSmall:hover {
    background: rgba(138, 206, 0, 0.8) !important;
    color: var(--k) !important;
}


/* Szklany efekt Liquid Glass dla kart z precyzyjnym wykluczeniem ekipy */
.card:not(.profileCard) {
    background: rgba(250, 247, 242, 0.5) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255, 255, 255, 0.4) !important;
}

/* Szklany efekt Liquid Glass dla okien wyskakujacych popup */
.swal2-popup {
    background: rgba(250, 247, 242, 0.65) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255, 255, 255, 0.5) !important;
    box-shadow: 0 24px 60px rgba(44, 37, 29, 0.25) !important;
}

/* Naprawa wielkosci kart ekipy aby kazda byla identyczna */
.profileCard {
    height: 280px !important;
background: var(--chosen-color) !important;
}

/* Usztywnienie ramy panelu mapy zapobiegajace zbednemu przewijaniu strony */
#mapaPanel {
    height: calc(100vh - 150px) !important;
    overflow: hidden !important;
    position: relative;
}

/* Nowy szklany styl zaktualizowanej legendy mapy */
.mapLegendBox {
    position: absolute;
    top: 20px;
    Right: 20px;
    background: rgba(250, 247, 242, 0.65) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255, 255, 255, 0.5) !important;
    padding: 20px;
    color: var(--k) !important;
    z-index: 100;
    box-shadow: 6px 6px 0 rgba(44, 37, 29, 0.15);
    width: 280px;
}
.legendRow {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
    font-size: 0.9rem;
    font-weight: 600;
}
.legendRow svg {
    flex-shrink: 0;
}

/* Pelny szklany liquid glass dla calego chatu i jego skladowych */
.chat-window {
    background: rgba(250, 247, 242, 0.4) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255, 255, 255, 0.4) !important;
}
.chat-header {
    background: rgba(44, 37, 29, 0.75) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}
.chatMessagesBox {
    background: rgba(234, 221, 207, 0.3) !important;
}
.chatInputArea {
    background: rgba(250, 247, 242, 0.4) !important;
    border-top: 1px solid rgba(44, 37, 29, 0.1) !important;
}
.chatMsg:not(.own) {
    background: rgba(255, 255, 255, 0.55) !important;
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
}
/* 1. Ożywienie tła, żeby szkło miało co rozmywać (subtelne plamy koloru) */
body::before {
    content: '';
    position: fixed;
    top: -50vw; 
    left: -50vw; 
    width: 200vw; 
    height: 200vh;
    background: 
        radial-gradient(circle at 30% 70%, rgba(138, 206, 0, 0.06), transparent 40%),
        radial-gradient(circle at 70% 30%, rgba(44, 37, 29, 0.05), transparent 40%);
    z-index: -1;
    pointer-events: none;
    background-attachment: fixed;
}

/* 2. Szklany, przylegający nagłówek (pasek z logo i zakładkami) */
header {
    background: rgba(250, 247, 242, 0.25) !important;
    backdrop-filter: blur(24px) saturate(150%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(150%) !important;
    border-bottom: 3px solid var(--k) !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15) !important;
}
.headerBar { 
    background: transparent !important; 
    box-shadow: none !important; 
}
nav.tabs {
    border-bottom: 3px solid var(--k) !important;
    background: rgba(0, 0, 0, 0.05) !important;
}
.tabBtn {
    font-weight: 800 !important;
    border-right: 2px solid var(--k) !important;
    font-size: 0.9rem !important;
}
.tabBtn.active {
    background: var(--g) !important;
    border-left: 2px solid var(--k) !important;
    border-right: 2px solid var(--k) !important;
    box-shadow: inset 0 -4px 0 var(--k) !important;
    color: var(--k) !important;
}
/* Aktywna zakładka jako szklany, zielony kafelek */
.tabBtn.active {
    background: rgba(138, 206, 0, 0.7) !important; 
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
}

.carTable {
    background: color-mix(in srgb, var(--chosen-color) 70%, transparent) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
}

/* 4. Szklane panele pływające (lista online i przycisk otwierający chat) */
#onlinePanel, .chat-launcher {
    background: rgba(44, 37, 29, 0.65) !important; /* Ciemne, dymione szkło */
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2) !important;
    color: #fff !important;
}

.adminMapControls {
    background: rgba(250, 247, 242, 0.4) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255, 255, 255, 0.4) !important;
}

#gmapLinkInput {
    background: rgba(255, 255, 255, 0.2) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    border: 1px solid rgba(255, 255, 255, 0.5) !important;
    color: var(--k) !important;
}

.chat-launcher {
    background: rgba(44, 37, 29, 0.65) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 2px solid var(--g) !important;
    box-shadow: 0 8px 32px rgba(138, 206, 0, 0.2) !important;
    color: #fff !important;
}

/* Nowy luksusowy wyglad glownych naglowkow na stronie */
.secLabel {
    font-size: 3.4rem !important;
    background: rgba(250, 247, 242, 0.45) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    padding: 24px 30px !important;
    border-left: 8px solid var(--g) !important;
    border-bottom: 1px solid rgba(255,255,255,0.5) !important;
    box-shadow: 12px 12px 0 rgba(44,37,29,0.06);
    margin-bottom: 50px !important;
}
.secLabel::after { 
    display: none !important; 
} 

/* Kanciasta i szklana pigulka uzytkownika */
.userPill { 
    border-radius: 0 !important; 
    border: 2px solid var(--g) !important; 
    background: rgba(44, 37, 29, 0.75) !important; 
    backdrop-filter: blur(12px) !important; 
    -webkit-backdrop-filter: blur(12px) !important; 
    color: #fff !important; 
}
.userName { color: #fff !important; }

/* Kanciaste i szklane menu wylogowania */
.userDropdownMenu { 
    border-radius: 0 !important; 
    border: 2px solid var(--g) !important; 
    background: rgba(44, 37, 29, 0.85) !important; 
    backdrop-filter: blur(16px) !important; 
    -webkit-backdrop-filter: blur(16px) !important; 
    box-shadow: 10px 10px 0 rgba(0,0,0,0.3) !important;
}

/* Okienko dla mapki w etapach i noclegach */
.cardMapRight { 
    width: 260px; 
    flex-shrink: 0; 
    min-height: 220px; 
    border: 2px solid var(--k); 
    background: #111; 
    border-radius: 0; 
}
@media(max-width: 768px) { 
    .cardMapRight { width: 100%; height: 250px; } 
}

/* Nowy, trzystanowy system przyciskow ekwipunku Liquid Glass */
.checkItem3 { 
    display: inline-flex; 
    align-items: center; 
    justify-content: center; 
    padding: 16px 24px; 
    background: rgba(250, 247, 242, 0.5); 
    backdrop-filter: blur(12px); 
    -webkit-backdrop-filter: blur(12px); 
    border: 1px solid rgba(255, 255, 255, 0.5); 
    font-size: 1.05rem; 
    font-weight: 700; 
    cursor: pointer; 
    transition: 0.2s; 
    color: var(--k); 
    user-select: none; 
    box-shadow: 6px 6px 0 rgba(44,37,29,0.05); 
}
.checkItem3:hover { 
    transform: translateY(-2px); 
    box-shadow: 8px 8px 0 var(--g); 
    border-color: var(--g);
}
/* Stan 2: Spakowane (Zielone) */
.checkItem3.state-packed { 
    background: rgba(138, 206, 0, 0.8) !important; 
    border: 2px solid var(--k) !important; 
    color: var(--k); 
    text-decoration: none; 
}
/* Stan 3: Skreslone (Ciemne) */
.checkItem3.state-crossed { 
    background: rgba(44, 37, 29, 0.6) !important; 
    border: 1px solid rgba(255,255,255,0.2) !important;
    color: #fff; 
    text-decoration: line-through; 
    opacity: 0.6; 
}

/* Nowy, mniejszy i szklany styl naglowkow z neonowym cieniem tekstu */
.secLabel {
    font-size: 2.7rem !important;
    background: rgba(250, 247, 242, 0.35) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    padding: 24px 30px !important;
    border-left: 8px solid var(--g) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4) !important;
    box-shadow: 12px 12px 0 rgba(44, 37, 29, 0.08);
    margin-bottom: 50px !important;
    text-shadow: 0 4px 15px rgba(138, 206, 0, 0.5) !important;
}

/* Gwarancja bocznej mapy w listach */
.cardMapRight { 
    width: 280px; 
    flex-shrink: 0; 
    min-height: 220px; 
    border: 2px solid var(--k); 
    background: #111; 
    border-radius: 0 !important; 
}
@media(max-width: 768px) { 
    .cardMapRight { width: 100%; height: 250px; } 
}

/* Kanciasta i szklana pigulka uzytkownika */
.userPill { 
    border-radius: 0 !important; 
    border: 2px solid var(--g) !important; 
    background: rgba(44, 37, 29, 0.75) !important; 
    backdrop-filter: blur(12px) !important; 
    -webkit-backdrop-filter: blur(12px) !important; 
    color: #fff !important; 
}
.userName { color: #fff !important; }

/* Kanciaste i szklane menu wylogowania */
.userDropdownMenu { 
    border-radius: 0 !important; 
    border: 2px solid var(--g) !important; 
    background: rgba(44, 37, 29, 0.85) !important; 
    backdrop-filter: blur(16px) !important; 
    -webkit-backdrop-filter: blur(16px) !important; 
    box-shadow: 10px 10px 0 rgba(0,0,0,0.3) !important;
}

/* Zaktualizowane zielone naglowki z czarnym, twardym cieniem */
.secLabel {
    font-size: 2.7rem !important;
    background: rgba(250, 247, 242, 0.35) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    padding: 24px 30px !important;
    border-left: 8px solid var(--g) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4) !important;
    box-shadow: 12px 12px 0 rgba(44, 37, 29, 0.08);
    margin-bottom: 50px !important;
    color: var(--g) !important; 
    text-shadow: 3px 3px 0 var(--k) !important;
}

.equipmentBullet{
display:flex;
align-items:center;
gap:10px;
width:100%;
}

.bulletDot{
font-size:1.4rem;
font-weight:700;
line-height:1;
}

.itemQty{
margin-left:auto;
font-size:.8rem;
opacity:.7;
font-weight:600;
}

.glass::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;

    background: linear-gradient(
        180deg,
        rgba(255,255,255,0.35),
        rgba(255,255,255,0.05) 40%,
        transparent
    );

    pointer-events: none;
}

/* GŁÓWNE BOKSY: KARTY, AUTA, NAMIOTY, OGŁOSZENIA */
.card, .carTable, .listRow, .checkItem3, .tentBanner, .profileCard {
    border: 3px solid var(--k) !important;
    box-shadow: 6px 6px 0 var(--k) !important;
    border-radius: 0 !important;
    transition: transform 0.2s, box-shadow 0.2s;
    position: relative;
}
.card:hover, .carTable:hover, .listRow:hover {
    transform: translate(-3px, -3px);
    box-shadow: 9px 9px 0 var(--g) !important;
}

/* POTĘŻNE LOGO */
.logo {
    font-size: 3.8rem !important;
    font-weight: 900 !important;
    color: var(--g) !important;
    text-shadow: 
        -2px -2px 0 var(--k), 
         2px -2px 0 var(--k), 
        -2px  2px 0 var(--k), 
         2px  2px 0 var(--k), 
         6px  6px 0 var(--k) !important;
    letter-spacing: -2px !important;
}

/* ZAKŁADKI NA GÓRZE (NAPRAWA ZJEŻDŻANIA) */
nav.tabs {
    display: flex;
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
    border-bottom: 4px solid var(--k);
}
nav.tabs::-webkit-scrollbar { display: none; }

/* UNIWERSALNA NAPRAWA WSZYSTKICH OKIEN POPUP I FORMULARZY */
.swal2-popup {
    border: 4px solid var(--k) !important;
    box-shadow: 10px 10px 0 var(--k) !important;
    border-radius: 0 !important;
    background: #f4efe7 !important;
}
.swal2-title {
    font-weight: 900 !important;
    color: var(--k) !important;
    text-transform: uppercase !important;
}
.swal2-input, .swal2-textarea, .swal2-select, .swal2-file {
    border: 3px solid var(--k) !important;
    box-shadow: 4px 4px 0 rgba(44,37,29,0.15) !important;
    border-radius: 0 !important;
    font-weight: 700 !important;
    color: var(--k) !important;
    background: #fff !important;
}
.swal2-input:focus, .swal2-textarea:focus {
    box-shadow: 4px 4px 0 var(--g) !important;
}
.swal2-confirm {
    background: var(--g) !important;
    color: var(--k) !important;
    border: 3px solid var(--k) !important;
    box-shadow: 4px 4px 0 var(--k) !important;
    border-radius: 0 !important;
    font-weight: 900 !important;
    text-transform: uppercase;
}
.swal2-cancel, .swal2-deny {
    background: #d44040 !important;
    color: #fff !important;
    border: 3px solid var(--k) !important;
    box-shadow: 4px 4px 0 var(--k) !important;
    border-radius: 0 !important;
    font-weight: 900 !important;
    text-transform: uppercase;
}

/* NAPRAWA WIDOKU MOBILNEGO */
@media(max-width: 768px) {
    /* Chowanie paska zakładek */
    nav.tabs { display: none !important; }
    
    /* Wymuszony układ kolumnowy w oknach popup */
    .accPopupGrid { 
        display: flex !important; 
        flex-direction: column !important; 
        gap: 20px !important; 
    }
    .accRight { 
        height: 350px !important; 
        min-height: 350px !important; 
    }
    
    /* Dopasowanie szerokości okien do telefonu */
    .swal2-popup { 
        width: 95% !important; 
        padding: 1.2em !important; 
        margin: 10px !important; 
    }
    
    .secLabel { 
        font-size: 2rem !important; 
        flex-direction: column; 
        align-items: flex-start; 
        gap: 15px; 
    }
    .logo { font-size: 2.8rem !important; }
    .routeMetrics { flex-direction: column !important; gap: 10px !important; }
}

@media(max-width: 768px) {
    /* 1. Układ popupu w pionie */
    .accPopupGrid { 
        display: flex !important; 
        flex-direction: column !important; 
    }
    
    /* 2. Miniatury pod spodem i mniejsze */
    .mobile-thumbs-container { 
        justify-content: center !important; 
        margin-top: 10px !important; 
    }
    .mobile-thumbs-container div { 
        width: 60px !important; 
        height: 60px !important; 
    }
    
    /* 3. Mniejsza mapa i tekst */
    .swal2-html-container { font-size: 0.9rem !important; }
    
    /* 4. Ogólne zwarcie popupu */
    .swal2-popup { 
        width: 95% !important; 
        padding: 15px !important; 
    }
}

@media(max-width: 768px) {
    /* Mapy z marginesami, żeby nie dotykały krawędzi ekranu */
    .cardMapRight {
        display: block !important;
        width: calc(100% - 20px) !important; /* Margines po 15px z każdej strony */
        margin: 10px auto !important;        /* Wyśrodkowanie */
        height: 200px !important;
        border: 3px solid var(--k) !important;
    }
}

/* Wymuszenie pogrubienia tylko dla authScreen */
#authScreen * {
    font-weight: 900 !important;
}

/* Opcjonalnie: upewnij się, że inputy też są ultra-grube */
#authScreen input {
    font-weight: 900 !important;
}



/* Brutalistyczna Legenda z efektem Liquid Glass */
@media(max-width: 768px) {
    .mapLegendBox {
        /* Styl Brutal */
        background: rgba(250, 247, 242, 0.8) !important; /* Tło z lekką przezroczystością */
        backdrop-filter: blur(12px) !important;           /* Liquid Glass */
        border: 3px solid var(--k) !important;            /* Gruba ramka */
        box-shadow: 6px 6px 0 var(--g) !important;        /* Twój charakterystyczny zielony cień */
        padding: 10px !important;
        font-size: 0.75rem !important;
        color: var(--k) !important;
        border-radius: 0 !important;                      /* Usuwamy zaokrąglenia */
        margin: 10px !important;
    }

    /* Pogrubienie tekstów wewnątrz legendy */
    .mapLegendBox, .mapLegendBox * {
        font-weight: 900 !important;
        text-transform: uppercase !important;
    }
}

/* Brutalistyczna Legenda - Globalnie (Desktop i Mobile) */
.mapLegendBox {
    /* Styl Brutal */
    background: rgba(250, 247, 242, 0.8) !important; /* Tło z przezroczystością */
    backdrop-filter: blur(12px) !important;           /* Liquid Glass */
    border: 3px solid var(--k) !important;            /* Gruba ramka */
    box-shadow: 6px 6px 0 var(--g) !important;        /* Zielony cień */
    padding: 15px !important;
    font-size: 0.9rem !important;                     /* Nieco większe na desktopie */
    color: var(--k) !important;
    border-radius: 0 !important;                      /* Ostre krawędzie */
    margin: 15px !important;
    width: fit-content !important;
    text-transform: uppercase !important;
    font-weight: 900 !important;                      /* Pogrubienie */
}

/* Wzmocnienie tekstów wewnątrz legendy */
.mapLegendBox * {
    font-weight: 900 !important;
    text-transform: uppercase !important;
}
/* Stylizacja "korytarza" trasy */
.route-path {
    stroke: #8ace00;       /* Kolor wypełnienia */
    stroke-width: 12px;    /* Grubość korytarza */
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    filter: drop-shadow(2px 2px 0px rgba(0,0,0,0.3));
}

/* Biały obrys trasy - efekt "wycięcia" w mapie */
.route-path-border {
    stroke: #ffffff;
    stroke-width: 16px;    /* Szerszy niż główny korytarz */
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}
@media(max-width: 768px) {
    /* 1. Naprawa nagłówka (logo i menu) */
    .headerBar {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 10px !important;
    }
    .logo {
        font-size: 1.5rem !important; /* Mniejsze logo, żeby się zmieściło */
        position: static !important;
        margin: 0 auto !important;
    }
    .mobileMenuBtn {
        position: static !important;
    }
    .userPill {
        position: static !important;
    }

    /* 2. Legenda - zwinięcie i mniejszy rozmiar */
    .mapLegendBox {
        font-size: 0.65rem !important;
        padding: 8px !important;
        width: 140px !important; /* Węższa legenda */
        top: 10px !important;
        right: 10px !important;
    }
    .mapLegendBox svg {
        width: 16px !important;
        height: 16px !important;
    }

#chatWidget {
    box-sizing: border-box !important;
}
#chatWidget:not(.expanded) {
    bottom: 25px !important; /* Zwiększ tę wartość, jeśli chcesz jeszcze wyżej */
}

@media (max-width: 768px) {
    .logo {
        -webkit-text-stroke: 1px var(--k) !important;
        text-shadow: 3px 3px 0 var(--k) !important;
        filter: none !important;
    }
    
    .logo * {
        text-shadow: none !important;
    }
}


.tent-slider {
    width: calc(100% + 48px);
    height: 180px;
    margin: -24px -24px 20px -24px;
    display: flex !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    scrollbar-width: none !important;
    background-color: var(--k); /* Dodaj ciemne tło pod zdjęcia */
    contain: strict; /* To mówi przeglądarce, żeby nie przeliczała layoutu karty przy zmianie zdjęć */
}

.tent-slider img {
    flex: 0 0 100% !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    scroll-snap-align: center !important;
    backface-visibility: hidden; /* Kolejny trik na płynność GPU */
}
/* Uniwersalny styl dla kart - działa tak samo wszędzie */
.card, .carTable {
    position: relative !important;
    padding: 20px !important; /* Odstęp dla tekstu */
    border: 3px solid var(--k) !important;
    overflow: hidden !important; /* Pilnuje, żeby zdjęcie nie wyciekło poza ramkę */
    box-sizing: border-box !important;
}

/* Obrazek - zawsze wypełnia szerokość karty */
.card > img:first-child, .carTable > img:first-child {
    display: block !important;
    width: calc(100% + 40px) !important; /* + padding karty */
    margin: -20px -20px 20px -20px !important; /* "Wypycha" zdjęcie do krawędzi */
    height: 180px !important;
    object-fit: cover !important;
    border-bottom: 3px solid var(--k) !important;
}

/* Zielony pasek - zawsze na samej górze */
.card::before, .carTable::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 6px !important;
    background: var(--g) !important;
    z-index: 10 !important;
    pointer-events: none !important;
}

.card-content {
    padding: 20px !important; /* Tekst będzie miał swój oddech */
}

/* Efekt płynnego szkła 30% na dowolnym popupie */
.liquid-glass-popup {
    background: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.37) !important;
}