/**
 * EnglishPro 移动站专用版式（/root/var/test/EnglishPro）
 * 在 common.css、practice-layout.css 之后引入。
 */

html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/* ---------- 隐藏顶栏（EnglishPro 全部页面） ---------- */
.navbar {
    display: none !important;
}

body > .main-content,
body > .container-page,
body > .msg-center-layout,
body > main:not(.main-stage) {
    margin-top: 0 !important;
}

/* ---------- 练习页主容器：全宽 + 安全区（无顶栏留白） ---------- */
.main-content {
    width: 100% !important;
    max-width: 100% !important;
    padding: max(12px, env(safe-area-inset-top, 0px)) max(14px, env(safe-area-inset-right)) calc(20px + env(safe-area-inset-bottom, 0px)) max(14px, env(safe-area-inset-left)) !important;
    box-sizing: border-box;
    height: auto !important;
    max-height: none !important;
}

.main-content.dictation-page,
.main-content.ctranse-page,
.main-content.speaking-page,
.main-content.etransc-page {
    width: 100% !important;
    max-width: 100% !important;
}

.dictation-page .dictation-result-panel.is-visible {
    display: flex !important;
}

body.dictation-show-result .dictation-page .practice-split-row {
    flex-direction: column !important;
    gap: 16px !important;
}

body.dictation-show-result .dictation-page .practice-pane--left,
body.dictation-show-result .dictation-page .practice-pane--right {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
}

body.dictation-show-result .dictation-page .practice-pane--right .practice-pane-inner {
    max-height: none !important;
    overflow: visible !important;
}

body.dictation-practice-page .main-content.dictation-page {
    padding-bottom: calc(32px + env(safe-area-inset-bottom, 0px)) !important;
    overflow: visible !important;
    height: auto !important;
    max-height: none !important;
    flex: none !important;
    display: block !important;
}

html.dictation-practice-root,
body.dictation-practice-page {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    max-height: none !important;
    height: auto !important;
    min-height: 100vh;
    min-height: 100dvh;
    display: block !important;
    -webkit-overflow-scrolling: touch;
}

/* 听写页：禁用桌面双栏 flex 陷阱，始终纵向全宽 */
body.dictation-practice-page .practice-split-row {
    display: block !important;
    width: 100% !important;
    overflow: visible !important;
    flex: none !important;
    min-height: 0 !important;
}

body.dictation-practice-page .practice-pane--left,
body.dictation-practice-page .practice-pane--right {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    overflow: visible !important;
    min-height: 0 !important;
    max-height: none !important;
}

body.dictation-practice-page .practice-pane--left .practice-pane-inner,
body.dictation-practice-page .practice-pane--right .practice-pane-inner {
    display: block !important;
    overflow: visible !important;
    max-height: none !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
}

body.dictation-practice-page .practice-pane--left .practice-pane-inner::before,
body.dictation-practice-page .practice-pane--left .practice-pane-inner::after,
body.dictation-practice-page .practice-pane--right .practice-pane-inner::before,
body.dictation-practice-page .practice-pane--right .practice-pane-inner::after {
    display: none !important;
    content: none !important;
}

body.dictation-practice-page:not(.dictation-show-result) .practice-pane--right {
    display: none !important;
}

body.dictation-practice-page.dictation-show-result .practice-pane--right {
    display: block !important;
}

body.dictation-practice-page.ep-result-split,
body.dictation-practice-page.ep-result-split .main-content.dictation-page {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

.practice-header {
    margin-bottom: 12px;
}

.header-title {
    font-size: clamp(1.125rem, 5vw, 1.375rem) !important;
    line-height: 1.3;
}

.controls-row {
    gap: 8px !important;
    margin-bottom: 14px !important;
}

.controls-row .level-select-wrapper,
.controls-row select#level-select,
.controls-row #current-level-display,
.controls-row #daily-progress,
.controls-row .notebook-btn {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center;
}

.controls-row #current-level-display,
.controls-row #daily-progress {
    white-space: normal !important;
    text-align: center;
    font-size: 0.8125rem !important;
    line-height: 1.35 !important;
    padding: 8px 12px !important;
}

/* ---------- 题目与输入 ---------- */
.source-card {
    padding: 16px 0 !important;
    margin-bottom: 12px !important;
    min-height: 0 !important;
}

.en-text,
.cn-text,
.etransc-page #source-text.en-text,
.ctranse-page #source-text.cn-text,
.speaking-page #source-text {
    font-size: clamp(1.0625rem, 4.2vw, 1.25rem) !important;
    line-height: 1.55 !important;
    text-align: left !important;
}

textarea,
.etransc-page .input-wrapper textarea#user-input,
.ctranse-page .input-wrapper textarea#user-input {
    font-size: 1.0625rem !important;
    line-height: 1.5 !important;
    min-height: 128px !important;
    padding: 14px !important;
}

.etransc-page .input-wrapper textarea#user-input::placeholder,
.ctranse-page .input-wrapper textarea#user-input::placeholder {
    font-size: 0.875rem !important;
}

.input-wrapper {
    margin-bottom: 12px !important;
}

/* ---------- 操作栏：大按钮 + 底部留白 ---------- */
.action-bar {
    gap: 8px !important;
    margin-top: 8px !important;
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

.action-bar .btn {
    min-width: 0 !important;
    min-height: 48px;
    font-size: 0.9375rem;
    flex: 1 1 100%;
}

.action-bar .btn-submit {
    order: -2;
}

.action-bar .btn-skip {
    order: -1;
}

.action-bar .ai-toggle,
.action-bar .quick-toggle {
    width: 100%;
    justify-content: center;
    order: 0;
}

/* ---------- 听写 ---------- */
.dictation-page .dictation-play-row {
    gap: 12px;
    margin-bottom: 16px;
}

.dictation-page .play-btn {
    width: 72px;
    height: 72px;
}

.dictation-page .dictation-step-label {
    font-size: 0.8125rem;
}

.dictation-page .dictation-mcq-option {
    padding: 12px 14px;
    font-size: 0.9375rem;
}

.dictation-page .dictation-blank-input {
    max-width: min(11ch, 32vw) !important;
    font-size: 1rem !important;
}

.dictation-page .dictation-question-card {
    padding: 12px 0;
}

/* ---------- 口语 ---------- */
.speaking-page .speaking-controls-row {
    flex-direction: column;
    gap: 12px;
    width: 100%;
    max-width: 100%;
}

.speaking-page .mic-btn,
.speaking-page .btn-play-draft,
.speaking-page .btn-tencent-score,
.speaking-page .play-btn {
    width: 80px;
    height: 80px;
}

.speaking-page .transcript-box,
.speaking-page .input-wrapper #transcript-box {
    min-height: 88px;
    font-size: 1rem !important;
    padding: 14px !important;
    text-align: left;
}

.speaking-page .word-popup {
    position: fixed !important;
    left: 12px !important;
    right: 12px !important;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px)) !important;
    top: auto !important;
    transform: none !important;
    max-width: none !important;
    width: auto !important;
    box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.12);
}

/* ---------- 查词弹层 ---------- */
.word-popup {
    left: 12px !important;
    right: 12px !important;
    max-width: none !important;
    width: auto !important;
}

.notebook-sidebar {
    width: min(100vw, 360px);
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* ---------- 评分结果：始终纵向堆叠 ---------- */
body.ep-result-split {
    height: auto !important;
    max-height: none !important;
    overflow: auto !important;
}

body.ep-result-split .main-content {
    overflow: visible !important;
    padding-bottom: calc(24px + env(safe-area-inset-bottom, 0px)) !important;
}

body.ep-result-split .practice-split-row {
    flex-direction: column !important;
    overflow: visible !important;
    gap: 16px !important;
}

body.ep-result-split .practice-pane--left,
body.ep-result-split .practice-pane--right {
    flex: none !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    max-height: none !important;
}

body.ep-result-split .practice-pane--left .practice-pane-inner,
body.ep-result-split .practice-pane--right .practice-pane-inner {
    max-height: none !important;
    overflow: visible !important;
    padding: 12px 0 !important;
}

body.ep-result-split .practice-pane--left .practice-pane-inner::before,
body.ep-result-split .practice-pane--left .practice-pane-inner::after,
body.ep-result-split .practice-pane--right .practice-pane-inner::before,
body.ep-result-split .practice-pane--right .practice-pane-inner::after {
    display: none;
}

body.ep-result-split .practice-pane--right {
    display: flex !important;
}

.result-box,
.error-analysis-box,
.correct-answer-box {
    padding: 16px !important;
    margin-top: 12px !important;
}

.score-grid-new {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
}

.total-score {
    font-size: clamp(1.75rem, 8vw, 2.25rem) !important;
}

.result-toast {
    top: auto !important;
    bottom: calc(72px + env(safe-area-inset-bottom, 0px));
    left: 14px;
    right: 14px;
    transform: none !important;
    max-width: none;
}

.result-toast.show {
    top: auto !important;
}

/* ---------- 积分商城 / 管理类页面 ---------- */
.container-page {
    max-width: 100% !important;
    margin-top: 0 !important;
    height: auto !important;
    max-height: none !important;
    padding-top: max(12px, env(safe-area-inset-top, 0px)) !important;
    padding-left: max(12px, env(safe-area-inset-left));
    padding-right: max(12px, env(safe-area-inset-right));
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

.msg-center-layout {
    margin-top: 0 !important;
    padding-top: max(12px, env(safe-area-inset-top, 0px)) !important;
}

.gifts-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

.points-number {
    font-size: 2.25rem !important;
}

.toolbar {
    flex-direction: column;
    align-items: stretch !important;
    gap: 12px;
}

.table-responsive,
.admin-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 380px) {
    .gifts-grid {
        grid-template-columns: 1fr !important;
    }
}
