/* トヨワク 履歴書ツール — リデザイン CSS */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&family=Noto+Serif+JP:wght@400;700&display=swap');

:root {
  --red:#eb0a1e; --red-dark:#c5001a; --red-soft:#fff0f2;
  --charcoal:#1a1a1a; --ink:#2d2d2d; --muted:#6b7280; --subtle:#9ca3af;
  --border:#e5e7eb; --surface:#f9fafb; --white:#fff;
  --green:#16a34a;
  --shadow-sm:0 1px 3px rgba(0,0,0,0.06);
  --shadow:0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.12);
  --radius:10px; --radius-sm:6px;
  --panel-w:460px; --header-h:56px;
  --tr:0.2s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;background:#dfe2e8;color:var(--ink);min-height:100vh;overflow:hidden}

/* === HEADER === */
.app-header{height:var(--header-h);background:var(--charcoal);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:fixed;top:0;left:0;right:0;z-index:200;box-shadow:0 2px 12px rgba(0,0,0,0.2)}
.logo-wrap{display:flex;align-items:center;gap:10px}
.header-logo{height:28px}
.header-sep{width:1px;height:20px;background:rgba(255,255,255,0.2)}
.header-subtitle{font-size:12px;color:rgba(255,255,255,0.55);letter-spacing:0.06em;font-weight:300}
.header-right{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;min-width:0;overflow:hidden;}

/* === LAYOUT === */
.app-body{display:flex;height:calc(100vh - var(--header-h));margin-top:var(--header-h)}

/* === SIDEBAR NAV === */
.sidebar-nav{width:64px;background:var(--charcoal);display:flex;flex-direction:column;align-items:center;padding:16px 0;gap:4px;flex-shrink:0;border-right:1px solid rgba(255,255,255,0.06)}
.nav-item{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:var(--tr);gap:2px;position:relative;border:none;background:transparent;color:rgba(255,255,255,0.4);font-family:inherit}
.nav-item:hover{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.8)}
.nav-item.active{background:var(--red);color:white}
.nav-item .nav-icon{font-size:18px;line-height:1}
.nav-item .nav-label{font-size:9px;font-weight:700;letter-spacing:0.03em;line-height:1}
.nav-item .check-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:#22c55e;border-radius:50%;border:1.5px solid var(--charcoal);display:none}
.nav-item.done .check-dot{display:block}
.nav-divider{width:32px;height:1px;background:rgba(255,255,255,0.1);margin:4px 0}

/* === FORM PANEL === */
.form-panel{width:var(--panel-w);flex-shrink:0;background:var(--white);display:flex;flex-direction:column;overflow:hidden;box-shadow:2px 0 16px rgba(0,0,0,0.06);position:relative;z-index:1}
.panel-header{padding:12px 24px 0;flex-shrink:0}
.panel-title{font-size:15px;font-weight:900;color:var(--charcoal);display:flex;align-items:center;gap:8px}
.panel-title-icon{font-size:22px;line-height:1;display:flex;align-items:center}
.panel-desc{font-size:11px;color:var(--muted);margin-top:2px;margin-left:40px;line-height:1.4}
.panel-progress{display:flex;align-items:center;gap:8px;padding:8px 24px 0}
.progress-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--red),#ff4d5e);border-radius:2px;transition:width 0.5s ease}
.progress-pct{font-size:11px;font-weight:700;color:var(--red);min-width:30px;text-align:right}
.panel-scroll{flex:1;overflow-y:auto;padding:12px 24px 20px;scrollbar-width:thin;scrollbar-color:#ddd transparent}
.panel-scroll::-webkit-scrollbar{width:4px}
.panel-scroll::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}
.form-section{display:none}
.form-section.active{display:block}

/* === FIELD CARD === */
.field-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;transition:border-color var(--tr),box-shadow var(--tr)}
.field-card:focus-within{border-color:var(--red);box-shadow:0 0 0 3px rgba(235,10,30,0.06)}
.card-title{font-size:10.5px;font-weight:700;letter-spacing:0.08em;color:var(--muted);text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.card-title::before{content:'';display:inline-block;width:3px;height:11px;background:var(--red);border-radius:2px;flex-shrink:0}

/* === FLOAT LABEL === */
.float-field{position:relative;margin-bottom:10px}
.float-field input,.float-field select,.float-field textarea{width:100%;padding:18px 12px 6px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:'Noto Sans JP',sans-serif;color:var(--charcoal);background:var(--white);transition:border-color var(--tr),box-shadow var(--tr);-webkit-appearance:none;appearance:none}
.float-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}
.float-field textarea{resize:vertical;min-height:88px;line-height:1.7}
.float-field label{position:absolute;top:12px;left:12px;font-size:12px;color:var(--subtle);font-weight:500;transition:var(--tr);pointer-events:none;line-height:1;white-space:nowrap}
.float-field input:focus,.float-field select:focus,.float-field textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(235,10,30,0.08)}
.float-field input:focus+label,.float-field input:not(:placeholder-shown)+label,.float-field select:focus+label,.float-field select.has-val+label,.float-field textarea:focus+label,.float-field textarea:not(:placeholder-shown)+label{top:5px;font-size:10px;color:var(--red);font-weight:700}

/* === PLAIN LABEL INPUT === */
.plain-label{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:0.04em;margin-bottom:5px;display:block}
.plain-label .req{color:var(--red);margin-left:2px}
.plain-input{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:'Noto Sans JP',sans-serif;color:var(--charcoal);background:var(--white);transition:border-color var(--tr),box-shadow var(--tr);-webkit-appearance:none;appearance:none}
.plain-input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(235,10,30,0.08)}
.plain-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}

/* === GRID === */
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.row-2>*{min-width:0}
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.mb-8{margin-bottom:8px}
.mb-10{margin-bottom:10px}

/* === POSTAL === */
.postal-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end;margin-bottom:10px}
.postal-btn{white-space:nowrap;padding:9px 14px;background:var(--charcoal);color:white;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:700;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:var(--tr);height:38px;display:flex;align-items:center;gap:4px}
.postal-btn:hover{background:var(--red)}
.postal-btn:disabled{opacity:0.6;pointer-events:none}

/* === PHOTO === */
.photo-section{display:flex;gap:16px;align-items:flex-start;background:var(--surface);border:1.5px dashed var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;transition:border-color var(--tr);cursor:pointer}
.photo-section:hover{border-color:rgba(235,10,30,0.4)}
.photo-drop{width:80px;height:107px;border-radius:var(--radius-sm);overflow:hidden;background:var(--white);border:1.5px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.photo-drop img{width:100%;height:100%;object-fit:cover;display:none}
.photo-drop img.visible{display:block}
.photo-placeholder{text-align:center;padding:4px}
.photo-placeholder .icon{font-size:22px;display:block;margin-bottom:4px}
.photo-placeholder .text{font-size:9px;color:var(--subtle);line-height:1.4}
.photo-info{flex:1}
.photo-info h4{font-size:13px;font-weight:700;margin-bottom:4px;color:var(--charcoal)}
.photo-info p{font-size:11px;color:var(--muted);line-height:1.6;margin-bottom:10px}
.photo-btns{display:flex;gap:6px;flex-wrap:wrap}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;border:none;font-family:'Noto Sans JP',sans-serif;transition:var(--tr);letter-spacing:0.03em;white-space:nowrap;line-height:1}
.btn-primary{background:var(--red);color:white}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 4px 14px rgba(235,10,30,0.35)}
.btn-primary:active{transform:translateY(0);box-shadow:none}
.btn-dark{background:var(--charcoal);color:white}
.btn-dark:hover{background:#333}
.btn-ghost-light{background:transparent;color:rgba(255,255,255,0.7);border:1.5px solid rgba(255,255,255,0.2)}
.btn-ghost-light:hover{background:rgba(255,255,255,0.1);color:white;border-color:rgba(255,255,255,0.4)}
.btn-outline{background:white;color:var(--muted);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--charcoal);color:var(--charcoal)}
.btn-sm{padding:6px 12px;font-size:11px}
.btn-xs{padding:4px 8px;font-size:10px;border-radius:4px}
.btn-danger{background:#fff0f0;color:#dc2626;border:1.5px solid #fecaca}
.btn-danger:hover{background:#fee2e2;border-color:#dc2626}

/* === PANEL FOOTER === */
.panel-footer{padding:8px 24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:white;flex-shrink:0}
.step-info{font-size:11px;color:var(--subtle)}
.autosave-badge{font-size:10px;color:var(--subtle);display:flex;align-items:center;gap:4px}
.autosave-badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.autosave-badge.saved{color:var(--green)}

/* === SECTION SEP === */
.section-sep{display:flex;align-items:center;gap:10px;margin:18px 0 12px}
.section-sep-text{font-size:10.5px;font-weight:900;letter-spacing:0.1em;color:var(--charcoal);text-transform:uppercase;white-space:nowrap;display:flex;align-items:center;gap:6px}
.section-sep-line{flex:1;height:1px;background:var(--border)}

/* === TIMELINE BLOCKS === */
.timeline-block{border:1.5px solid var(--border);border-radius:var(--radius);background:white;margin-bottom:8px;transition:border-color var(--tr),box-shadow var(--tr);overflow:hidden}
.timeline-block.drag-over{border-color:var(--red);box-shadow:0 0 0 2px rgba(235,10,30,0.15)}
.timeline-block.dragging{opacity:0.4}
.tl-header{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;user-select:none;background:var(--surface);border-bottom:1px solid transparent;transition:background var(--tr),border-color var(--tr)}
.timeline-block.expanded .tl-header{border-bottom-color:var(--border);background:white}
.tl-drag{color:var(--subtle);cursor:grab;flex-shrink:0;padding:2px 4px;display:flex;flex-direction:column;gap:3px}
.tl-drag span{display:block;width:14px;height:2px;background:var(--border);border-radius:1px}
.tl-drag:active{cursor:grabbing}
.tl-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;flex-shrink:0}
.tl-badge.edu{background:#dbeafe;color:#1d4ed8}
.tl-badge.work{background:#dcfce7;color:#15803d}
.tl-badge.qual{background:#fef3c7;color:#92400e}
.tl-badge.career-co{background:#f3e8ff;color:#7e22ce}
.tl-summary{flex:1;min-width:0}
.tl-name{font-size:12px;font-weight:700;color:var(--charcoal);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-date{font-size:10px;color:var(--muted);margin-top:1px}
.tl-chevron{color:var(--subtle);font-size:12px;transition:transform var(--tr);flex-shrink:0}
.timeline-block.expanded .tl-chevron{transform:rotate(180deg)}
.tl-body{display:none;padding:14px;border-top:1px solid var(--border);animation:fadeIn 0.15s ease}
.timeline-block.expanded .tl-body{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* === ADD BUTTON === */
.add-row{display:flex;gap:8px;margin-top:4px}
.btn-add-block{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px;border:1.5px dashed var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--muted);font-size:12px;font-weight:700;cursor:pointer;font-family:'Noto Sans JP',sans-serif;transition:var(--tr)}
.btn-add-block:hover{border-color:var(--red);color:var(--red);background:var(--red-soft)}
.btn-add-block .plus{width:20px;height:20px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;transition:var(--tr)}
.btn-add-block:hover .plus{background:var(--red);color:white}

/* === TOGGLE === */
.toggle-row{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer;user-select:none}
.toggle-row input[type="checkbox"]{width:0;height:0;opacity:0;position:absolute}
.toggle-track{width:36px;height:20px;border-radius:10px;background:var(--border);position:relative;flex-shrink:0;transition:background var(--tr)}
.toggle-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;background:white;border-radius:50%;box-shadow:var(--shadow-sm);transition:transform var(--tr)}
.toggle-row input:checked ~ .toggle-track{background:var(--red)}
.toggle-row input:checked ~ .toggle-track .toggle-thumb{transform:translateX(16px)}
.toggle-label{font-size:12px;color:var(--muted);font-weight:500}

/* === EMPTY STATE === */
.empty-state{text-align:center;padding:24px 0;color:var(--subtle)}
.empty-state .empty-icon{font-size:32px;display:block;margin-bottom:8px}
.empty-state .empty-text{font-size:12px;line-height:1.6}

/* === HINT === */
.hint{font-size:10.5px;color:var(--subtle);margin-top:3px;line-height:1.5;display:flex;align-items:flex-start;gap:4px}
.hint::before{content:'ℹ';font-size:10px;flex-shrink:0;margin-top:1px}

/* === PREVIEW === */
.preview-panel{flex:1;overflow-y:auto;background:#c8ccd4;display:flex;flex-direction:column;align-items:center;padding:16px 12px;scrollbar-width:thin;scrollbar-color:#aaa transparent;min-width:0;overflow-x:hidden;box-sizing:border-box;}
.preview-panel::-webkit-scrollbar{width:5px}
.preview-panel::-webkit-scrollbar-thumb{background:#aaa;border-radius:3px}
.preview-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,0.85);border-radius:20px;padding:4px 12px;font-size:10.5px;font-weight:700;color:#1a1a1a;letter-spacing:0.06em;margin-bottom:10px;align-self:flex-start;white-space:nowrap;flex-shrink:0;}
.page-gap{height:40px;display:flex;align-items:center;justify-content:center;width:100%}
.page-gap-line{width:200px;height:1px;border-top:2px dashed rgba(255,255,255,0.4)}

/* === RESUME DOCUMENT === */
.resume-doc{width:794px;min-height:1123px;background:white;box-shadow:0 8px 40px rgba(0,0,0,0.22);position:relative;font-family:'Noto Serif JP',serif;padding:36px 44px 44px;transform-origin:top left;flex-shrink:0;transition:transform 0.15s ease;}
.watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-35deg);opacity:0.04;pointer-events:none;z-index:0}
.watermark img{width:380px}
.doc-content{position:relative;z-index:1}

/* --- Doc header --- */
.doc-title-bar{text-align:center;margin-bottom:16px;padding-bottom:12px;border-bottom:2.5px solid var(--charcoal);position:relative}
.doc-main-title{font-size:26px;font-weight:700;letter-spacing:0.5em;padding-right:0.5em}
.doc-date-line{font-size:11px;color:var(--muted);text-align:right;margin-top:6px}
.toyowaku-stamp{position:absolute;top:0;right:0;background:var(--red);color:white;font-size:9px;font-weight:700;padding:3px 8px 3px 6px;border-radius:3px;display:flex;align-items:center;gap:4px;font-family:'Noto Sans JP',sans-serif}
.toyowaku-stamp img{height:11px;filter:brightness(0) invert(1)}

/* --- Tables --- */
.personal-grid{display:grid;grid-template-columns:1fr 82px;gap:12px;margin-bottom:14px}
.info-table{width:100%;border-collapse:collapse;font-size:11.5px}
.info-table td{padding:5px 7px;border:1px solid #333;vertical-align:middle;line-height:1.5}
.info-table td.lbl{background:#f0f0f0;font-weight:700;font-size:10.5px;white-space:nowrap}
.info-table td.name-cell{font-size:20px;font-weight:700;letter-spacing:0.08em;padding:6px 8px}
.photo-frame{border:1px solid #333;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#f8f8f8}
.photo-frame img{width:100%;height:100%;object-fit:cover}
.no-photo{font-size:9px;color:#bbb;text-align:center;padding:6px;line-height:1.5}
.doc-sec-title{font-size:12px;font-weight:700;background:var(--charcoal);color:white;padding:4px 10px;letter-spacing:0.12em;font-family:'Noto Sans JP',sans-serif}
.doc-table{width:100%;border-collapse:collapse;font-size:11.5px}
.doc-table td{padding:4px 7px;border:1px solid #333;border-top:none;vertical-align:top;line-height:1.6}
.doc-table td.ym{width:78px;text-align:center;white-space:nowrap}
.qual-table{width:100%;border-collapse:collapse;font-size:11.5px}
.qual-table td{padding:4px 7px;border:1px solid #333;border-top:none;vertical-align:top}
.qual-table td.qym{width:84px;text-align:center}
.motive-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid #333;border-top:none}
.motive-cell{padding:0;border-right:1px solid #333}
.motive-cell:last-child{border-right:none}
.motive-cell-title{font-size:10px;font-weight:700;background:#f0f0f0;padding:4px 8px;border-bottom:1px solid #333;font-family:'Noto Sans JP',sans-serif}
.motive-cell-body{font-size:11px;padding:8px;min-height:88px;line-height:1.8;white-space:pre-wrap}
.meta-table{width:100%;border-collapse:collapse;font-size:11px}
.meta-table td{padding:4px 7px;border:1px solid #333;border-top:none;white-space:nowrap}
.meta-table td.lbl{background:#f0f0f0;font-weight:700}

/* --- Career doc entries --- */
.career-entry{border:1px solid #333;margin-bottom:10px;page-break-inside:avoid}
.career-entry-head{background:#f0f0f0;padding:5px 10px;border-bottom:1px solid #333;font-weight:700;font-size:12px;display:flex;align-items:center;gap:8px;font-family:'Noto Sans JP',sans-serif;flex-wrap:wrap}
.career-entry-head .co-period{font-weight:400;font-size:10.5px;color:var(--muted)}
.career-entry-head .co-type{font-weight:400;font-size:10px;background:white;border:1px solid #ccc;padding:1px 6px;border-radius:3px;margin-left:auto}
.career-entry-table{width:100%;border-collapse:collapse;font-size:11px}
.career-entry-table td{padding:5px 8px;border-bottom:1px solid #e8e8e8;vertical-align:top;line-height:1.7}
.career-entry-table tr:last-child td{border-bottom:none}
.career-entry-table td.row-lbl{width:80px;background:#fafafa;font-weight:700;color:var(--muted);white-space:nowrap}
.career-entry-table td.row-val{white-space:pre-wrap}

/* === TOAST === */
.toast{position:fixed;bottom:24px;right:24px;background:var(--charcoal);color:white;padding:12px 20px 12px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;z-index:9999;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity 0.25s,transform 0.25s;display:flex;align-items:center;gap:10px;max-width:300px;font-family:'Noto Sans JP',sans-serif;box-shadow:var(--shadow-lg)}
.toast.show{opacity:1;transform:translateY(0);pointer-events:auto}
.toast-bar{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px}
.toast.success .toast-bar{background:#22c55e}
.toast.error .toast-bar{background:var(--red)}

/* === 印刷専用スタイル === */
@media print {
  /* 1. 不要な UI 要素をすべて非表示にする */
  .app-header, .sidebar-nav, .form-panel, .panel-footer, 
  .preview-chip, .page-gap, #diagnosis-toggle, .toast, 
  .modal-overlay, .print-confirm-overlay, .watermark { 
    display: none !important; 
  }

  /* 2. 背景と外枠の制限を解除 */
  body, .app-body, .preview-panel {
    background: white !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    display: block !important;
    width: 100% !important;
    height: auto !important;
  }

  /* 3. 履歴書本体のスタイル調整 */
  .resume-doc {
    width: 210mm !important;       /* A4の横幅に固定 */
    min-height: auto !important;   /* 余白による白紙防止 */
    padding: 12mm 15mm !important; /* 印刷時の余白を調整 */
    margin: 0 auto !important;
    border: none !important;
    box-shadow: none !important;
    
    /* 重要：プレビュー用の scale(縮小) を強制的に解除 */
    transform: none !important; 
    
    /* 重要：背景色や罫線の色を強制的に印刷する */
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    
    /* ページ区切りの設定 */
    page-break-after: always !important;
    break-after: page !important;
  }

  /* コンテンツ内の調整 */
  .doc-content {
    width: 100% !important;
  }

  /* 職務経歴書（2枚目）の後は改ページしない（白紙ページ防止） */
  #resume-document-2 {
    page-break-after: avoid !important;
    break-after: avoid !important;
  }

  /* 印刷対象外のdocを非表示 */
  [data-print-hide] { display: none !important; }

  /* 履歴書のみ選択時、doc1が最後になるので改ページ抑制 */
  [data-print-last] { page-break-after: avoid !important; break-after: avoid !important; }

  /* 印刷プレビュー時にリンクの横にURLが出ないようにする（ブラウザ設定対策） */
  a:after { content: none !important; }
}

/* 印刷中・印刷後もモーダルを強制非表示にするクラス */
.modal-print-hidden {
  display: none !important;
}

/* 印刷確認モーダル専用オーバーレイ（@media printのmodal-overlay非表示の影響を受けない） */
.print-confirm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  align-items: center;
  justify-content: center;
  z-index: 9000;
  backdrop-filter: blur(3px);
}

/* === MODAL === */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);display:flex;align-items:center;justify-content:center;z-index:9000;backdrop-filter:blur(3px)}
.modal-box{background:white;border-radius:16px;padding:28px 20px;max-width:440px;width:calc(100vw - 32px);box-shadow:0 24px 60px rgba(0,0,0,0.25);animation:modalIn 0.25s ease;box-sizing:border-box;}
@keyframes modalIn{from{opacity:0;transform:scale(0.92) translateY(12px)}to{opacity:1;transform:none}}
.modal-icon{font-size:40px;text-align:center;margin-bottom:12px}
.modal-title{font-size:18px;font-weight:900;color:var(--charcoal);text-align:center;margin-bottom:12px}
.modal-text{font-size:13px;color:var(--muted);line-height:1.8;text-align:center;margin-bottom:20px}
.modal-text strong{color:var(--charcoal)}


/* === 項目ヒント（？ボタン） === */
.hint-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; border-radius: 50%;
  background: #e5e7eb; color: #6b7280;
  font-size: 10px; font-weight: 700; cursor: pointer;
  border: none; font-family: inherit; flex-shrink: 0;
  position: relative; vertical-align: middle; margin-left: 4px;
  transition: background 0.15s;
}
.hint-btn:hover { background: #eb0a1e; color: white; }
.hint-btn.tt-active { background: #eb0a1e; color: white; }
.hint-tooltip {
  display: none;
  position: fixed;
  background: #1a1a1a; color: white;
  font-size: 11px; font-weight: 400; line-height: 1.6;
  padding: 7px 10px; border-radius: 6px;
  z-index: 99999;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  pointer-events: none; min-width: 180px; max-width: 260px;
  white-space: normal;
  word-break: break-word;
}
.hint-tooltip.tt-above::after {
  content: ''; position: absolute; top: 100%; left: var(--tt-arrow-left, 50%);
  transform: translateX(-50%);
  border: 5px solid transparent; border-top-color: #1a1a1a;
}
.hint-tooltip.tt-below::after {
  content: ''; position: absolute; bottom: 100%; left: var(--tt-arrow-left, 50%);
  transform: translateX(-50%);
  border: 5px solid transparent; border-bottom-color: #1a1a1a;
}
/* === FIELD ERROR === */
.field-error{font-size:11px;color:var(--red);margin-top:4px;display:flex;align-items:center;gap:4px;padding:4px 8px;background:var(--red-soft);border-radius:4px}
.field-error::before{content:"⚠"}

/* === TYPE SELECT in tl-actions === */
.type-sel{font-family:"Noto Sans JP",sans-serif;appearance:none;-webkit-appearance:none}

/* === TEMPLATE MODAL === */
.tmpl-tab{padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);background:white;font-size:12px;font-weight:700;cursor:pointer;font-family:"Noto Sans JP",sans-serif;color:var(--muted);transition:var(--tr)}
.tmpl-tab.active{background:var(--charcoal);color:white;border-color:var(--charcoal)}
.tmpl-tab:hover:not(.active){border-color:var(--charcoal);color:var(--charcoal)}

.tmpl-card{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:var(--tr);background:white}
.tmpl-card:hover{border-color:var(--red);background:var(--red-soft)}
.tmpl-card-title{font-size:12px;font-weight:700;color:var(--charcoal);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.tmpl-card-preview{font-size:11px;color:var(--muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tmpl-card-badge{font-size:10px;background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0;border-radius:3px;padding:1px 6px;font-weight:700}

/* === CHAR COUNTER === */
.char-count{transition:color 0.2s}
.char-count.warn{color:#f59e0b!important}
.char-count.over{color:var(--red)!important}

/* === CARD TITLE FLEX === */
.field-card .card-title{justify-content:space-between}

/* === TOOLTIP (郵便番号ヒント) === */
.field-hint{font-size:10.5px;color:var(--subtle);margin-top:3px;padding:4px 8px;background:var(--surface);border-radius:4px;display:flex;align-items:center;gap:4px}
.field-hint::before{content:"💡";font-size:11px}

/* === CROP MODAL === */
#crop-canvas{display:block;user-select:none;-webkit-user-select:none;}
#crop-zoom{height:6px;border-radius:3px;}

/* === ① 診断パネル === */
.diag-item{display:flex;align-items:flex-start;gap:8px;padding:7px 10px;font-size:11.5px;line-height:1.5;border-bottom:1px solid rgba(0,0,0,0.06);}
.diag-item:last-child{border-bottom:none;}
.diag-item.error{background:#fff5f5;color:#c0392b;}
.diag-item.warning{background:#fffbf0;color:#b7791f;}
.diag-item.info{background:#f0f7ff;color:#2563eb;}
.diag-icon{font-size:13px;flex-shrink:0;margin-top:1px;}
.diag-text{flex:1;}
.diag-text strong{font-weight:700;display:block;margin-bottom:1px;}
.diag-text span{opacity:0.85;}
#diagnosis-panel{margin-bottom:4px;}

/* === ② 和暦ヒント === */
.wareki-hint{font-size:10.5px;color:#16a34a;font-weight:700;margin-top:3px;padding:2px 6px;background:#f0fdf4;border-radius:4px;display:inline-block;}

/* === ③ クイック資格ボタン === */
.quick-qual-btn{font-size:11px;font-family:"Noto Sans JP",sans-serif;font-weight:700;padding:4px 10px;border:1.5px solid #e5e7eb;border-radius:20px;background:white;color:#4b5563;cursor:pointer;transition:all 0.15s;white-space:nowrap;}
.quick-qual-btn:hover{border-color:#eb0a1e;color:#eb0a1e;background:#fff0f2;}

/* === ⑥ レイアウトスタイル（モダン） === */
.resume-doc.layout-modern .doc-sec-title{background:linear-gradient(90deg,#eb0a1e,#c5001a);letter-spacing:0.15em;}
.resume-doc.layout-modern .doc-title-bar{border-bottom-color:#eb0a1e;border-bottom-width:3px;}
.resume-doc.layout-modern .info-table td.lbl{background:#fff0f2;color:#c0392b;}
.resume-doc.layout-simple .doc-sec-title{background:#4b5563;font-weight:500;}
.resume-doc.layout-simple .doc-title-bar{border-bottom:1.5px solid #9ca3af;}
.resume-doc.layout-simple .info-table td.lbl{background:#f9fafb;color:#6b7280;}

/* === ヘッダーボタン共通 === */
#layout-select{
  font-family:"Noto Sans JP",sans-serif;font-size:12px;
  background:transparent;border:1.5px solid rgba(255,255,255,0.25);
  color:rgba(255,255,255,0.75);border-radius:6px;cursor:pointer;
  appearance:none;-webkit-appearance:none;
  padding:6px 10px;font-weight:700;transition:all 0.2s;
}
#layout-select:hover{background:rgba(255,255,255,0.1);color:white;border-color:rgba(255,255,255,0.5);}
#layout-select option{background:#1a1a1a;color:white;}

/* ヘッダーボタンにツールチップ */
.header-right .btn[title]{position:relative;}
.header-right .btn[title]:hover::after{
  content:attr(title);
  position:absolute;
  bottom:-32px;left:50%;transform:translateX(-50%);
  background:#333;color:white;
  font-size:10px;font-weight:500;white-space:nowrap;
  padding:4px 8px;border-radius:4px;
  pointer-events:none;z-index:9999;
  font-family:"Noto Sans JP",sans-serif;
}

/* 幅に応じてラベルを段階的に省略 */
@media (max-width: 1200px) {
  #save-json-btn .btn-label,
  #load-json-btn .btn-label,
  #clear-btn .btn-label { display:none; }
}
@media (max-width: 980px) {
  #fullscreen-preview-btn .btn-label { display:none; }
  #layout-select { display:none; }
}

/* === チュートリアル === */
.tut-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.3);transition:all 0.2s;cursor:pointer;}
.tut-dot.active{background:var(--red);width:22px;border-radius:4px;}
.tut-slide{animation:fadeIn 0.25s ease;}
.tut-step-icon{font-size:36px;margin-bottom:10px;display:block;}
.tut-step-title{font-size:15px;font-weight:900;color:var(--charcoal);margin-bottom:8px;}
.tut-step-body{font-size:13px;color:var(--muted);line-height:1.8;}
.tut-step-body strong{color:var(--charcoal);}
.tut-step-body .tut-tag{display:inline-block;background:var(--red-soft);color:var(--red);font-size:11px;font-weight:700;padding:1px 7px;border-radius:3px;margin:0 2px;}
.tut-step-tip{margin-top:10px;padding:8px 12px;background:var(--surface);border-radius:6px;border-left:3px solid var(--red);font-size:11.5px;color:var(--muted);}

@media(max-width:800px){.app-header{padding:0 10px;}.header-subtitle{display:none;}}
