*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── DARK THEME (default) ── */
:root{
  --bg:#0a0d13;
  --bg2:#0f1219;
  --nav-bg:rgba(10,13,19,.92);
  --accent:#00c8e0;
  --accent2:#0066ff;
  --text:#e8ecf4;
  --muted:#7a82a0;
  --border:rgba(255,255,255,.07);
  --card:rgba(255,255,255,.04);
  --card-hover:rgba(255,255,255,.07);
  --map-filter:invert(.88) hue-rotate(180deg) saturate(.75);
  --canvas-opacity:.55;
  --fh:'Space Grotesk',sans-serif;
  --fb:'Inter',sans-serif;
}

/* ── LIGHT THEME ── */
body.light{
  --bg:#f2f5fa;
  --bg2:#e8edf5;
  --nav-bg:rgba(242,245,250,.95);
  --accent:#0077cc;
  --accent2:#0044aa;
  --text:#1c2333;
  --muted:#5a6a85;
  --border:rgba(0,0,0,.09);
  --card:rgba(255,255,255,.75);
  --card-hover:rgba(255,255,255,.95);
  --map-filter:none;
  --canvas-opacity:.18;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.75;overflow-x:hidden;transition:background .4s,color .4s}
#net-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:var(--canvas-opacity);transition:opacity .4s}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.75rem 5%;background:var(--nav-bg);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);transition:padding .3s,background .4s}
nav.scrolled{padding:.55rem 5%}
.logo{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.logo svg{width:57px;height:57px;flex-shrink:0}
.logo-text-wrap{display:flex;flex-direction:column;line-height:1.2}
.logo-text{font-family:var(--fh);font-size:1.25rem;font-weight:700;background:linear-gradient(90deg,#00e5ff,#8b00ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.02em}
body.light .logo-text{background:linear-gradient(90deg,#0077cc,#5500cc);-webkit-background-clip:text;background-clip:text}
.logo-sub{font-size:.6rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.nav-links{list-style:none;display:flex;gap:1.75rem;align-items:center}
.nav-links a{text-decoration:none;color:var(--muted);font-size:.88rem;font-weight:400;letter-spacing:.01em;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--accent);transition:width .25s;border-radius:2px}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1rem}
.nav-cta{display:inline-flex;align-items:center;gap:.45rem;padding:.48rem 1.05rem;background:var(--accent);color:#fff!important;font-family:var(--fh);font-weight:600;border-radius:6px;font-size:.83rem;text-decoration:none;transition:opacity .2s,transform .15s}
body.light .nav-cta{color:#fff!important}
.nav-cta:hover{opacity:.88;transform:translateY(-1px)}

/* ── THEME TOGGLE ── */
.theme-toggle{position:relative;width:46px;height:26px;flex-shrink:0;cursor:pointer}
.theme-toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle-track{position:absolute;inset:0;background:rgba(255,255,255,.12);border:1px solid var(--border);border-radius:13px;transition:background .35s,border-color .35s}
body.light .toggle-track{background:rgba(0,119,204,.15);border-color:rgba(0,119,204,.3)}
.toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#7a82a0;transition:transform .3s,background .3s;display:flex;align-items:center;justify-content:center;font-size:10px;line-height:1}
body.light .toggle-thumb{transform:translateX(20px);background:var(--accent)}
.toggle-thumb::before{content:'🌙'}
body.light .toggle-thumb::before{content:'☀️'}


/* LOGO IMAGE */
.logo-img{width:57px;height:57px;object-fit:contain;flex-shrink:0}
.logo-fallback{flex-shrink:0}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:8rem 5% 5rem;position:relative;z-index:1}
.hero h1{font-family:var(--fh);font-size:clamp(2.4rem,5.5vw,5rem);font-weight:700;line-height:1.1;letter-spacing:-.025em;margin-bottom:1.25rem;max-width:680px;opacity:0;animation:fadeUp .6s .15s ease both}
.hero h1 em{font-style:normal;color:var(--accent)}
#typewriter::after{content:'|';animation:caret .8s infinite;color:var(--accent)}
@keyframes caret{0%,100%{opacity:1}50%{opacity:0}}
.hero>p{font-size:1.05rem;color:var(--muted);max-width:500px;margin-bottom:2.25rem;font-weight:400;line-height:1.75;opacity:0;animation:fadeUp .6s .3s ease both}
.hero-btns{display:flex;flex-wrap:wrap;gap:.85rem;opacity:0;animation:fadeUp .6s .42s ease both}
.btn-primary{display:inline-flex;align-items:center;gap:.45rem;padding:.8rem 1.75rem;background:var(--accent);color:#fff;font-family:var(--fh);font-size:.95rem;font-weight:600;border-radius:6px;text-decoration:none;transition:opacity .2s,transform .2s,box-shadow .2s}
.btn-primary:hover{opacity:.88;transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,119,204,.3)}
.btn-secondary{display:inline-flex;align-items:center;gap:.45rem;padding:.8rem 1.75rem;background:transparent;color:var(--text);font-family:var(--fh);font-size:.95rem;font-weight:500;border:1px solid var(--border);border-radius:6px;text-decoration:none;transition:border-color .2s,transform .2s,background .2s}
.btn-secondary:hover{border-color:rgba(0,200,224,.4);background:rgba(0,200,224,.05);transform:translateY(-2px)}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:2rem;margin-top:3.5rem;padding:2.25rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);opacity:0;animation:fadeUp .6s .56s ease both;flex-wrap:wrap;transition:border-color .4s}
.stat-item{text-align:center}
.stat-num{font-family:var(--fh);font-size:1.75rem;font-weight:700;color:var(--accent);line-height:1}
.stat-label{font-size:.78rem;color:var(--muted);margin-top:.2rem;font-weight:400}
.stat-divider{width:1px;height:40px;background:var(--border)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .65s ease,transform .65s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .65s ease,transform .65s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* ── SECTIONS ── */
section{padding:5rem 5%;position:relative;z-index:1;transition:background .4s}
#uslugi{background:var(--bg2)}
#kontakt{background:var(--bg2)}
#zgloszenie{background:var(--bg)}
.section-label{font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem;font-family:var(--fh)}
.section-title{font-family:var(--fh);font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.18;margin-bottom:.85rem}
.section-sub{color:var(--muted);font-size:.98rem;max-width:480px;line-height:1.7}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.75rem}
.service-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.6rem;transition:border-color .25s,transform .3s,box-shadow .3s,background .4s;position:relative;overflow:hidden;transition-delay:var(--d,0s)}
.service-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.service-card:hover{background:var(--card-hover);border-color:rgba(0,150,200,.22);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.12)}
.service-card:hover::after{transform:scaleX(1)}
.service-icon{width:44px;height:44px;background:rgba(0,150,200,.08);border:1px solid rgba(0,150,200,.14);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;font-size:1.3rem;transition:transform .25s}
.service-card:hover .service-icon{transform:scale(1.1)}
.service-card h3{font-family:var(--fh);font-size:1rem;font-weight:600;margin-bottom:.4rem;color:var(--text)}
.service-card p{font-size:.88rem;color:var(--muted);line-height:1.65}

/* ── WHY ── */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:2.75rem;align-items:center}
.why-list{display:flex;flex-direction:column;gap:1.25rem}
.why-item{display:flex;gap:.9rem;align-items:flex-start;padding:.85rem;border-radius:8px;transition:background .25s}
.why-item:hover{background:rgba(0,150,200,.05)}
.why-num{font-family:var(--fh);font-size:2rem;font-weight:700;color:rgba(0,200,224,.14);line-height:1.1;flex-shrink:0;transition:color .25s;min-width:2.75rem}
body.light .why-num{color:rgba(0,100,180,.15)}
.why-item:hover .why-num{color:rgba(0,200,224,.4)}
body.light .why-item:hover .why-num{color:rgba(0,100,180,.45)}
.why-item h4{font-family:var(--fh);font-size:.95rem;font-weight:600;margin-bottom:.2rem;color:var(--text)}
.why-item p{font-size:.88rem;color:var(--muted);line-height:1.6}
.why-rating-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:2.25rem;text-align:center;position:relative;overflow:hidden;transition:background .4s}
.why-rating-box::before{content:'';position:absolute;top:-40%;left:-40%;width:180%;height:180%;background:conic-gradient(from 0deg,transparent 0%,rgba(0,200,224,.025) 30%,transparent 50%);animation:rotateGlow 10s linear infinite}
@keyframes rotateGlow{to{transform:rotate(360deg)}}
.rating-big{font-family:var(--fh);font-size:4.5rem;font-weight:700;color:var(--accent);line-height:1;position:relative}
.stars{font-size:1.3rem;margin:.6rem 0;letter-spacing:.08em;position:relative}
.rating-sub{color:var(--muted);font-size:.88rem;position:relative}
.reviews-list{display:flex;flex-direction:column;gap:.85rem;margin-top:1.4rem;text-align:left;position:relative}
.review{background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:8px;padding:.9rem 1.1rem;transition:border-color .25s,transform .25s,background .4s}
body.light .review{background:rgba(255,255,255,.6)}
.review:hover{border-color:rgba(0,150,200,.2);transform:translateX(3px)}
.review-text{font-size:.83rem;color:var(--muted);line-height:1.55;margin-bottom:.4rem}
.review-author{font-size:.73rem;color:var(--accent);opacity:.7;font-weight:500}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2.75rem;align-items:start}
.contact-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.75rem;transition:background .4s}
.contact-item{display:flex;gap:.9rem;align-items:flex-start;padding:.9rem 0;border-bottom:1px solid var(--border)}
.contact-item:last-child{border-bottom:none}
.contact-ico{width:38px;height:38px;background:rgba(0,150,200,.08);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;transition:background .25s,transform .25s}
.contact-item:hover .contact-ico{background:rgba(0,150,200,.15);transform:scale(1.08)}
.contact-label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.18rem;font-weight:500}
.contact-val{font-size:.98rem;font-weight:500;color:var(--text)}
.contact-val a{color:var(--accent);text-decoration:none}
.contact-val a:hover{text-decoration:underline}
.hours-table{width:100%;border-collapse:collapse;margin-top:.85rem}
.hours-table tr{border-bottom:1px solid var(--border)}
.hours-table tr:last-child{border-bottom:none}
.hours-table td{padding:.45rem 0;font-size:.88rem;vertical-align:middle}
.hours-day{color:var(--muted);width:55%;padding-right:.5rem}
.hours-time{font-weight:600;color:var(--text);text-align:right;white-space:nowrap}
.closed{color:#cc4444!important;font-weight:600}
.map-placeholder{border-radius:10px;overflow:hidden;border:1px solid var(--border);min-height:360px}
.map-placeholder iframe{width:100%;height:100%;min-height:360px;border:none;filter:var(--map-filter);transition:filter .4s}

/* ── FOOTER ── */
footer{background:var(--bg);border-top:1px solid var(--border);padding:2rem 5%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;position:relative;z-index:1;transition:background .4s}
footer p{font-size:.82rem;color:var(--muted)}
footer a{color:var(--accent);text-decoration:none}
footer a:hover{text-decoration:underline}
.footer-logo{display:flex;align-items:center;gap:.5rem;font-family:var(--fh);font-size:.9rem;font-weight:600;color:var(--text)}
.footer-copy{font-size:.78rem;color:var(--muted);opacity:.6}

/* ── FLOAT ── */
.float-phone{position:fixed;bottom:1.75rem;right:1.75rem;z-index:200;display:flex;align-items:center;gap:.65rem;background:var(--accent);color:#fff;font-family:var(--fh);font-weight:600;font-size:.9rem;padding:.75rem 1.4rem;border-radius:6px;text-decoration:none;box-shadow:0 6px 28px rgba(0,150,200,.3);transition:transform .2s,box-shadow .2s;animation:softPulse 3s infinite}
.float-phone:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(0,150,200,.45)}
@keyframes softPulse{0%,100%{box-shadow:0 6px 28px rgba(0,150,200,.3)}50%{box-shadow:0 6px 38px rgba(0,150,200,.55)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ── FORM ── */
.form-wrap{max-width:680px;margin:2.5rem auto 0}
.form-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:2.25rem 2.5rem;transition:background .4s}
.form-group{margin-bottom:1.4rem}
.form-group label{display:block;font-family:var(--fh);font-size:.8rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.form-group input,.form-group select,.form-group textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--fb);font-size:.97rem;padding:.72rem 1rem;outline:none;transition:border-color .2s,background .2s,color .4s;resize:vertical}
body.light .form-group input,body.light .form-group select,body.light .form-group textarea{background:rgba(255,255,255,.8)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted);opacity:.6}
.form-group select option{background:var(--bg2);color:var(--text)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:rgba(0,150,200,.5);background:rgba(0,150,200,.04)}
.form-footer-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:.5rem}
.form-note{font-size:.82rem;color:var(--muted)}
.form-msg{margin-top:1rem;padding:.7rem 1rem;border-radius:6px;font-size:.88rem;font-weight:500}
.form-ok{background:rgba(0,180,100,.1);border:1px solid rgba(0,180,100,.25);color:#00b464}
.form-err{background:rgba(210,60,60,.1);border:1px solid rgba(210,60,60,.25);color:#cc3333}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .nav-links{display:none}
  .services-grid{grid-template-columns:1fr}
  .why-grid,.contact-grid{grid-template-columns:1fr}
  .stat-divider{display:none}
  .map-placeholder{min-height:240px}
  footer{flex-direction:column;text-align:center}
  .float-phone{bottom:1rem;right:1rem;font-size:.83rem;padding:.65rem 1.1rem}
  .form-card{padding:1.5rem}
}
@media(max-width:1024px) and (min-width:769px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── PERFORMANCE ── */
#net-canvas{will-change:transform}
.service-card{content-visibility:auto;contain-intrinsic-size:0 200px}
.review{content-visibility:auto;contain-intrinsic-size:0 80px}
img{loading:lazy;decoding:async}
