/* === styles_updated6.css === */
:root{
  --gold:#C9A24A;
  --navy:#0b1a33;
  --blue-dark:#0f2547;
  --muted:#8ea3c2;
  --glass:rgba(255,255,255,0.05);
  --max-width:1200px;
  --radius:14px;
  --phi:1.618;
  --space-1:.62rem;
  --space-2:1rem;
  --space-3:1.62rem;
  --space-4:2.62rem;
  --space-5:4.24rem;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Montserrat',system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial;
  color:#e6ecf5;
  background:linear-gradient(180deg,var(--blue-dark) 0%,var(--navy) 100%) fixed;
  background-size:cover;
  -webkit-font-smoothing:antialiased;
}

.container{max-width:var(--max-width);margin:0 auto;padding:var(--space-4) var(--space-2)}
.section{position:relative;padding:var(--space-5) 0}
.centered{text-align:center}

.site-header{position:sticky;top:0;z-index:50}
.site-header .header-bg{position:absolute;inset:0;background:rgba(11,26,51,0.72);backdrop-filter:saturate(120%) blur(8px);border-bottom:1px solid rgba(255,255,255,0.06)}
.header-inner{position:relative;display:flex;align-items:center;justify-content:space-between;padding:.8rem 0}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.logo-container{position:relative;width:72px;height:74px;flex-shrink:0}
.site-logo{position:absolute;top:55%;left:50%;transform:translate(-50%,-50%);height:130px;width:auto}
.main-nav ul{list-style:none;display:flex;gap:1.1rem;margin:0;padding:0}
.main-nav a{color:#e6ecf5;text-decoration:none;font-weight:600;padding:.5rem .75rem;border-radius:8px;position:relative}
.main-nav a::after{content:"";position:absolute;left:.6rem;right:.6rem;bottom:.25rem;height:2px;background:transparent;transition:background .2s}
.main-nav a:hover{color:var(--gold)} .main-nav a:hover::after{background:var(--gold)}
.nav-toggle{display:none;background:none;border:1px solid rgba(255,255,255,0.08);color:#ddd;padding:.5rem .7rem;border-radius:8px}

/* HERO */
.hero-section .hero-box{position:relative;border-radius:12px;overflow:hidden;background-image:url(hero.png);background-size:cover;background-position:center;box-shadow:0 12px 40px rgba(0,0,0,.45)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,20,40,0.35),rgba(10,20,40,0.8))}
.hero-inner{position:relative;padding:6rem 2rem;text-align:center}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,2rem);margin:0 0 .6rem;color:var(--gold)}
.hero-sub{font-size:18px;color:#d9e3f0;max-width:920px;margin:0 auto var(--space-3)}
.hero-ctas .btn{margin:.2rem .25rem}
.wave-sep{position:absolute;left:0;right:0;line-height:0;height:120px;bottom:-1px}
.wave-sep svg{width:100%;height:100%} .wave-sep path{fill:rgba(201,162,74,0.14)}

.btn{display:inline-block;padding:.8rem 1.2rem;border-radius:10px;text-decoration:none;font-weight:700;transition:transform .18s ease, box-shadow .18s ease}
.btn-primary{background:var(--gold);color:var(--navy)}
.btn-ghost{border:1px solid rgba(255,255,255,0.15);color:#fff;background:transparent}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,0.3)}

/* DARKER BOX AESTHETIC (nav-tone) */
.box,
.service-card-inner,
.contact-card,
.info-tile {
  padding: 1.4rem;
  background: linear-gradient(180deg, rgba(11,26,51,0.40), rgba(11,26,51,0.28));
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 12px;
}
.photo-frame,
.heading-card{
  background:linear-gradient(180deg, rgba(11,26,51,0.40), rgba(11,26,51,0.28));
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px;
}
.box{padding:calc(var(--space-4) - .4rem);overflow:hidden}
.service-card-inner{padding:var(--space-3)}
.heading-card{padding:1rem 1.2rem;margin:0 auto var(--space-3);text-align:center}

.contact-title {
  margin-bottom: 1.2rem;

  font-weight: 600;
  font-size: 1.4rem;
  text-align: left; /* lub center jeśli tak wolisz */
}

/* Services */
.service-item + .service-item{margin-top:var(--space-3)}
.phi-card{display:grid;grid-template-columns:minmax(0,0.618fr) minmax(0,0.382fr);gap:var(--space-4);align-items:center}
.phi-card.reverse{grid-template-columns:minmax(0,0.382fr) minmax(0,0.618fr)}
.phi-text h3{color:var(--gold);margin:.2rem 0 var(--space-2)}
.actions{display:flex;gap:.4rem;flex-wrap:wrap} /* buttons inline */
.phi-media{display:grid}
.phi-media img{width:100%;height:360px;object-fit:cover;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,0.45)}

/* About */
.about-box{padding:var(--space-4)}
.about-grid{display:grid;grid-template-columns:minmax(0,0.618fr) minmax(0,0.382fr);gap:var(--space-4);align-items:center}
.photo-frame{max-width:360px;margin-left:auto}
.photo-frame img{display:block;width:100%;height:auto}
.about-text ul{color:var(--muted)}

/* Testimonials */
.testimonials h2{text-align:center;margin-bottom:var(--space-3)}
.testimonial-slider{position:relative;max-width:640px;margin:0 auto}
.testimonial{display:none;background:linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.02));padding:var(--space-3);border-radius:12px;text-align:center}
.testimonial.active{display:block}
.testimonial footer{color:var(--muted);font-size:14px}
.testimonial-slider .prev,.testimonial-slider .next{position:absolute;top:50%;transform:translateY(-50%);background:var(--gold);color:var(--navy);border:none;font-size:24px;padding:.2rem .6rem;border-radius:50%;cursor:pointer}
.testimonial-slider .prev{left:-50px}.testimonial-slider .next{right:-50px}

/* Contact */
.phi-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,0.618fr);gap:var(--space-4);align-items:start}
.contact-form{display:flex;flex-direction:column;gap:.75rem}
.contact-form label{font-size:14px;color:var(--muted);display:flex;flex-direction:column;gap:.35rem}
.contact-form input,.contact-form textarea{padding:.75rem;border-radius:8px;border:1px solid rgba(255,255,255,0.12);background:transparent;color:#fff}
.contact-hint{color:var(--muted);font-size:13px;margin:.25rem 0 var(--space-1)}

/* Footer */
.site-footer.typographic.minimal{position:relative;margin-top:var(--space-5);overflow:hidden;background:#0b1a33}
.site-footer .footer-gradient{position:absolute;inset:0;background:
  radial-gradient(1200px 600px at 80% -10%, rgba(201,162,74,0.08), transparent 60%),
  linear-gradient(180deg, rgba(9,18,34,.92), rgba(9,18,34,.98));z-index:0}
.footer-wrap{position:relative;z-index:1}
.footer-top.single-row.swapped{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}
.socials.left{display:flex;gap:.6rem;justify-content:flex-start}
.socials.left a{display:inline-flex;align-items:center;justify-content:center;padding:.4rem .6rem;border:1px solid rgba(255,255,255,0.12);border-radius:999px;text-decoration:none;color:#e6ecf5}
.socials.left a:hover{border-color:var(--gold);color:var(--gold)}
.wordmark.right{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}
.wordmark .motto{font-family:'Playfair Display',serif;font-size:clamp(1.1rem,2vw,1.4rem);color:#e6ecf5}
.wordmark .signature{color:var(--gold);font-weight:600}
.footer-divider.short{height:1px;max-width:420px;margin:var(--space-2) auto;background:rgba(255,255,255,0.5)}
.footer-bottom.small{font-size:.9rem;text-align:center;color:#cfd8e6}

@media (max-width:1100px){
  .phi-card,.phi-card.reverse{grid-template-columns:1fr}
  .phi-media img{height:280px}
}
@media (max-width:980px){
  .main-nav{display:none}
  .nav-toggle{display:inline-block;position:relative;z-index:2}
  .main-nav.open{display:block;position:absolute;left:0;right:0;top:64px;background:linear-gradient(180deg,rgba(11,26,51,0.98),rgba(15,37,71,0.98));padding:1rem;border-bottom:1px solid rgba(255,255,255,0.08)}
  .main-nav.open ul{flex-direction:column;gap:.4rem}
  .about-grid{grid-template-columns:1fr}
  .photo-frame{margin:0 auto}
  .footer-top.single-row.swapped{flex-direction:column;align-items:center;text-align:center}
  .wordmark.right{align-items:center}
}
@media (max-width:520px){
  .hero-title{font-size:clamp(1.6rem,6vw,2.1rem)}
}

/* --- Link telefonu w złotym odcieniu --- */
a[href^="tel"] {
  color: var(--gold);
  text-decoration: none;
  font-weight: 600;
}

a[href^="tel"]:hover {
  text-decoration: underline;
  color: #dcb75f; /* jaśniejszy złoty przy hoverze */
}

.about-grid {
  display: grid;
  align-items: center;
  gap: 1.62rem;
}

.about-photo img {
  width: 100%;
  max-width: 200px;     /* zdjęcie będzie mniejsze i bardziej eleganckie */
  height: auto;
  aspect-ratio: 3/4;     /* profesjonalne proporcje portretowe */
  object-fit: cover;
  border-radius: 14px;   /* łagodniejsze, nowoczesne zaokrąglenie */
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
  display: block;
  margin: 0 auto;
}

.about-grid:nth-child(odd) .about-photo {
  justify-self: end; /* wyrównanie do prawej dla równowagi */
}

.about-grid:nth-child(even) .about-photo {
  justify-self: start; /* gdybyś kiedyś znów dodał obraz po lewej */
}


.about-grid.reverse {
  grid-template-columns: 0.382fr 0.618fr;
}

.about-grid.reverse .about-photo {
  justify-self: start;
}

.about-grid.reverse .about-text {
  justify-self: end;
}


/* === Mobile responsiveness improvements (2025-11-10) === */

/* 1) Make hero typography fluid */
.hero-title{
  font-size: clamp(1.8rem, 4.2vw + 0.2rem, 2.8rem) !important;
}
.hero-sub{
  font-size: clamp(1rem, 2.6vw, 1.125rem) !important;
  line-height: 1.6;
}

/* 2) Avoid fixed image heights; keep aspect ratios */
.phi-media img{
  height: auto !important;
  aspect-ratio: 16 / 10;
}
.about-photo img{
  max-width: min(260px, 90vw);
}

/* 3) Improve header & logo scaling on small screens */
@media (max-width: 980px){
  .logo-container{ width:56px; height:56px; }
  .site-logo{ height:72px; } /* slightly larger than container due to absolute centering */
  .header-inner{ padding: .5rem 0; }
  .main-nav.open{ top:56px; } /* aligns dropdown with smaller header */
}

/* 4) Collapse contact grid on tablets/phones */
@media (max-width: 980px){
  .phi-grid{ grid-template-columns: 1fr !important; }
}

/* 5) Safer testimonial controls on small screens */
@media (max-width: 980px){
  .testimonial-slider{ padding: 0 2.4rem; }
  .testimonial-slider .prev{ left: 8px; }
  .testimonial-slider .next{ right: 8px; }
}

/* 6) Reduce paddings on small screens for better fit */
@media (max-width: 720px){
  .container{ padding: var(--space-3) var(--space-2); }
  .section{ padding: var(--space-4) 0; }
  .hero-inner{ padding: 4rem 1rem; }
  .service-card-inner{ padding: 1rem; }
  .box{ padding: 1rem; }
  .phi-media img{ aspect-ratio: 4 / 3; }
  .btn{ width: 100%; text-align: center; }
}

/* 7) Extra-small tweaks */
@media (max-width: 420px){
  .site-logo{ height:56px; }
  .main-nav a{ padding: .6rem .75rem; }
  .testimonial-slider{ padding: 0 1.6rem; }
  .phi-media img{ aspect-ratio: 1.2 / 1; }
  /* Prevent iOS zoom on inputs */
  .contact-form input,
  .contact-form textarea{
    font-size: 16px;
  }
}
