@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500;600;700&display=swap');

/* =========================
   VARIABLES
========================= */

:root{
    --bg-body:#f3f6fb;
    --bg-card:rgba(255,255,255,0.80);
    --bg-card-solid:#ffffff;
    --bg-soft:#edf5ff;
    --bg-soft-2:#dcecff;

    --primary:#2060bc;
    --primary-dark:#12386d;
    --primary-light:#e8f2ff;

    --text:#17324d;
    --text-soft:#67809c;

    --border:rgba(32,96,188,0.10);
    --border-strong:rgba(32,96,188,0.18);

    --success:#4caf50;
    --warning:#f59e0b;
    --danger:#db1702;

    --shadow-md:0 12px 30px rgba(19, 51, 97, 0.08);
    --shadow-lg:0 24px 60px rgba(19, 51, 97, 0.12);

    --radius-lg:18px;
    --radius-md:14px;

    --transition:0.3s ease;
}

/* =========================
   RESET
========================= */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
    font-family:"Montserrat", sans-serif;
    background:radial-gradient(circle at top left, #ffffff 0%, #f4f8fd 38%, #edf3fa 100%);
    color:var(--text);
    min-height:100vh;
}

/* =========================
   LAYOUT
========================= */

.app{
    min-height:100vh;
    display:flex;
    flex-direction:column;
}

.header{
    padding:20px 30px;
}

.logo{
    font-weight:700;
    font-size:18px;
    color:var(--primary);
}

.main{
    flex:1;
    display:flex;
    justify-content:center;
    align-items:center;
    padding:30px;
}

/* =========================
   CARD
========================= */

.card{
    background:var(--bg-card);
    backdrop-filter:blur(12px);
    border-radius:var(--radius-lg);
    padding:40px;
    max-width:600px;
    width:100%;
    box-shadow:var(--shadow-md);
    text-align:center;
}

.card-wide{
    max-width:900px;
}

/* =========================
   TYPO
========================= */

h1{
    font-size:26px;
    margin-bottom:15px;
}

p{
    color:var(--text-soft);
    margin-bottom:20px;
    line-height:1.5;
}

/* =========================
   BUTTON
========================= */

.btn{
    display:inline-block;
    background:var(--primary);
    color:#fff;
    padding:12px 24px;
    border-radius:10px;
    text-decoration:none;
    font-weight:600;
    border:none;
    cursor:pointer;
    transition:var(--transition);
}

.btn:hover{
    background:var(--primary-dark);
}

/* =========================
   INPUT
========================= */

.input{
    width:100%;
    padding:12px;
    border-radius:var(--radius-md);
    border:1px solid var(--border);
    font-family:inherit;
    font-size:14px;
    transition:var(--transition);
}

.input:focus{
    outline:none;
    border-color:var(--primary);
}

/* =========================
   ALERT
========================= */

.alert-error{
    color:var(--danger);
    margin-bottom:15px;
    font-size:14px;
}

/* =========================
   PDF PREVIEW
========================= */

.pdf-container{
    margin:25px 0;
}

#pdf-container {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
}

#pdf-container canvas {
    width: 100%;
    height: auto;
    display: block;
    margin-bottom: 20px;
    border: 1px solid #ddd;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    background: #fff;
}

/* =========================
   CHECKBOX
========================= */

.checkbox{
    display:flex;
    align-items:flex-start;
    gap:12px;
    text-align:left;
    margin-bottom:25px;
}

.checkbox input{
    margin-top:4px;
    transform:scale(1.1);
}

.checkbox span{
    font-size:14px;
    color:var(--text-soft);
}

/* =========================
   SIGNATURE
========================= */

.signature-container{
    margin:25px 0;
    text-align:left;
}

.signature-canvas{
    width:100%;
    height:200px;
    background:#fff;
    border:1px solid var(--border);
    border-radius:var(--radius-md);
    box-shadow:var(--shadow-md);
    cursor:crosshair;
}

.signature-actions{
    margin-top:10px;
}

.signature-clear{
    font-size:13px;
    color:var(--primary);
    background:none;
    border:none;
    cursor:pointer;
}

.signature-clear:hover{
    text-decoration:underline;
}

/* =========================
   SMALL TEXT
========================= */

.text-small{
    font-size:14px;
    color:var(--text-soft);
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width:768px){

    .main{
        padding:20px;
    }

    .card{
        padding:25px;
    }

    h1{
        font-size:22px;
    }

    .pdf-frame{
        height:300px;
    }

    .signature-canvas{
        height:180px;
    }

}