:root{
    --contact-bg:#0d1224;
    --contact-bg-2:#131933;
    --contact-line:rgba(255,255,255,.08);
    --contact-text:#eef2ff;
    --contact-soft:rgba(255,255,255,.74);

    --contact-blue:#4ea1ff;
    --contact-violet:#7c5cff;
    --contact-cyan:#38d7ff;
    --contact-green:#22c55e;
    --contact-red:#ef4444;
}

body.contact-page{
    background:#fff;
    color:#0f172a;
    overflow-x:hidden;
}

/* hero */
.contact-hero{
    position:relative;
    min-height:95vh;
    padding:140px 0 70px;
    overflow:hidden;
    color:#fff;
    background:
        radial-gradient(circle at 14% 20%, rgba(78,161,255,.20), transparent 24%),
        radial-gradient(circle at 84% 18%, rgba(124,92,255,.18), transparent 24%),
        radial-gradient(circle at 70% 78%, rgba(56,215,255,.10), transparent 24%),
        linear-gradient(180deg, #0d1224 0%, #11162d 50%, #151a35 100%);
}

.contact-grid{
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size:56px 56px;
    mask-image:linear-gradient(to bottom, rgba(0,0,0,.9), rgba(0,0,0,.2));
}

.contact-orb{
    position:absolute;
    width:420px;
    height:420px;
    border-radius:50%;
    filter:blur(80px);
    opacity:.18;
}

.orb-a{
    left:-80px;
    top:100px;
    background:#4ea1ff;
}

.orb-b{
    right:-90px;
    top:60px;
    background:#7c5cff;
}

.contact-hero-wrap{
    position:relative;
    z-index:2;
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:46px;
    align-items:center;
}

.contact-badge,
.section-kicker{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:12px 16px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.05);
    backdrop-filter:blur(12px);
    font-size:.78rem;
    letter-spacing:.16em;
    text-transform:uppercase;
    font-weight:800;
}

.section-kicker{
    padding:0;
    background:none;
    border:none;
    color:#6f7dff;
}

.section-kicker.light{
    color:#d7ddff;
}

.contact-copy h1{
    margin:22px 0 18px;
    font-size:clamp(2.8rem, 5vw, 5.6rem);
    line-height:1.02;
    letter-spacing:-.045em;
    font-weight:900;
    color:#fff;
}

.contact-copy h1 span{
    display:block;
    background:linear-gradient(90deg, #ffffff 0%, #a8d0ff 35%, #8f9fff 68%, #b98cff 100%);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
    color:transparent;
}

.contact-lead{
    max-width:760px;
    font-size:1.06rem;
    line-height:1.9;
    color:var(--contact-soft);
    margin:0 0 28px;
}

.contact-points{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:14px;
}

.point-card{
    padding:18px;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.04);
    backdrop-filter:blur(10px);
}

.point-card strong{
    display:block;
    margin-bottom:6px;
    color:#fff;
    font-size:1rem;
}

.point-card span{
    display:block;
    color:rgba(255,255,255,.68);
    line-height:1.6;
    font-size:.92rem;
}

/* panel */
.contact-panel{
    border-radius:30px;
    overflow:hidden;
    border:1px solid rgba(255,255,255,.08);
    background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
    backdrop-filter:blur(16px);
    box-shadow:0 30px 90px rgba(0,0,0,.36);
}

.panel-top{
    display:flex;
    gap:8px;
    padding:16px 20px;
    border-bottom:1px solid rgba(255,255,255,.08);
}

.panel-top span{
    width:10px;
    height:10px;
    border-radius:50%;
    background:rgba(255,255,255,.32);
}

.panel-body{
    position:relative;
    min-height:520px;
    padding:24px;
}

.panel-chip{
    display:inline-flex;
    padding:10px 14px;
    border-radius:999px;
    border:1px solid rgba(78,161,255,.28);
    background:rgba(78,161,255,.14);
    color:#d4eaff;
    font-size:.76rem;
    font-weight:800;
    letter-spacing:.16em;
    text-transform:uppercase;
    margin-bottom:18px;
}

.status-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:14px;
    margin-bottom:18px;
}

.status-card{
    padding:20px;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.05);
}

.status-card strong{
    display:block;
    color:#fff;
    margin-bottom:6px;
    font-size:1rem;
}

.status-card span{
    color:rgba(255,255,255,.66);
    font-size:.92rem;
}

.contact-lines{
    position:relative;
    height:130px;
    border-radius:20px;
    border:1px solid rgba(255,255,255,.08);
    background:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(180deg, rgba(10,17,27,.45), rgba(10,17,27,.82));
    background-size:24px 24px, 24px 24px, auto;
    overflow:hidden;
}

.line{
    position:absolute;
    left:0;
    right:0;
    height:2px;
    border-radius:999px;
    background:linear-gradient(90deg, transparent 0%, #6bd5ff 30%, #8f7cff 70%, transparent 100%);
}

.l1{ top:28px; animation:contactMove 3.2s linear infinite; }
.l2{ top:63px; animation:contactMove 4.1s linear infinite; }
.l3{ top:98px; animation:contactMove 5s linear infinite; }

@keyframes contactMove{
    0%{ transform:translateX(-28%); opacity:.35; }
    50%{ opacity:1; }
    100%{ transform:translateX(28%); opacity:.35; }
}

.mini-note{
    position:absolute;
    padding:16px 18px;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.06);
    backdrop-filter:blur(12px);
    box-shadow:0 20px 50px rgba(0,0,0,.18);
}

.note-a{
    left:18px;
    bottom:26px;
    width:220px;
}

.note-b{
    right:22px;
    top:120px;
    width:210px;
}

.mini-note strong{
    display:block;
    color:#fff;
    margin-bottom:5px;
    font-size:.96rem;
}

.mini-note span{
    display:block;
    color:rgba(255,255,255,.66);
    font-size:.88rem;
}

/* form section */
.contact-form-section{
    padding:110px 0 120px;
    background:linear-gradient(180deg, #f7f9ff 0%, #ffffff 100%);
}

.contact-layout{
    display:grid;
    grid-template-columns:1.15fr .85fr;
    gap:28px;
    align-items:start;
}

.contact-form-wrap{
    padding:34px;
    border-radius:30px;
    border:1px solid rgba(15,23,42,.08);
    background:#fff;
    box-shadow:0 24px 70px rgba(15,23,42,.06);
}

.section-heading{
    max-width:760px;
    margin-bottom:30px;
}

.section-heading h2{
    margin:14px 0 14px;
    font-size:clamp(2rem,3vw,3.1rem);
    line-height:1.08;
    letter-spacing:-.03em;
    color:#0f172a;
}

.section-heading p{
    margin:0;
    color:#667085;
    line-height:1.8;
}

.form-alert{
    padding:16px 18px;
    border-radius:16px;
    margin-bottom:18px;
    font-weight:600;
}

.form-alert.success{
    background:rgba(34,197,94,.10);
    color:#15803d;
    border:1px solid rgba(34,197,94,.22);
}

.form-alert.error{
    background:rgba(239,68,68,.10);
    color:#b91c1c;
    border:1px solid rgba(239,68,68,.22);
}

.contact-form{
    width:100%;
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
}

.form-group{
    display:flex;
    flex-direction:column;
}

.form-group-full{
    grid-column:1 / -1;
}

.form-group label{
    font-size:.95rem;
    font-weight:700;
    color:#111827;
    margin-bottom:10px;
}

.form-group input,
.form-group select,
.form-group textarea{
    width:100%;
    border:1px solid rgba(15,23,42,.10);
    background:#fff;
    border-radius:16px;
    padding:15px 16px;
    font-size:.98rem;
    color:#111827;
    outline:none;
    transition:.25s ease;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
    border-color:rgba(78,161,255,.5);
    box-shadow:0 0 0 4px rgba(78,161,255,.08);
}

.form-group textarea{
    resize:vertical;
    min-height:160px;
}

.submit-btn{
    margin-top:20px;
    width:100%;
    border:none;
    border-radius:18px;
    padding:16px 22px;
    font-size:1rem;
    font-weight:800;
    cursor:pointer;
    color:#fff;
    background:linear-gradient(135deg, var(--contact-blue), var(--contact-violet));
    box-shadow:0 18px 45px rgba(78,161,255,.18);
    transition:.3s ease;
}

.submit-btn:hover{
    transform:translateY(-2px);
    box-shadow:0 24px 60px rgba(78,161,255,.26);
}

/* side */
.contact-side{
    display:grid;
    gap:18px;
}

.side-box{
    padding:28px;
    border-radius:26px;
    border:1px solid rgba(15,23,42,.08);
    background:#fff;
    box-shadow:0 18px 50px rgba(15,23,42,.05);
}

.side-box.dark{
    background:linear-gradient(135deg, #11172b 0%, #171e35 100%);
    color:#fff;
    border-color:rgba(255,255,255,.08);
}

.side-box h3{
    margin:14px 0 12px;
    font-size:1.5rem;
    color:inherit;
}

.side-box p{
    margin:0 0 18px;
    color:inherit;
    line-height:1.8;
}

.side-box small{
    color:rgba(255,255,255,.7);
}

.side-box.dark a{
    color:#fff;
    text-decoration:none;
    font-weight:700;
}

.side-list{
    display:grid;
    gap:14px;
}

.side-item{
    padding:18px;
    border-radius:18px;
    border:1px solid rgba(15,23,42,.08);
    background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.side-item strong{
    display:block;
    margin-bottom:6px;
    color:#111827;
}

.side-item span{
    display:block;
    color:#667085;
    line-height:1.7;
    font-size:.94rem;
}

/* responsive */
@media (max-width: 1200px){
    .contact-hero-wrap,
    .contact-layout{
        grid-template-columns:1fr;
    }
}

@media (max-width: 992px){
    .contact-points{
        grid-template-columns:1fr;
    }
}

@media (max-width: 768px){
    .contact-hero{
        padding:120px 0 60px;
    }

    .contact-copy h1{
        font-size:2.4rem;
    }

    .section-heading h2{
        font-size:2rem;
    }

    .form-grid{
        grid-template-columns:1fr;
    }

    .contact-form-wrap,
    .side-box{
        padding:22px;
    }

    .panel-body{
        min-height:560px;
        padding:18px;
    }

    .note-a,
    .note-b{
        position:relative;
        left:auto;
        right:auto;
        top:auto;
        bottom:auto;
        width:100%;
        margin-top:14px;
    }
}