/* ===============================
GLOBAL
================================ */

body{
    margin:0;
    font-family:'Montserrat',sans-serif;
    background: radial-gradient(circle at top left,#0b1220,#101a33,#1e293b);
    color:#fff;
    overflow-x:hidden;
}

/* ===============================
FLOATING ORBS
================================ */

.floating{
    position:absolute;
    border-radius:50%;
    opacity:.25;
    animation:float 14s ease-in-out infinite;
    z-index:0;
}

.floating.one{
    width:260px;
    height:260px;
    top:-80px;
    left:-60px;
    background:radial-gradient(circle,#ff7a00,#ffb347);
}

.floating.two{
    width:200px;
    height:200px;
    bottom:-60px;
    right:-40px;
    background:radial-gradient(circle,#ff9100,#ffc371);
}

.floating.three{
    width:160px;
    height:160px;
    top:40%;
    right:-50px;
    background:radial-gradient(circle,#ffb347,#ff7a00);
}

@keyframes float{
    0%,100%{transform:translate(0,0)}
    50%{transform:translate(25px,-35px)}
}

/* ===============================
CONTAINER
================================ */

.container{
    max-width:900px;
    margin:auto;
    padding:40px 20px;
    position:relative;
    z-index:2;
}

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

h1{
    font-size:2.4rem;
    font-weight:900;
    text-align:center;
    margin-bottom:10px;

    background:linear-gradient(90deg,#ff7a00,#ffb347,#ff9100);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

.subtitle{
    text-align:center;
    color:#cbd5f5;
    margin-bottom:35px;
}

/* ===============================
CARD
================================ */

.card{
    background:rgba(11,18,32,.9);
    border:1px solid rgba(255,165,0,.3);
    border-radius:24px;
    padding:35px;
    backdrop-filter:blur(18px);
    box-shadow:0 20px 50px rgba(0,0,0,.6);
    margin-bottom:30px;
    animation:fadeSlide 0.7s ease;
}

@keyframes fadeSlide{
    from{
        opacity:0;
        transform:translateY(30px);
    }
    to{
        opacity:1;
        transform:translateY(0);
    }
}

/* ===============================
INPUTS
================================ */

input,
textarea,
select{

    width:100%;
    padding:15px;
    margin-top:12px;

    border-radius:14px;
    border:1px solid rgba(255,165,0,.25);

    background:#0b1220;
    color:#fff;

    font-size:15px;
    outline:none;
    transition:.3s;
}

input:focus,
textarea:focus,
select:focus{

    border-color:#ff7a00;
    box-shadow:0 0 15px rgba(255,122,0,.4);
}

/* ===============================
SERVICE GRID
================================ */

.services{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:20px;
    margin-top:20px;
}

/* ===============================
SERVICE CARD
================================ */

.service{

    background:linear-gradient(145deg,#0b1220,#091024);
    border:1px solid rgba(255,165,0,.25);

    padding:22px;
    border-radius:18px;

    cursor:pointer;
    font-weight:600;
    font-size:15px;

    position:relative;
    overflow:hidden;

    transition:.35s cubic-bezier(.2,.7,.2,1);

    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
}

/* glowing border */
.service::before{

    content:"";
    position:absolute;
    inset:-1px;

    border-radius:18px;
    background:linear-gradient(
        120deg,
        rgba(255,140,0,.2),
        rgba(255,200,0,.4),
        rgba(255,140,0,.2)
    );

    opacity:0;
    transition:.35s;
}

/* shine sweep */
.service::after{

    content:"";
    position:absolute;
    top:0;
    left:-120%;
    width:60%;
    height:100%;

    background:linear-gradient(
        120deg,
        transparent,
        rgba(255,255,255,.2),
        transparent
    );

    transform:skewX(-20deg);
    transition:.6s;
}

/* hover fire */
.service:hover{

    transform:translateY(-6px) scale(1.02);

    border-color:#ff9800;

    background:linear-gradient(
        145deg,
        #0b1220,
        #111a33
    );

    box-shadow:
        0 0 20px rgba(255,140,0,.4),
        0 10px 40px rgba(255,122,0,.35);
}

.service:hover::before{
    opacity:1;
}

.service:hover::after{
    left:140%;
}

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

button{

    background:linear-gradient(135deg,#ff7a00,#ff3c00);

    border:none;
    color:#fff;

    padding:14px 22px;
    border-radius:999px;

    font-weight:700;
    font-size:14px;

    cursor:pointer;

    transition:.3s ease;

    margin:8px;
}

/* center modal buttons */
.modal-box button{
    display:inline-block;
}

/* hover glow */
button:hover{

    transform:translateY(-3px);

    box-shadow:
        0 8px 20px rgba(255,122,0,.4),
        0 0 15px rgba(255,150,0,.6);
}

/* cancel button variant */

.modal-box button.close{

    background:#222c44;
    color:#ccc;
}

.modal-box button.close:hover{

    background:#2f3b5a;
    box-shadow:none;
}

/* ===============================
MODALS
================================ */

.modal{

    position:fixed;
    inset:0;

    display:none;
    align-items:center;
    justify-content:center;

    background:rgba(0,0,0,.65);
    backdrop-filter:blur(6px);

    z-index:999;
}

.modal-box{

    background:rgba(11,18,32,.95);

    border:1px solid rgba(255,165,0,.3);
    border-radius:24px;

    padding:34px;

    width:90%;
    max-width:440px;

    box-shadow:
        0 25px 60px rgba(0,0,0,.7),
        0 0 40px rgba(255,122,0,.15);

    text-align:center;
}

/* modal title */

.modal-box h3{

    margin-top:0;
    margin-bottom:20px;

    font-weight:900;
    font-size:20px;

    background:linear-gradient(
        90deg,
        #ff7a00,
        #ffb347,
        #ff9100
    );

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

/* ===============================
MODAL FORM CONTENT
================================ */

#configContent input,
#configContent select{

    width:100%;
    margin-top:10px;
    margin-bottom:14px;

    padding:12px;

    border-radius:12px;

    border:1px solid rgba(255,165,0,.25);

    background:#0b1220;
    color:#fff;
}

/* preview box */

#invoicePreview{

    background:#0b1220;
    border:1px solid rgba(255,165,0,.25);

    padding:16px;
    border-radius:14px;

    margin-bottom:16px;

    text-align:left;
    line-height:1.6;
}

/* checkbox alignment */

#previewModal label{

    display:flex;
    align-items:center;
    gap:10px;

    margin-bottom:18px;
    justify-content:center;
}
/* ===============================
UPLOAD AREA
================================ */

.profile-upload{

    margin-top:18px;
}

.upload-label{

    display:block;
    padding:12px;
    border-radius:14px;

    border:1px dashed rgba(255,165,0,.4);
    text-align:center;

    cursor:pointer;
}

.logo-preview{

    margin-top:10px;
    min-height:80px;

    display:flex;
    align-items:center;
    justify-content:center;

    border:1px solid rgba(255,165,0,.2);
    border-radius:14px;
}

.logo-preview img{

    max-width:100%;
    max-height:90px;
    border-radius:10px;
}

/* ===============================
CONTINUE PREVIOUS PAYMENT BUTTON
================================ */

.continue-payment{
    width:100%;
    display:flex;
    justify-content:center;   /* horizontal center */
    align-items:center;
    margin:20px auto 10px auto;
}

/* button */

.resume-btn{

    background:linear-gradient(135deg,#ff7a00,#ff3c00);
    border:none;

    padding:14px 26px;

    color:#fff;
    font-weight:700;
    font-size:15px;

    border-radius:999px;

    cursor:pointer;

    display:inline-flex;
    align-items:center;
    gap:10px;

    transition:all .25s ease;

    box-shadow:0 6px 18px rgba(255,122,0,.35);

    margin:0 auto;   /* ensures perfect centering */
}

/* hover effect */

.resume-btn:hover{

    transform:translateY(-3px);

    box-shadow:
        0 10px 28px rgba(255,122,0,.55),
        0 0 14px rgba(255,150,0,.6);
}

/* icon */

.resume-btn i{
    font-size:14px;
}

/* MOBILE FIX */

@media (max-width:768px){

    .resume-btn{
        font-size:14px;
        padding:13px 22px;
    }

}