/* ===== 日本签证申请表 — 和风雅致 ===== */

:root {
    --jp-vermilion: #C24641;      /* 朱色 - 传统日本红 */
    --jp-vermilion-deep: #9B2D2A;
    --jp-vermilion-light: #E8736B;
    --jp-indigo: #2D4B63;         /* 蓝铁色 */
    --jp-gold: #B9975B;
    --jp-gold-light: #D4C08C;
    --jp-ink: #2B2B2B;            /* 墨色 */
    --jp-ink-light: #5C5C5C;
    --jp-washi: #FBF9F6;          /* 和纸色 */
    --jp-washi-warm: #F7F3EC;
    --jp-cream: #FFFDF9;
    --jp-border: #E0D8CD;
    --jp-border-light: #EDE8E0;
    --jp-shadow-sm: 0 1px 3px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.03);
    --jp-shadow-md: 0 4px 16px rgba(0,0,0,0.05), 0 2px 6px rgba(0,0,0,0.03);
    --jp-shadow-lg: 0 12px 32px rgba(0,0,0,0.07), 0 4px 12px rgba(0,0,0,0.04);
    --jp-radius: 10px;
    --jp-radius-sm: 6px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: "Noto Serif SC", "Noto Sans SC", "PingFang SC", "Hiragino Mincho ProN", "Yu Mincho", "Microsoft YaHei", serif;
    background-color: #F2EDE4;
    color: var(--jp-ink);
    min-height: 100vh;
    line-height: 1.8;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* 和纸纹理背景 */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        /* 青海波纹样 */
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 40px,
            rgba(0,0,0,0.008) 40px,
            rgba(0,0,0,0.008) 41px
        ),
        repeating-linear-gradient(
            90deg,
            transparent,
            transparent 40px,
            rgba(0,0,0,0.005) 40px,
            rgba(0,0,0,0.005) 41px
        ),
        /* 微妙的和纸纤维感 */
        radial-gradient(
            ellipse at 20% 50%,
            rgba(180,160,140,0.06) 0%,
            transparent 50%
        ),
        radial-gradient(
            ellipse at 80% 20%,
            rgba(180,160,140,0.04) 0%,
            transparent 40%
        );
}

/* ========== 顶部导航 ========== */
.jp-header {
    position: relative;
    background: linear-gradient(175deg, #2D3A3A 0%, #1B2626 40%, #263636 100%);
    color: #fff;
    padding: 52px 24px 44px;
    text-align: center;
    overflow: hidden;
    z-index: 1;
}

/* 樱花装饰层 */
.jp-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        /* 左侧樱花枝暗示 */
        radial-gradient(circle at 8% 70%, rgba(194,70,65,0.25) 0%, transparent 35%),
        radial-gradient(circle at 5% 75%, rgba(194,70,65,0.18) 0%, transparent 28%),
        radial-gradient(circle at 12% 66%, rgba(194,70,65,0.15) 0%, transparent 22%),
        /* 右侧点缀 */
        radial-gradient(circle at 92% 30%, rgba(194,70,65,0.20) 0%, transparent 30%),
        radial-gradient(circle at 88% 35%, rgba(194,70,65,0.12) 0%, transparent 24%),
        radial-gradient(circle at 95% 28%, rgba(194,70,65,0.16) 0%, transparent 20%),
        /* 整体微妙的暖光 */
        radial-gradient(ellipse at 50% 0%, rgba(194,70,65,0.08) 0%, transparent 60%);
    pointer-events: none;
}

/* 青海波纹样覆盖 */
.jp-header::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 24px,
            rgba(255,255,255,0.015) 24px,
            rgba(255,255,255,0.015) 25px
        );
    pointer-events: none;
    mask-image: linear-gradient(to bottom, transparent 0%, black 15%, black 85%, transparent 100%);
    -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 15%, black 85%, transparent 100%);
}

.jp-header-inner {
    position: relative;
    z-index: 2;
}

.jp-flag {
    font-size: 14px;
    display: inline-block;
    background: rgba(255,255,255,0.10);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 100px;
    padding: 5px 18px;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin-bottom: 20px;
    font-family: "Noto Sans SC", sans-serif;
    backdrop-filter: blur(4px);
}

.jp-header h1 {
    font-size: 34px;
    font-weight: 600;
    letter-spacing: 4px;
    margin-bottom: 8px;
    font-family: "Noto Serif SC", "Hiragino Mincho ProN", "Yu Mincho", serif;
}

.jp-subtitle {
    font-size: 13px;
    color: rgba(255,255,255,0.45);
    letter-spacing: 5px;
    text-transform: uppercase;
    font-family: "Noto Sans SC", sans-serif;
}

/* ========== 主体布局 ========== */
.jp-main {
    max-width: 920px;
    margin: -28px auto 80px;
    padding: 0 24px;
    position: relative;
    z-index: 1;
}

/* ========== 卡片 ========== */
.jp-card {
    margin-bottom: 22px;
    border-radius: var(--jp-radius) !important;
    border: 1px solid var(--jp-border) !important;
    background: var(--jp-cream) !important;
    box-shadow: var(--jp-shadow-sm) !important;
    transition: box-shadow 0.35s ease, border-color 0.35s ease;
    overflow: hidden;
}

.jp-card:hover {
    box-shadow: var(--jp-shadow-md) !important;
    border-color: var(--jp-border-light) !important;
}

.jp-card .el-card__header {
    background: linear-gradient(to bottom, #FFFDF9, #FAF7F2);
    border-bottom: 1px solid var(--jp-border-light);
    padding: 18px 28px;
    border-radius: var(--jp-radius) var(--jp-radius) 0 0;
}

.jp-card .el-card__body {
    padding: 28px;
}

/* 卡片头部左侧色条 */
.jp-card .el-card__header::before {
    content: '';
    position: absolute;
    left: 0;
    top: 14px;
    bottom: 14px;
    width: 3px;
    background: var(--jp-vermilion);
    border-radius: 0 3px 3px 0;
}

.jp-card-header {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    font-weight: 600;
    color: var(--jp-ink);
    font-family: "Noto Serif SC", "Hiragino Mincho ProN", serif;
    letter-spacing: 0.5px;
}

.jp-card-icon {
    font-size: 18px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(194,70,65,0.07);
    border-radius: 8px;
    flex-shrink: 0;
}

/* ========== 表单元素 ========== */
.jp-card .el-form-item {
    margin-bottom: 20px;
}

.jp-card .el-form-item__label {
    font-size: 12.5px;
    color: var(--jp-ink-light);
    font-weight: 500;
    padding-bottom: 5px;
    letter-spacing: 0.3px;
}

/* 必填星号 */
.jp-card .el-form-item__label::before {
    color: var(--jp-vermilion) !important;
}

.jp-card .el-input__wrapper {
    border-radius: var(--jp-radius-sm);
    background: #FFFEFC;
    box-shadow: 0 0 0 1px var(--jp-border) inset !important;
    transition: all 0.25s ease;
    padding: 0 14px;
}

.jp-card .el-input__wrapper:hover {
    box-shadow: 0 0 0 1px #D0C8BB inset !important;
    background: #fff;
}

.jp-card .el-input__wrapper.is-focus {
    box-shadow: 0 0 0 2px rgba(194,70,65,0.18) inset !important;
    background: #fff;
}

.jp-card .el-input__inner {
    color: var(--jp-ink);
    font-size: 14px;
}

.jp-card .el-input__inner::placeholder {
    color: #C4BDB2;
    font-size: 13px;
}

/* Select */
.jp-card .el-select .el-input__wrapper {
    border-radius: var(--jp-radius-sm);
}

/* Radio */
.jp-card .el-radio {
    margin-right: 20px;
}

.jp-card .el-radio__input.is-checked .el-radio__inner {
    background-color: var(--jp-vermilion);
    border-color: var(--jp-vermilion);
}

.jp-card .el-radio__input.is-checked + .el-radio__label {
    color: var(--jp-vermilion);
    font-weight: 500;
}

.jp-card .el-radio__inner {
    width: 16px;
    height: 16px;
}

/* DatePicker */
.jp-card .el-date-editor.el-input {
    width: 100%;
}

/* Divider */
.jp-card .el-divider {
    margin: 28px 0 22px;
}

.jp-card .el-divider__text {
    font-size: 12.5px;
    color: var(--jp-ink-light);
    font-weight: 500;
    background: var(--jp-cream);
    letter-spacing: 1px;
    font-family: "Noto Serif SC", serif;
}

/* ========== 上传区域 ========== */
.jp-upload-area {
    text-align: center;
    padding: 4px 0;
}

.jp-upload-inner {
    padding: 28px 0;
}

.jp-upload-icon {
    font-size: 44px;
    color: var(--jp-vermilion);
    display: block;
    margin: 0 auto 12px;
}

.jp-upload-title {
    font-size: 15px;
    color: var(--jp-ink);
    font-weight: 500;
    margin-bottom: 4px;
    letter-spacing: 0.5px;
}

.jp-upload-hint {
    font-size: 12.5px;
    color: #B0A89B;
    letter-spacing: 0.3px;
}

.jp-card .el-upload-dragger {
    border: 2px dashed #D8D0C4 !important;
    border-radius: var(--jp-radius) !important;
    background: linear-gradient(180deg, #FFFEFC, #FAF8F4) !important;
    transition: all 0.35s ease !important;
}

.jp-card .el-upload-dragger:hover {
    border-color: var(--jp-vermilion-light) !important;
    background: linear-gradient(180deg, #FFFDFB, #FDF6F4) !important;
}

/* 上传状态提示 */
.upload-status {
    margin-top: 14px;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 13px;
    text-align: left;
}

.upload-status.upload-success {
    background: #ECF5EC;
    color: #2D5A2D;
    border-left: 3px solid #5B9E5B;
}

.upload-status.upload-error {
    background: #FDF2F2;
    color: #8B2525;
    border-left: 3px solid var(--jp-vermilion);
}

.upload-status.upload-loading {
    background: #EEF4FA;
    color: #2D4B63;
    border-left: 3px solid var(--jp-indigo);
}

/* OCR识别提示 */
.ocr-tips {
    margin-top: 14px;
    padding: 14px 16px;
    background: #FDF9F0;
    border: 1px solid #F0E4CF;
    border-radius: 8px;
    font-size: 12.5px;
    color: #7A6838;
    text-align: left;
    line-height: 1.7;
}

.ocr-tips strong {
    display: block;
    margin-bottom: 4px;
    font-size: 13px;
    letter-spacing: 0.5px;
}

.ocr-tips ul {
    margin: 2px 0 0 18px;
    padding: 0;
}

.ocr-tips li {
    margin-bottom: 1px;
}

/* ========== 按钮 ========== */
.jp-form-actions {
    display: flex;
    gap: 16px;
    justify-content: center;
    padding: 36px 0 80px;
}

.jp-submit-btn {
    background: linear-gradient(160deg, var(--jp-vermilion) 0%, var(--jp-vermilion-deep) 100%) !important;
    border: none !important;
    border-radius: 100px !important;
    padding: 14px 52px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    letter-spacing: 1.5px;
    box-shadow:
        0 6px 20px rgba(194,70,65,0.30),
        0 1px 3px rgba(194,70,65,0.15) !important;
    transition: all 0.3s ease !important;
    font-family: "Noto Serif SC", "Hiragino Mincho ProN", serif;
}

.jp-submit-btn:hover {
    transform: translateY(-2px);
    box-shadow:
        0 10px 28px rgba(194,70,65,0.38),
        0 2px 6px rgba(194,70,65,0.20) !important;
}

.jp-submit-btn:active {
    transform: translateY(0);
    box-shadow:
        0 3px 10px rgba(194,70,65,0.22) !important;
}

.jp-reset-btn {
    border-radius: 100px !important;
    padding: 14px 36px !important;
    border: 1px solid var(--jp-border) !important;
    color: var(--jp-ink-light) !important;
    font-size: 14px !important;
    letter-spacing: 1px;
    background: #FFFEFC !important;
    transition: all 0.3s ease !important;
}

.jp-reset-btn:hover {
    border-color: var(--jp-vermilion-light) !important;
    color: var(--jp-vermilion) !important;
    background: #FFFDFB !important;
}

/* ========== 成功对话框 ========== */
.jp-success-dialog {
    text-align: center;
    padding: 24px 0;
}

.jp-success-icon {
    font-size: 56px;
    margin-bottom: 20px;
}

.jp-success-dialog p {
    font-size: 15px;
    color: var(--jp-ink);
    margin-bottom: 20px;
}

.jp-pdf-link {
    margin-top: 14px;
}

.jp-pdf-link .el-link {
    font-weight: 500;
    letter-spacing: 0.5px;
}

.jp-pdf-btn {
    margin-top: 12px;
}

.jp-pdf-btn .el-button {
    background: linear-gradient(160deg, var(--jp-vermilion) 0%, var(--jp-vermilion-deep) 100%);
    border: none;
    border-radius: 100px;
    padding: 12px 36px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 1px;
    color: #fff;
    box-shadow: 0 4px 14px rgba(194,70,65,0.25);
    transition: all 0.3s ease;
    font-family: "Noto Serif SC", "Hiragino Mincho ProN", serif;
}

.jp-pdf-btn .el-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(194,70,65,0.35);
}

/* ========== 加载遮罩 ========== */
.jp-loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(20,20,20,0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.jp-loading-content {
    text-align: center;
    color: #fff;
}

.jp-loading-content p {
    margin-top: 18px;
    font-size: 15px;
    letter-spacing: 2px;
    font-family: "Noto Serif SC", serif;
}

/* ========== Element Plus Dialog 覆盖 ========== */
.el-dialog {
    border-radius: 14px !important;
    overflow: hidden;
}

.el-dialog__header {
    background: linear-gradient(to bottom, #FFFDF9, #FAF7F2);
    border-bottom: 1px solid var(--jp-border-light);
    padding: 20px 28px !important;
}

.el-dialog__title {
    font-family: "Noto Serif SC", "Hiragino Mincho ProN", serif;
    font-weight: 600;
    letter-spacing: 1px;
}

.el-dialog__body {
    padding: 28px !important;
}

.el-dialog__footer {
    padding: 0 28px 24px !important;
}

/* ========== Element Plus Message 覆盖 ========== */
.el-message {
    border-radius: 8px !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.10) !important;
}

/* ========== 通知 ========== */
.notification {
    position: fixed;
    top: 24px;
    right: 24px;
    padding: 16px 24px;
    border-radius: 10px;
    box-shadow: 0 8px 28px rgba(0,0,0,0.12), 0 2px 6px rgba(0,0,0,0.06);
    z-index: 10000;
    max-width: 420px;
    font-size: 14px;
    line-height: 1.6;
    animation: slideIn 0.35s ease-out;
    font-family: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
    letter-spacing: 0.3px;
}

.notification-success {
    background: #3D6B4F;
    color: #fff;
}

/* ========== 动画 ========== */
@keyframes slideIn {
    from { transform: translateX(400px); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

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

.jp-card {
    animation: fadeInUp 0.5s ease forwards;
}

.jp-card:nth-child(1) { animation-delay: 0.05s; }
.jp-card:nth-child(2) { animation-delay: 0.10s; }
.jp-card:nth-child(3) { animation-delay: 0.15s; }
.jp-card:nth-child(4) { animation-delay: 0.20s; }
.jp-card:nth-child(5) { animation-delay: 0.25s; }
.jp-card:nth-child(6) { animation-delay: 0.30s; }
.jp-card:nth-child(7) { animation-delay: 0.35s; }

/* ========== 响应式 ========== */
@media (max-width: 768px) {
    .jp-header {
        padding: 36px 16px 32px;
    }

    .jp-header h1 {
        font-size: 24px;
        letter-spacing: 3px;
    }

    .jp-flag {
        font-size: 12px;
        padding: 4px 14px;
        margin-bottom: 14px;
    }

    .jp-main {
        padding: 0 14px;
        margin-top: -20px;
    }

    .jp-card .el-card__body {
        padding: 18px;
    }

    .jp-card .el-card__header {
        padding: 14px 20px;
    }

    .jp-form-actions {
        flex-direction: column;
        padding: 28px 0 48px;
    }

    .jp-submit-btn,
    .jp-reset-btn {
        width: 100%;
        justify-content: center;
    }
}
