/* =========================================================
   TEMPLATE AURORA
   Dla: fotografów, artystów, kreatywnych — ciemny z turkusową zorzą
========================================================= */

:root{
--accent-color:#00d296;
--accent-blue:#0096ff;
--accent-glow:rgba(0,210,150,.28);
--accent-soft:rgba(0,210,150,.75);
--text-primary:#e8fff8;
--text-muted:rgba(200,255,240,.55);
}

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap&subset=latin-ext');

html,
body{
margin:0;
padding:0;
}

.landing-main{
margin:0;
padding-bottom:0;
}

.template-aurora .landing-footer{
margin-top:0;
}

.landing-page .section:first-of-type{
padding-top:0;
margin-top:0;
}

.template-aurora{
font-family:"Space Grotesk",system-ui,sans-serif;
color:var(--text-primary);
background:
  radial-gradient(ellipse at 20% 0%, rgba(0,210,150,.16) 0%, transparent 52%),
  radial-gradient(ellipse at 80% 8%, rgba(0,150,255,.12) 0%, transparent 44%),
  radial-gradient(ellipse at 50% 100%, rgba(120,0,255,.08) 0%, transparent 48%),
  #060d10;
}

.template-aurora h1,
.template-aurora h2,
.template-aurora h3{
font-family:"Space Grotesk",system-ui,sans-serif;
letter-spacing:-.02em;
}

/* =========================================================
   SECTIONS
========================================================= */

.template-aurora .section:not(.section-hero){
margin-bottom:20px;
padding-left:8px;
padding-right:8px;
}

.template-aurora .layout-container{
max-width:1400px;
margin:0 auto;
padding-left:26px;
padding-right:26px;
box-sizing:border-box;
}

.template-aurora .section:not(.section-hero) > .layout-container{
max-width:1368px;
padding:34px 40px 44px;
background:rgba(0,210,150,.03);
border:1px solid rgba(0,210,150,.12);
border-radius:24px;
box-shadow:0 0 60px rgba(0,210,150,.04), 0 20px 50px rgba(0,0,0,.3);
}

/* =========================================================
   HEADINGS
========================================================= */

.template-aurora h2{
text-align:center;
font-size:clamp(1.6rem,2.2vw,2.2rem);
margin:0 0 36px;
font-weight:700;
color:var(--text-primary);
}

/* =========================================================
   ABOUT
========================================================= */

.template-aurora .ui-box{
max-width:880px;
margin:0 auto;
padding:28px 32px;
border-radius:18px;
background:rgba(0,210,150,.04);
border:1px solid rgba(0,210,150,.12);
line-height:1.9;
text-align:center;
color:var(--text-muted);
}

.template-aurora .ui-box p{
margin:0;
}

/* =========================================================
   GALLERY
========================================================= */

.template-aurora #upg-gallery{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:16px;
}

.template-aurora .photo-link,
.template-aurora .upg-box,
.template-aurora .upg-photo,
.template-aurora .upg-hover{
cursor:zoom-in;
}

.template-aurora .upg-box{
position:relative;
overflow:hidden;
border-radius:16px;
background:#0a1a14;
border:1px solid rgba(0,210,150,.12);
transition:border-color .25s ease, box-shadow .25s ease;
}

.template-aurora .upg-box:hover{
border-color:rgba(0,210,150,.4);
box-shadow:0 0 28px rgba(0,210,150,.12);
}

.template-aurora .upg-photo{
display:block;
width:100%;
height:auto;
transition:transform .45s ease;
}

.template-aurora .upg-box:hover .upg-photo{
transform:scale(1.05);
}

.template-aurora .upg-hover{
position:absolute;
inset:0;
display:flex;
align-items:flex-end;
background:linear-gradient(to top,rgba(6,13,16,.94),rgba(6,13,16,.1));
opacity:0;
transition:opacity .24s ease;
pointer-events:none;
}

.template-aurora .upg-box:hover .upg-hover{
opacity:1;
}

.template-aurora .upg-title{
width:100%;
padding:14px 16px;
color:var(--text-primary);
font-size:13px;
font-weight:600;
text-align:center;
}

/* =========================================================
   SERVICES
========================================================= */

.template-aurora .landing-services-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
gap:18px;
}

.template-aurora .landing-service-card{
display:flex;
flex-direction:column;
text-decoration:none;
color:inherit;
background:rgba(0,210,150,.04);
border:1px solid rgba(0,210,150,.12);
border-radius:20px;
padding:16px;
transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}

.template-aurora .landing-service-card:hover{
transform:translateY(-3px);
border-color:rgba(0,210,150,.35);
box-shadow:0 10px 36px rgba(0,210,150,.1);
}

.template-aurora .landing-service-photo{
position:relative;
aspect-ratio:16/10;
overflow:hidden;
border-radius:14px;
background:#0a1a14;
margin-bottom:14px;
}

.template-aurora .landing-service-photo img{
width:100%;
height:100%;
object-fit:cover;
display:block;
}

.template-aurora .landing-service-badge{
position:absolute;
top:10px;
left:10px;
z-index:2;
padding:5px 10px;
border-radius:999px;
background:rgba(0,210,150,.18);
border:1px solid rgba(0,210,150,.35);
color:var(--accent-color);
font-size:11px;
font-weight:700;
text-transform:uppercase;
letter-spacing:.06em;
backdrop-filter:blur(6px);
}

.template-aurora .landing-service-title{
margin:0 0 8px;
font-size:18px;
font-weight:700;
color:var(--text-primary);
text-align:left;
}

.template-aurora .landing-service-desc{
margin:0;
font-size:13px;
line-height:1.75;
color:var(--text-muted);
text-align:left;
}

/* =========================================================
   PRICING
========================================================= */

.template-aurora .landing-pricing-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
gap:16px;
max-width:1040px;
margin:0 auto;
}

.template-aurora .landing-pricing-card{
position:relative;
padding:24px 20px;
border-radius:18px;
background:rgba(255,255,255,.03);
border:1px solid rgba(0,210,150,.1);
text-align:center;
transition:border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}

.template-aurora .landing-pricing-card.highlight{
background:rgba(0,210,150,.08);
border-color:rgba(0,210,150,.45);
box-shadow:0 0 40px rgba(0,210,150,.1), 0 14px 36px rgba(0,0,0,.25);
transform:translateY(-4px);
}

.template-aurora .landing-pricing-badge{
display:inline-flex;
margin-bottom:14px;
padding:5px 14px;
border-radius:999px;
background:linear-gradient(135deg,var(--accent-color),var(--accent-blue));
color:#060d10;
font-size:11px;
font-weight:700;
text-transform:uppercase;
letter-spacing:.06em;
}

.template-aurora .landing-pricing-card h3{
margin:0;
font-size:1.1rem;
font-weight:700;
color:var(--text-primary);
}

.template-aurora .landing-price{
margin:14px 0;
font-size:32px;
font-weight:700;
color:var(--accent-color);
}

.template-aurora .landing-pricing-card.highlight .landing-price{
color:var(--accent-color);
text-shadow:0 0 20px rgba(0,210,150,.4);
}

.template-aurora .landing-pricing-desc{
margin:0;
font-size:13px;
line-height:1.75;
color:var(--text-muted);
}

/* =========================================================
   FAQ
========================================================= */

.template-aurora .landing-faq{
max-width:900px;
margin:0 auto;
display:flex;
flex-direction:column;
gap:10px;
}

.template-aurora .landing-faq-item{
border:1px solid rgba(0,210,150,.12);
border-radius:14px;
background:rgba(255,255,255,.02);
overflow:hidden;
}

.template-aurora .landing-faq-item.open{
border-color:rgba(0,210,150,.4);
box-shadow:0 6px 22px rgba(0,210,150,.08);
}

.template-aurora .landing-faq-question{
width:100%;
background:none;
border:0;
padding:16px 20px;
text-align:left;
font-size:15px;
font-weight:600;
cursor:pointer;
position:relative;
color:var(--text-primary);
font-family:"Space Grotesk",system-ui,sans-serif;
}

.template-aurora .landing-faq-question::after{
content:"+";
position:absolute;
right:20px;
top:50%;
transform:translateY(-50%);
font-size:22px;
font-weight:400;
color:var(--accent-color);
opacity:.7;
}

.template-aurora .landing-faq-item.open .landing-faq-question::after{
content:"−";
}

.template-aurora .landing-faq-answer{
display:none;
padding:0 20px 18px;
line-height:1.8;
color:var(--text-muted);
text-align:left;
white-space:pre-line;
}

.template-aurora .landing-faq-item.open .landing-faq-answer{
display:block;
}

/* =========================================================
   CTA BUTTONS
========================================================= */

.template-aurora .landing-cta-buttons{
display:flex;
flex-wrap:wrap;
gap:12px;
justify-content:center;
}

.template-aurora .landing-btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
padding:12px 24px;
border-radius:12px;
font-weight:700;
font-size:14px;
text-decoration:none;
font-family:"Space Grotesk",system-ui,sans-serif;
transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
border:1px solid transparent;
}

.template-aurora .landing-btn:hover{
transform:translateY(-2px);
}

.template-aurora .landing-btn-primary{
background:linear-gradient(135deg,var(--accent-color),var(--accent-blue));
color:#060d10;
border-color:transparent;
box-shadow:0 6px 22px rgba(0,210,150,.3);
font-weight:700;
}

.template-aurora .landing-btn-primary:hover{
box-shadow:0 10px 30px rgba(0,210,150,.4);
}

.template-aurora .landing-btn-secondary{
background:rgba(0,210,150,.08);
color:var(--accent-color);
border-color:rgba(0,210,150,.28);
}

.template-aurora .landing-btn-secondary:hover{
background:rgba(0,210,150,.14);
border-color:rgba(0,210,150,.5);
}

.template-aurora .landing-btn-accent{
background:rgba(0,150,255,.15);
color:#5cc8ff;
border-color:rgba(0,150,255,.3);
}

.template-aurora .landing-btn-accent:hover{
background:rgba(0,150,255,.25);
border-color:rgba(0,150,255,.55);
}

.template-aurora .landing-btn-accent-outline{
background:transparent;
color:var(--accent-color);
border-color:rgba(0,210,150,.4);
}

.template-aurora .landing-btn-accent-outline:hover{
background:linear-gradient(135deg,var(--accent-color),var(--accent-blue));
color:#060d10;
border-color:transparent;
box-shadow:0 6px 22px rgba(0,210,150,.25);
}

.template-aurora .landing-btn-text{
padding:12px 8px;
background:transparent;
color:var(--text-muted);
border:0;
box-shadow:none;
}

.template-aurora .landing-btn-text:hover{
color:var(--accent-color);
background:transparent;
transform:none;
}

.template-aurora .cta-icon{
display:flex;
align-items:center;
justify-content:center;
}

.template-aurora .cta-icon img{
width:18px;
height:18px;
display:block;
}

.template-aurora .landing-btn-primary .cta-icon img{
filter:brightness(0);
}

.template-aurora .landing-btn-secondary .cta-icon img,
.template-aurora .landing-btn-accent-outline .cta-icon img,
.template-aurora .landing-btn-text .cta-icon img{
filter:brightness(0) saturate(100%) invert(72%) sepia(48%) saturate(500%) hue-rotate(120deg) brightness(100%) contrast(90%);
}

.template-aurora .landing-btn-accent .cta-icon img{
filter:brightness(0) saturate(100%) invert(75%) sepia(40%) saturate(600%) hue-rotate(180deg) brightness(110%);
}

/* =========================================================
   SOCIAL
========================================================= */

.template-aurora .landing-social-links{
display:flex;
flex-wrap:wrap;
gap:10px;
justify-content:center;
}

.template-aurora .landing-social-btn{
width:48px;
height:48px;
border-radius:12px;
display:flex;
align-items:center;
justify-content:center;
background:rgba(0,210,150,.06);
border:1px solid rgba(0,210,150,.16);
transition:border-color .2s ease, background .2s ease, transform .2s ease, box-shadow .2s ease;
}

.template-aurora .landing-social-btn:hover{
transform:translateY(-3px);
border-color:rgba(0,210,150,.5);
background:rgba(0,210,150,.12);
box-shadow:0 8px 22px rgba(0,210,150,.15);
}

.template-aurora .landing-social-btn img{
width:20px;
height:20px;
display:block;
filter:brightness(0) saturate(100%) invert(72%) sepia(48%) saturate(500%) hue-rotate(120deg) brightness(100%) contrast(90%);
transition:filter .2s ease;
}

.template-aurora .landing-social-btn:hover img{
filter:brightness(0) saturate(100%) invert(90%) sepia(30%) saturate(400%) hue-rotate(100deg);
}

/* =========================================================
   CONTACT FORM
========================================================= */

.template-aurora .landing-contact-form{
max-width:820px;
margin:0 auto;
display:flex;
flex-direction:column;
gap:16px;
}

.template-aurora .landing-form-field{
display:flex;
flex-direction:column;
gap:8px;
}

.template-aurora .landing-form-field label{
font-size:12px;
font-weight:700;
letter-spacing:.1em;
text-transform:uppercase;
color:var(--accent-soft);
}

.template-aurora .landing-form-field input,
.template-aurora .landing-form-field textarea{
width:100%;
padding:13px 16px;
box-sizing:border-box;
border:1px solid rgba(0,210,150,.15);
border-radius:12px;
background:rgba(0,210,150,.04);
font:inherit;
font-family:"Space Grotesk",system-ui,sans-serif;
color:var(--text-primary);
outline:none;
transition:border-color .2s ease, box-shadow .2s ease;
}

.template-aurora .landing-form-field textarea{
min-height:150px;
resize:vertical;
line-height:1.75;
}

.template-aurora .landing-form-field input:focus,
.template-aurora .landing-form-field textarea:focus{
border-color:rgba(0,210,150,.5);
box-shadow:0 0 0 3px rgba(0,210,150,.08);
}

.template-aurora .landing-contact-form .btn,
.template-aurora .landing-contact-form .btn.btn-primary{
align-self:center;
min-width:220px;
padding:12px 24px;
border-radius:12px;
border:0;
background:linear-gradient(135deg,var(--accent-color),var(--accent-blue));
color:#060d10;
font-weight:700;
font-family:"Space Grotesk",system-ui,sans-serif;
cursor:pointer;
box-shadow:0 6px 22px rgba(0,210,150,.28);
}

.template-aurora .landing-contact-form .btn:hover,
.template-aurora .landing-contact-form .btn.btn-primary:hover{
box-shadow:0 10px 30px rgba(0,210,150,.38);
}

/* =========================================================
   FOOTER
========================================================= */

.template-aurora .landing-footer{
margin-top:0;
padding:22px 0 28px;
background:transparent;
border-top:1px solid rgba(0,210,150,.08);
}

.template-aurora .landing-footer .layout-container{
max-width:1368px;
}

.template-aurora .landing-footer-inner{
display:flex;
align-items:center;
justify-content:space-between;
gap:16px;
font-size:13px;
color:rgba(0,210,150,.3);
}

.template-aurora .landing-footer-brand a{
color:rgba(0,210,150,.55);
text-decoration:none;
font-weight:600;
transition:color .2s ease;
}

.template-aurora .landing-footer-brand a:hover{
color:var(--accent-color);
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width:900px){
.template-aurora #upg-gallery{
grid-template-columns:repeat(2,minmax(0,1fr));
}
}

@media (max-width:700px){
.template-aurora .layout-container{
padding-left:16px;
padding-right:16px;
}

.template-aurora .section:not(.section-hero) > .layout-container{
padding:24px 20px 32px;
}

.template-aurora #upg-gallery{
grid-template-columns:1fr;
}

.template-aurora .landing-footer-inner{
flex-direction:column;
gap:8px;
text-align:center;
}
}
