/* ================================================================
   CODESCRIPTUM — KONTAKT
   Dedicated contact page styling
   ================================================================ */

/* ── Reset & Variables ───────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --indigo:#4F46E5;--indigo-dark:#3730A3;--electric:#6366F1;
  --cyan:#06B6D4;--cyan-light:#22D3EE;--neon:#A78BFA;--neon-light:#C4B5FD;
  --emerald:#10B981;--orange:#F59E0B;--rose:#F43F5E;
  --dark:#030712;--dark-800:#0B0F1A;--dark-card:#111827;--dark-surface:#1F2937;
  --gray-100:#F8FAFC;--gray-200:#E2E8F0;--gray-300:#CBD5E1;
  --gray-400:#94A3B8;--gray-500:#64748B;--white:#FFFFFF;
  --font:'Inter',system-ui,sans-serif;
  --font-display:'Space Grotesk','Inter',sans-serif;
  --section-py:110px;--container:1200px;--radius:16px;--radius-sm:10px;
}

html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font);color:var(--gray-100);background:var(--dark);line-height:1.7;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ── Header / Nav inherited from global.css ─────────────────── */


/* ── Gradient text ───────────────────────────────────────────── */
.gradient-text{
  background:linear-gradient(135deg,var(--cyan-light),var(--electric),var(--neon));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;background-size:200% 200%;animation:gradientShift 4s ease-in-out infinite;
}
.gradient-text-dark{
  background:linear-gradient(135deg,var(--indigo),var(--electric),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;background-size:200% 200%;animation:gradientShift 4s ease-in-out infinite;
}
@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;border-radius:50px;font-weight:600;font-size:.95rem;
  cursor:pointer;border:none;transition:all .35s cubic-bezier(.25,.8,.25,1);
  font-family:var(--font);position:relative;overflow:hidden;
}
.btn--primary{
  background:linear-gradient(135deg,var(--indigo),var(--electric));color:#fff;
  box-shadow:0 4px 20px rgba(99,102,241,.3);
}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(99,102,241,.5)}
.btn--ghost{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:#fff;
  backdrop-filter:blur(10px);
}
.btn--ghost:hover{background:rgba(99,102,241,.1);border-color:var(--electric);transform:translateY(-3px)}
.btn--glow::before{
  content:'';position:absolute;inset:-2px;border-radius:inherit;
  background:linear-gradient(135deg,var(--cyan),var(--electric),var(--neon));
  z-index:-1;opacity:0;transition:opacity .4s;filter:blur(15px);
}
.btn--glow:hover::before{opacity:.6}
.btn--full{width:100%;justify-content:center}
.btn--sm{padding:10px 22px;font-size:.88rem}
.btn__text,.btn__loader{display:flex;align-items:center;gap:8px}
.btn__loader{display:none}
.btn.loading .btn__text{display:none}
.btn.loading .btn__loader{display:flex}

/* ── Sections ────────────────────────────────────────────────── */
.section{padding:var(--section-py) 0;position:relative;overflow:hidden}
.section--dark{background:var(--dark)}
.section--light{background:var(--gray-100);color:var(--dark)}
.section--gradient{
  background:linear-gradient(135deg,var(--dark-800) 0%,#1a1040 50%,var(--dark-800) 100%);
}
.section__title{
  text-align:center;font-size:clamp(1.8rem,4vw,2.8rem);
  font-family:var(--font-display);margin-bottom:16px;
}
.section__title--light{color:#fff}
.section__subtitle{
  text-align:center;font-size:1.05rem;color:var(--gray-400);
  max-width:640px;margin:0 auto 50px;
}
.section__subtitle--light{color:rgba(255,255,255,.6)}
.section--light .section__subtitle{color:var(--gray-500)}

/* ── CONTACT HERO ────────────────────────────────────────────── */
.contact-hero{
  position:relative;min-height:60vh;display:flex;align-items:center;
  justify-content:center;text-align:center;padding:140px 0 70px;overflow:hidden;
}
.contact-hero__bg{position:absolute;inset:0;z-index:0}
.contact-hero__canvas{position:absolute;inset:0;width:100%;height:100%}
.contact-hero__aurora{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 30% 80%,rgba(99,102,241,.12),transparent 60%),
    radial-gradient(ellipse 60% 40% at 70% 20%,rgba(6,182,212,.08),transparent 50%);
}
.contact-hero__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(99,102,241,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(99,102,241,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,#000 30%,transparent 70%);
}
.contact-hero__orb{
  position:absolute;border-radius:50%;filter:blur(80px);
  animation:orbFloat 8s ease-in-out infinite alternate;
}
.contact-hero__orb--1{
  width:380px;height:380px;top:-80px;right:-80px;
  background:radial-gradient(circle,rgba(99,102,241,.15),transparent 70%);
}
.contact-hero__orb--2{
  width:320px;height:320px;bottom:-60px;left:-60px;
  background:radial-gradient(circle,rgba(6,182,212,.12),transparent 70%);
  animation-delay:-4s;
}
@keyframes orbFloat{0%{transform:translate(0,0) scale(1)}100%{transform:translate(25px,-15px) scale(1.04)}}

.contact-hero__inner{position:relative;z-index:1;max-width:750px;margin:0 auto}
.contact-hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 20px;border-radius:50px;font-size:.85rem;font-weight:500;
  background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.2);
  color:var(--neon-light);margin-bottom:28px;
}
.contact-hero__badge-dot{
  width:8px;height:8px;border-radius:50%;background:var(--emerald);
  box-shadow:0 0 8px var(--emerald);animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.contact-hero__title{
  font-size:clamp(2rem,5vw,3.4rem);font-family:var(--font-display);
  font-weight:800;line-height:1.15;margin-bottom:22px;
}
.contact-hero__subtitle{
  font-size:clamp(1rem,1.7vw,1.15rem);
  color:rgba(255,255,255,.65);line-height:1.8;margin-bottom:32px;
}
.contact-hero__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ── QUICK CONTACT CARDS ─────────────────────────────────────── */
.quick-cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.quick-card{
  background:rgba(99,102,241,.04);border:1px solid rgba(99,102,241,.1);
  border-radius:var(--radius);padding:32px 24px;text-align:center;
  transition:all .35s ease;
}
.quick-card:hover{
  border-color:rgba(99,102,241,.25);background:rgba(99,102,241,.08);
  transform:translateY(-6px);box-shadow:0 12px 40px rgba(99,102,241,.12);
}
.quick-card__icon-wrap{
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(6,182,212,.12));
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;color:var(--electric);margin:0 auto 18px;
  border:1px solid rgba(99,102,241,.15);
}
.quick-card h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.quick-card p{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.6}
.quick-card a{color:var(--cyan-light);font-weight:600;transition:color .2s}
.quick-card a:hover{color:var(--electric)}
.quick-card__note{
  display:block;font-size:.78rem;color:var(--gray-400);margin-top:10px;
  font-style:italic;
}
.quick-card__socials{
  display:flex;gap:10px;justify-content:center;margin-top:6px;
}
.quick-card__socials a{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.15);
  font-size:.95rem;color:var(--electric);transition:all .3s;
}
.quick-card__socials a:hover{
  background:linear-gradient(135deg,var(--indigo),var(--electric));
  color:#fff;border-color:transparent;transform:translateY(-3px);
  box-shadow:0 4px 16px rgba(99,102,241,.3);
}

@media(max-width:900px){.quick-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.quick-cards{grid-template-columns:1fr}}

/* ── CONTACT FORM + SIDEBAR ──────────────────────────────────── */
.contact-main{
  display:grid;grid-template-columns:1.4fr .6fr;gap:40px;align-items:start;
}
.contact-form{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:40px 36px;backdrop-filter:blur(10px);
}
.contact-form__row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.contact-form__group{display:flex;flex-direction:column;gap:6px}
.contact-form__group label{font-size:.85rem;font-weight:500;color:rgba(255,255,255,.7)}
.contact-form__group label small{color:var(--gray-400)}
.contact-form__group input,
.contact-form__group textarea,
.contact-form__group select{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-sm);padding:13px 16px;font-size:.92rem;
  color:#fff;transition:all .25s;outline:none;
}
.contact-form__group input::placeholder,
.contact-form__group textarea::placeholder{color:rgba(255,255,255,.3)}
.contact-form__group input:focus,
.contact-form__group textarea:focus,
.contact-form__group select:focus{
  border-color:var(--electric);
  box-shadow:0 0 0 3px rgba(99,102,241,.15);
  background:rgba(255,255,255,.08);
}
.contact-form__group select{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='%2394A3B8'%3E%3Cpath d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;
}
.contact-form__group select option{background:var(--dark-card);color:#fff}
.contact-form__error{font-size:.78rem;color:var(--rose);min-height:16px}
.contact-form__rodo{margin:16px 0 24px}
.contact-form__checkbox{display:flex;align-items:flex-start;gap:12px;cursor:pointer}
.contact-form__checkbox input[type="checkbox"]{display:none}
.contact-form__checkmark{
  width:20px;height:20px;min-width:20px;border-radius:5px;
  border:2px solid rgba(255,255,255,.2);display:flex;
  align-items:center;justify-content:center;transition:all .25s;margin-top:2px;
}
.contact-form__checkbox input:checked~.contact-form__checkmark{
  background:var(--electric);border-color:var(--electric);
}
.contact-form__checkbox input:checked~.contact-form__checkmark::after{
  content:'\2713';color:#fff;font-size:.72rem;font-weight:700;
}
.contact-form__checkbox-text{font-size:.82rem;color:rgba(255,255,255,.55);line-height:1.5}
.contact-form__checkbox-text a{color:var(--electric);text-decoration:underline}

/* ── Sidebar cards ───────────────────────────────────────────── */
.contact-sidebar{display:flex;flex-direction:column;gap:18px}
.sidebar-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-sm);padding:24px 22px;
  transition:all .3s;
}
.sidebar-card:hover{border-color:rgba(99,102,241,.2);background:rgba(99,102,241,.05)}
.sidebar-card__icon{
  font-size:1.4rem;margin-bottom:12px;
  background:linear-gradient(135deg,var(--electric),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.sidebar-card h3{font-size:.95rem;font-weight:700;margin-bottom:6px}
.sidebar-card p{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.6}

@media(max-width:768px){
  .contact-main{grid-template-columns:1fr}
  .contact-form{padding:28px 20px}
  .contact-form__row{grid-template-columns:1fr}
}

/* ── FIRM DATA ───────────────────────────────────────────────── */
.firm-data{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  max-width:800px;margin:0 auto;
}
.firm-data__block{
  background:var(--white);border:1px solid var(--gray-200);
  border-radius:var(--radius);padding:36px 32px;
}
.firm-data__block h3{
  font-size:1.1rem;font-weight:700;color:var(--dark);margin-bottom:16px;
  display:flex;align-items:center;gap:10px;
}
.firm-data__block h3 i{
  color:var(--electric);font-size:1.2rem;
}
.firm-data__block ul{list-style:none;padding:0}
.firm-data__block li{
  font-size:.92rem;color:var(--gray-500);padding:8px 0;
  border-bottom:1px solid rgba(0,0,0,.04);
}
.firm-data__block li:last-child{border-bottom:none}
.firm-data__block li strong{color:var(--dark);font-weight:600;margin-right:6px}
.firm-data__block a{color:var(--electric);font-weight:500;transition:color .2s}
.firm-data__block a:hover{color:var(--indigo)}

.firm-socials{display:flex;flex-wrap:wrap;gap:12px}
.firm-social{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px;border-radius:12px;
  background:linear-gradient(135deg,rgba(99,102,241,.04),rgba(6,182,212,.04));
  border:1px solid rgba(99,102,241,.1);
  font-size:.88rem;font-weight:500;color:var(--gray-500);
  transition:all .3s;
}
.firm-social i{
  font-size:1.1rem;color:var(--electric);
}
.firm-social:hover{
  background:linear-gradient(135deg,var(--indigo),var(--electric));
  color:#fff;border-color:transparent;
  transform:translateY(-3px);box-shadow:0 6px 20px rgba(99,102,241,.2);
}
.firm-social:hover i{color:#fff}

@media(max-width:600px){
  .firm-data{grid-template-columns:1fr}
}

/* ── MAP SECTION ─────────────────────────────────────────────── */
.map-section{position:relative;background:var(--dark)}
.map-section__wrapper{position:relative;height:500px}
.map-section__iframe{
  position:absolute;inset:0;width:100%;height:100%;
  filter:brightness(.7) contrast(1.15) saturate(.6) hue-rotate(200deg);
  transition:filter .4s ease;
}
.map-section__wrapper:hover .map-section__iframe{
  filter:brightness(.85) contrast(1.1) saturate(.8) hue-rotate(200deg);
}
.map-section__overlay{position:absolute;top:50%;left:40px;transform:translateY(-50%);z-index:2}
.map-section__overlay-inner{
  background:rgba(3,7,18,.88);backdrop-filter:blur(20px);
  border:1px solid rgba(99,102,241,.2);border-radius:var(--radius);
  padding:36px 32px;max-width:320px;
}
.map-section__overlay-inner i.fa-map-location-dot{
  font-size:2rem;
  background:linear-gradient(135deg,var(--electric),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;margin-bottom:12px;display:block;
}
.map-section__overlay-inner h3{font-size:1.2rem;font-weight:700;margin-bottom:10px}
.map-section__overlay-inner p{font-size:.92rem;color:rgba(255,255,255,.65);line-height:1.6;margin-bottom:20px}

@media(max-width:600px){
  .map-section__wrapper{height:420px}
  .map-section__overlay{left:50%;transform:translate(-50%,-50%);width:calc(100% - 32px)}
  .map-section__overlay-inner{max-width:100%;text-align:center}
}

/* ── CTA FINAL ───────────────────────────────────────────────── */
.cta-final{padding:80px 0}

/* ── Form toast ──────────────────────────────────────────────── */
.form-toast{
  position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);
  z-index:10000;opacity:0;visibility:hidden;pointer-events:none;
  transition:all .5s cubic-bezier(.34,1.56,.64,1);
}
.form-toast.show{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.form-toast__inner{
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(135deg,var(--indigo),var(--electric));
  padding:16px 24px;border-radius:14px;color:#fff;
  box-shadow:0 10px 40px rgba(99,102,241,.4);
}
.form-toast__icon{font-size:1.4rem}
.form-toast__content strong{display:block;font-size:.95rem}
.form-toast__content p{font-size:.82rem;opacity:.8}
.form-toast__close{
  background:rgba(255,255,255,.15);border:none;color:#fff;width:30px;height:30px;
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.form-toast__close:hover{background:rgba(255,255,255,.25)}

/* ── Responsive ──────────────────────────────────────────────── */
@media(max-width:768px){
  .contact-hero{min-height:50vh;padding:120px 0 60px}
  .contact-hero__title{font-size:clamp(1.7rem,5vw,2.4rem)}
  :root{--section-py:80px}
}
@media(max-width:480px){
  .contact-hero{padding:110px 0 50px}
  :root{--section-py:60px}
}
