:root{--bg: #f6f2e8;--bg-soft: #fffdf8;--ink: #1f2529;--ink-soft: #4a585e;--line: #d5cdc0;--accent: #0f766e;--accent-strong: #115e59;--accent-soft: #cce9e4;--danger: #be3f2f;--danger-soft: #fbe8e6;--warn: #9a6b13;--warn-soft: #fff2d8;--shadow: 0 24px 50px -30px rgba(21, 31, 39, .45)}*{box-sizing:border-box}body{margin:0;min-width:1200px;color:var(--ink);font-family:Avenir Next,Helvetica Neue,Trebuchet MS,sans-serif;background:radial-gradient(circle at 12% 14%,rgba(15,118,110,.11),transparent 32%),radial-gradient(circle at 86% 18%,rgba(190,63,47,.09),transparent 30%),linear-gradient(145deg,#f2ecdf,#f8f5ed 48%,#f4ede2)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.32;background-image:linear-gradient(to right,rgba(20,33,41,.06) 1px,transparent 1px);background-size:36px 36px}#root{position:relative;z-index:1}.app-shell{width:1200px;margin:36px auto 56px;animation:rise-in .36s ease-out}.hero{padding:30px 34px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(135deg,#fffef8,#fcf8ee);box-shadow:var(--shadow)}.hero h1{margin:2px 0 8px;font-size:48px;letter-spacing:.02em;font-family:Iowan Old Style,Palatino Linotype,serif}.eyebrow{margin:0;font-size:12px;letter-spacing:.19em;text-transform:uppercase;color:var(--accent-strong);font-weight:700}.hero-copy{margin:0;color:var(--ink-soft);max-width:720px;line-height:1.6}.topbar{display:flex;justify-content:space-between;align-items:center;margin:18px 0}.step-chip{margin:0;padding:9px 14px;border:1px solid var(--line);border-radius:999px;background:var(--bg-soft);font-size:13px;font-weight:600}.panel{border:1px solid var(--line);border-radius:20px;background:var(--bg-soft);padding:22px;box-shadow:var(--shadow)}.nested-panel{margin-top:20px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-header h2{margin:0;font-family:Iowan Old Style,Palatino Linotype,serif}.status-pill{padding:5px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.status-pill.ok{color:var(--accent-strong);background:var(--accent-soft)}.status-pill.error{color:var(--danger);background:var(--danger-soft)}.action-row{display:flex;align-items:center;gap:10px}.download-bar{margin-top:18px;display:flex;gap:10px}.btn{border:1px solid transparent;border-radius:12px;padding:10px 16px;font-size:13px;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.btn:hover:enabled{transform:translateY(-1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{color:#fff;background:var(--accent);box-shadow:0 10px 22px -14px #0f766ecc}.btn-primary:hover:enabled{background:var(--accent-strong)}.btn-secondary{color:var(--ink);border-color:var(--line);background:#f2eee5}.btn-ghost{color:var(--ink-soft);border-color:var(--line);background:#f8f4eb}.btn-danger{color:#fff;background:var(--danger)}.btn-danger:hover:enabled{background:#a43426}.template-row{margin:16px 0 20px;color:var(--ink-soft)}.template-link{margin-right:10px;color:var(--accent-strong);text-decoration-thickness:1px;text-underline-offset:2px}.csv-builder{border:1px solid var(--line);border-radius:16px;background:#fdf9f1;padding:16px;margin-bottom:16px}.section-title{margin:0}.section-copy{margin:8px 0 14px;color:var(--ink-soft)}.builder-options{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}.builder-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft)}.builder-input,.builder-select,.csv-textarea,.file-input{border:1px solid #cfc5b6;border-radius:10px;background:#fff;color:var(--ink);font-size:14px}.builder-input,.builder-select{height:38px;padding:0 10px}.builder-input.compact{width:90px}.builder-input{width:220px}.builder-select{min-width:150px}.field-grid{margin-bottom:12px}.field-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.design-editor,.template-apply-bar,.access-pattern-editor{border:1px solid var(--line);border-radius:14px;background:#fffcf7;padding:16px;margin-bottom:16px}.template-apply-bar{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.section-heading-row{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}.empty-design{border:1px dashed #cfc5b6;border-radius:12px;background:#f9f4ea;padding:16px}.empty-design p{margin-top:0}.table-design-list{display:grid;gap:14px}.table-design-card{border:1px solid #d7cec0;border-radius:12px;background:#fffaf2;padding:14px}.table-design-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}.table-field-grid{display:flex;flex-wrap:wrap;gap:10px}.table-field-grid label,.column-edit-row label,.fk-fields label{display:grid;gap:5px;font-size:12px;font-weight:700;color:var(--ink-soft)}.column-list-heading{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.column-list-heading p{margin:0;font-weight:700}.column-edit-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-items:end;padding:12px 0;border-top:1px solid #eadfcd}.column-edit-row:first-of-type{border-top:0}.column-flags{display:flex;gap:10px;align-items:center;min-height:38px}.column-flags label{display:inline-flex;gap:5px;align-items:center;font-size:13px;font-weight:700;color:var(--ink)}.fk-fields{display:contents}.column-description{grid-column:span 2}.advanced-csv-editor{border:1px solid var(--line);border-radius:12px;background:#f8f2e8;padding:12px}.advanced-csv-editor>summary{cursor:pointer;font-weight:700;color:var(--ink)}.compact-actions{margin:0}.access-pattern-list{display:grid;gap:12px}.access-pattern-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-items:end;border:1px solid #d7cec0;border-radius:12px;background:#fffaf2;padding:12px}.access-pattern-card label{display:grid;gap:5px;font-size:12px;font-weight:700;color:var(--ink-soft)}.wide-field{grid-column:span 2}@media(max-width:720px){.section-heading-row,.table-design-header,.template-apply-bar{display:grid}.column-description,.wide-field{grid-column:auto}}.required-badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:700;color:#0c5e58;background:#d9f2ef}.csv-card{border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:12px;background:#fffcf7}.csv-tabs{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.csv-tab{border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:12px;font-weight:700;letter-spacing:.02em;color:var(--ink-soft);background:#f7f2e9;cursor:pointer}.csv-tab.active{color:#fff;background:var(--accent);border-color:var(--accent)}.csv-card-title{margin:0 0 8px;font-weight:700}.file-input{width:100%;padding:8px;margin-bottom:8px}.csv-hint{margin-bottom:10px;padding:8px 10px;border:1px dashed #ccbfae;border-radius:10px;background:#f9f4ea}.csv-help{margin:12px 0;padding:12px;border:1px solid #c8d8ce;border-radius:10px;background:#f3f8f2}.csv-help p{margin:0;color:var(--ink);line-height:1.6}.csv-help ul{margin:8px 0 0;padding-left:20px;color:var(--ink-soft);line-height:1.55}.csv-hint summary{cursor:pointer;font-weight:700;color:var(--ink-soft)}.csv-hint-text{margin:8px 0 6px;font-size:13px;color:var(--ink-soft)}.csv-hint-code{display:block;padding:8px;border-radius:8px;background:#fff;border:1px solid #dbd1c3;font-family:Consolas,Courier New,monospace;font-size:12px;white-space:pre-wrap;word-break:break-all}.csv-textarea{width:100%;padding:10px;line-height:1.5;font-family:Consolas,Courier New,monospace}.sheet-wrapper{margin-top:10px}.sheet-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:8px}.sheet-meta{margin:0;font-size:12px;color:var(--ink-soft)}.sheet-alert{margin:0 0 8px;padding:8px 10px;border:1px solid #e8c98f;border-radius:10px;background:#fff3dd;font-size:12px;color:#7a5311}.sheet-scroll{overflow-x:auto;border:1px solid #d9d0c4;border-radius:10px;background:#fff}.sheet-table{width:100%;border-collapse:collapse;min-width:920px}.sheet-table th,.sheet-table td{border-right:1px solid #ece2d5;border-bottom:1px solid #ece2d5;padding:6px;vertical-align:top}.sheet-table th{position:sticky;top:0;z-index:1;background:#f8f3ea}.sheet-header-input,.sheet-cell-input{width:100%;border:1px solid #d9cfbf;border-radius:8px;padding:7px 8px;font-size:12px;background:#fff}.sheet-header-input{font-weight:700}.sheet-cell-input.cell-invalid{border-color:#d25e4f;background:#fff1ee}.sheet-action-col{min-width:90px;text-align:center}.raw-editor,.csv-preview{margin-top:10px;border:1px dashed #ccbfae;border-radius:10px;padding:8px 10px;background:#f9f4ea}.raw-editor summary,.csv-preview summary{cursor:pointer;font-weight:700;color:var(--ink-soft)}.validate-bar{margin-top:14px}.message-list{margin:14px 0;padding:12px 12px 12px 28px;border-radius:12px}.warning-list{background:var(--warn-soft);border:1px solid #efd5a3}.error-list{background:var(--danger-soft);border:1px solid #efc5bf}.table-column-preview{margin:16px 0}.table-column-preview h3{margin:0 0 8px;font-size:16px}.table-column-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.table-column-card{border:1px solid var(--line);border-radius:10px;background:#fffaf2;padding:12px}.table-column-card h4{margin:0 0 10px;font-size:15px}.table-column-card h4 span{display:block;margin-top:2px;font-size:12px;font-weight:600;color:var(--ink-soft)}.table-column-card ul{margin:0;padding:0;list-style:none}.table-column-card li{display:grid;gap:2px;padding:8px 0;border-top:1px solid #eadfcd}.table-column-card li:first-child{border-top:0;padding-top:0}.table-column-card li span,.table-column-card li small{color:var(--ink-soft)}.result-section{margin-top:18px}.result-card{border:1px solid var(--line);border-radius:14px;background:#fffaf2;padding:14px;margin-top:12px}.result-card h3{margin-top:0}.explain-box{margin:8px 0 12px;padding:10px 12px;border:1px solid #d7cec0;border-radius:10px;background:#f8f2e8}.explain-box p{margin:0;font-size:13px;line-height:1.55;color:var(--ink-soft)}.explain-title{margin-bottom:4px!important;font-weight:700;color:var(--ink)}.code-block{margin:0;padding:12px;border-radius:10px;border:1px solid #d7cec0;background:#f7f2e8;line-height:1.45;overflow-x:auto;font-family:Consolas,Courier New,monospace;font-size:13px}.notice-text{margin:0 0 12px;color:var(--ink-soft)}.error-text{color:#8d2f24;font-weight:700}.guide-text{margin:0 0 12px;color:var(--ink-soft);font-size:13px;line-height:1.6}@keyframes rise-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
