:root{--paper: #F7F4EF;--paper-subtle: #EDE9E3;--paper-card: #FFFFFF;--paper-inset: #F0EDE7;--ink: #1A1917;--ink-mid: #6B6560;--ink-light: #706A64;--ink-faint: #C8C2BB;--rule: #D8D2CB;--rule-light: #E6E1DA;--accent: #1A1917;--mode-mark: #5A6E8C;--persona-mark: #7A5C3A;--subject-mark: #3D6B4F;--font-body: "DM Sans", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", "Courier New", monospace;--font-display: "Comic Neue", "Comic Sans MS", cursive;--radius-card: 3px;--radius-input: 4px;--radius-btn: 3px;--shadow-card: 0 1px 3px rgba(0,0,0,.07), 0 4px 14px rgba(0,0,0,.05);--shadow-card-lift: 0 2px 8px rgba(0,0,0,.1), 0 8px 24px rgba(0,0,0,.07)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}:focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:2px}body{font-family:var(--font-body);background:var(--paper-subtle);color:var(--ink);min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center}.session-progress{width:100%;max-width:640px;padding:14px 20px 0;display:flex;align-items:stretch;gap:4px}.session-progress__stage{display:flex;flex-direction:column;gap:5px;flex:1}.session-progress__stage--map{flex:2}.session-progress__bar{height:3px;border-radius:2px;background:var(--rule);transition:background .2s}.session-progress__stage--done .session-progress__bar{background:var(--ink-mid)}.session-progress__stage--current .session-progress__bar{background:var(--ink)}.session-progress__label{font-family:var(--font-mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);line-height:1}.session-progress__stage--map .session-progress__label{font-size:.65rem;letter-spacing:.1em}.session-progress__stage--done .session-progress__label{color:var(--ink-mid)}.session-progress__stage--current .session-progress__label{color:var(--ink);font-weight:600}.session-progress__sublabel{font-weight:400;color:var(--ink-faint);font-size:.55rem}.session-progress__stage--current .session-progress__sublabel{color:var(--ink-mid)}.scene{width:100%;max-width:640px;padding:32px 20px 80px;display:flex;flex-direction:column;gap:0}.step{display:flex;flex-direction:column;gap:24px;animation:fadeUp .3s ease-out}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.step__header{display:flex;flex-direction:column;gap:6px}.difficulty-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:4px}.difficulty-bar__label{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-light)}.difficulty-select{font-family:var(--font-mono);font-size:.75rem;color:var(--ink);background:var(--paper-inset);border:1px solid var(--rule);border-radius:4px;padding:3px 6px;cursor:pointer}.difficulty-select option{font-size:1rem}.difficulty-select:hover{border-color:var(--ink-mid)}.step__eyebrow{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-light);text-transform:uppercase;letter-spacing:.1em}.step__heading{font-family:var(--font-display);font-size:1.5rem;font-weight:600;line-height:1.2;color:var(--ink)}.step__subhead{font-size:.9rem;color:var(--ink-mid);line-height:1.5;max-width:480px}.step__actions{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.step__actions__spacer{flex:0 0 auto;min-width:0}@media (max-width: 380px){.step__actions{flex-direction:column;align-items:stretch}.step__actions__spacer{display:none}}.btn{font-family:var(--font-body);font-size:.95rem;font-weight:500;padding:12px 24px;border-radius:var(--radius-btn);border:1.5px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;line-height:1;display:inline-flex;align-items:center;gap:6px}.btn--primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}.btn--primary:hover:not(:disabled){background:#2e2b27;box-shadow:0 2px 8px #00000026}.btn--primary:disabled{opacity:.35;cursor:not-allowed}.btn--ghost{background:transparent;color:var(--ink-mid);border-color:var(--rule)}.btn--ghost:hover:not(:disabled){border-color:var(--ink-mid);color:var(--ink)}.btn--ghost:disabled{opacity:.35;cursor:not-allowed}.btn--sm{font-size:.82rem;padding:8px 16px}.btn--full{width:100%;justify-content:center}.btn--danger{background:transparent;color:#b91c1c;border-color:#fecaca}.btn--danger:hover:not(:disabled){background:#fef2f2;border-color:#b91c1c}.confirm-discard{background:#fef2f2;border:1px solid #FECACA;border-radius:var(--radius-card);padding:16px;display:flex;flex-direction:column;gap:14px}.confirm-discard__message{font-size:.875rem;color:#7f1d1d;line-height:1.55}.confirm-discard__actions{display:flex;gap:10px}.wordmark{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--ink)}.step--landing{position:relative}.landing__icon{position:absolute;top:6px;left:6px;width:clamp(60px,22vmin,110px);height:auto;pointer-events:none;-webkit-user-select:none;user-select:none}.landing__header{display:flex;flex-direction:column;gap:8px;padding-bottom:28px;padding-left:calc(clamp(60px,22vmin,110px) + 22px);border-bottom:1px solid var(--rule-light);min-height:130px;justify-content:center}.landing__tagline{font-size:.9rem;color:var(--ink-mid);line-height:1.5}.landing__body{display:flex;flex-direction:column;gap:20px}.field-group{display:flex;flex-direction:column;gap:10px}.field-group__label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-light)}.difficulty-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media (max-width: 400px){.difficulty-grid{grid-template-columns:repeat(2,1fr)}}.difficulty-btn{display:flex;flex-direction:column;gap:3px;padding:20px 12px;background:var(--paper-card);border:1.5px solid var(--rule);border-radius:var(--radius-card);cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s}.difficulty-btn:hover{border-color:var(--ink-mid);box-shadow:0 0 0 1px var(--ink-mid)}.difficulty-btn__label{font-size:.85rem;font-weight:600;color:var(--ink);line-height:1}.difficulty-btn__desc{font-size:.72rem;color:var(--ink-light);line-height:1.3}.shapes-primer{background:var(--paper-inset);border:1px solid var(--rule-light);border-radius:var(--radius-card);padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px}.about__heading,.shapes-primer__heading{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--ink-mid)}.about__desc,.shapes-primer__desc{font-size:.78rem;color:var(--ink-light);line-height:1.5;margin-top:-4px}.shapes-grid{display:grid;grid-template-columns:1fr;gap:10px 16px}.shape-entry{display:flex;flex-direction:row;align-items:flex-start;gap:10px}.shape-entry__img{width:46px;height:46px;object-fit:contain;flex-shrink:0;opacity:.7;filter:sepia(1) saturate(6) hue-rotate(188deg)}.shape-entry__text{display:flex;flex-direction:column;gap:2px}.shape-entry__label{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--ink-mid)}.shape-entry__desc{font-size:.8rem;color:var(--ink-light);line-height:1.45}.explainer{border-top:1px solid var(--rule-light);padding-top:12px}.explainer__toggle{font-size:.82rem;color:var(--ink-mid);cursor:pointer;list-style:none;display:flex;align-items:center;gap:6px}.explainer__toggle::-webkit-details-marker{display:none}.explainer__toggle:before{content:"▸";font-size:.65rem;color:var(--ink-faint);transition:transform .2s}details[open] .explainer__toggle:before{transform:rotate(90deg)}.explainer__body{display:flex;flex-direction:column;gap:10px;padding-top:12px}.explainer__body p{font-size:.85rem;color:var(--ink-mid);line-height:1.6}.notecard{background:var(--paper-card);border:1px solid var(--rule);border-radius:var(--radius-card);padding:14px 16px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;animation:cardIn .22s ease-out}@keyframes cardIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.notecard:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.notecard--mode:before{background:var(--mode-mark)}.notecard--persona:before{background:var(--persona-mark)}.notecard--subject:before{background:var(--subject-mark)}.notecard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.notecard__label{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;display:block;margin-bottom:0}.notecard--mode .notecard__label{color:var(--mode-mark)}.notecard--persona .notecard__label{color:var(--persona-mark)}.notecard--subject .notecard__label{color:var(--subject-mark)}.notecard__number{display:inline-block;margin-left:5px;font-size:.6rem;font-weight:400;opacity:.6;letter-spacing:0}.notecard__controls{display:flex;align-items:center;gap:8px}.notecard__redraw,.notecard__expand,.notecard__customize,.notecard__edit-confirm,.notecard__edit-cancel{flex-shrink:0;border-radius:50%;border:1px solid var(--rule);background:transparent;color:var(--ink-light);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:border-color .15s,color .15s,background .15s;width:28px;height:28px;padding:0;font-size:.7rem}.notecard__redraw{font-size:.95rem}.notecard__customize{font-size:.85rem}.notecard__redraw:hover,.notecard__expand:hover,.notecard__customize:hover{border-color:var(--ink-mid);color:var(--ink);background:var(--paper-inset)}.notecard__edit-confirm{border-color:var(--subject-mark);color:var(--subject-mark)}.notecard__edit-confirm:hover{background:var(--subject-mark);color:var(--paper-card)}.notecard__edit-cancel:hover{border-color:var(--ink-mid);color:var(--ink);background:var(--paper-inset)}.notecard__edit-input{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--ink);line-height:1.25;width:100%;background:transparent;border:none;border-bottom:1.5px solid var(--subject-mark);border-radius:0;padding:2px 0 4px;outline:none}.notecard__edit-input::placeholder{color:var(--ink-faint);font-weight:400}.notecard__title{font-size:1rem;font-weight:600;color:var(--ink);line-height:1.25;margin-bottom:0}.notecard--expanded .notecard__title{margin-bottom:8px}.notecard--subject .notecard__title{font-style:italic;text-transform:lowercase}.notecard__body{font-size:.85rem;color:var(--ink-mid);line-height:1.55;margin-bottom:10px}.notecard__body--preview{font-size:.78rem;color:var(--ink-light);line-height:1.4;margin-bottom:0;margin-top:2px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.notecard__detail{list-style:none;display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--rule-light);padding-top:10px;margin-top:4px}.notecard__detail li{font-size:.8rem;color:var(--ink-mid);line-height:1.45;padding-left:14px;position:relative}.notecard__detail li:before{content:"—";position:absolute;left:0;color:var(--ink-faint)}.card-stack-group{display:flex;flex-direction:column;gap:16px}@media (min-width: 560px){.card-stack-group{flex-direction:row;justify-content:center}}.card-stack{position:relative;width:100%;max-width:200px;height:140px}@media (max-width: 559px){.card-stack{max-width:100%;height:90px}}.card-stack__shadow{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--paper-card);border:1px solid var(--rule);border-radius:var(--radius-card)}.card-stack__shadow--2{transform:translate(5px,5px);opacity:.5}.card-stack__shadow--1{transform:translate(2.5px,2.5px);opacity:.7}.card-stack__face{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--paper-inset);border:1px solid var(--rule);border-radius:var(--radius-card);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-card)}.card-stack__label{font-family:var(--font-mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-faint)}.cards-revealed{display:flex;flex-direction:column;gap:12px;animation:fadeUp .35s ease-out}.solo-note{background:var(--paper-inset);border:1px solid var(--rule-light);border-radius:var(--radius-card);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.solo-note__label{font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-light)}.solo-note p{font-size:.82rem;color:var(--ink-mid);font-style:italic}.focus-panel{background:var(--paper-card);border:1px solid var(--rule);border-radius:var(--radius-card);padding:18px 20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:12px}.focus-panel__label{font-size:.95rem;font-weight:600;color:var(--ink)}.focus-panel__instruction{font-size:.83rem;color:var(--ink-mid);line-height:1.5;margin-top:-6px}.focus-sentence{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;font-size:.92rem;color:var(--ink-mid)}.focus-sentence__stem{white-space:nowrap}.focus-sentence__input{flex:1;min-width:160px;font-family:var(--font-body);font-size:.92rem;padding:6px 10px;border:1.5px solid var(--rule);border-radius:var(--radius-input);background:var(--paper);color:var(--ink);outline:none;transition:border-color .15s}.focus-sentence__input:focus{border-color:var(--ink)}.focus-sentence__input::placeholder{color:var(--ink-faint)}.focus-sentence__tail{font-size:.92rem;color:var(--ink-light);width:100%;margin-top:-4px}.focus-sentence__tail em{font-style:normal}.focus-warning{font-size:.82rem;color:var(--ink-mid);font-style:italic;line-height:1.5;padding:8px 12px;background:var(--paper-inset);border-left:2px solid var(--ink-faint);border-radius:0 var(--radius-input) var(--radius-input) 0}.focus-sentence__input--warn{border-color:var(--ink-mid)}.focus-panel__hint-toggle{font-family:var(--font-body);font-size:.8rem;color:var(--ink-light);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:2px;text-align:left;padding:0}.focus-panel__hint-toggle:hover{color:var(--ink-mid)}.hint-list{list-style:none;display:flex;flex-direction:column;gap:4px;padding:10px;background:var(--paper-inset);border-radius:var(--radius-input)}.hint-list__item{font-family:var(--font-body);font-size:.82rem;text-transform:lowercase;color:var(--ink-mid);background:none;border:none;cursor:pointer;text-align:left;padding:4px 6px;border-radius:2px;line-height:1.4;width:100%;transition:background .1s,color .1s}.hint-list__item:hover{background:var(--rule-light);color:var(--ink)}.practice-focus{background:var(--paper-card);border:1px solid var(--rule);border-left:3px solid var(--ink);border-radius:var(--radius-card);padding:14px 18px;box-shadow:var(--shadow-card)}.practice-focus__sentence{font-size:1.05rem;line-height:1.5;color:var(--ink-mid)}.practice-focus__stem{color:var(--ink-light)}.practice-focus__focus{color:var(--ink);font-weight:600}.practice-focus__tail{color:var(--ink-light);font-size:.9rem}.practice-focus__tail em{font-style:normal;color:var(--ink-mid)}.session-focus-anchor{font-family:var(--font-mono);font-size:.65rem;color:var(--ink-light);letter-spacing:.02em;line-height:1.4}.session-focus-anchor strong{color:var(--ink-mid);font-weight:500}.session-focus-anchor em{font-style:normal;color:var(--ink-mid)}.practice-madlib{background:var(--paper-card);border:1px solid var(--rule);border-left:3px solid var(--ink);border-radius:var(--radius-card);padding:16px 18px 14px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:8px}.practice-madlib__sentence{font-size:1.05rem;line-height:1.65;color:var(--ink-mid)}.practice-madlib__stem{color:var(--ink-light);font-style:italic}.practice-madlib__focus{color:var(--ink);font-weight:700;font-style:normal}.practice-madlib__join{color:var(--ink-light)}.practice-madlib__token{cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;text-decoration-thickness:1.5px;font-weight:500;transition:opacity .12s}.practice-madlib__token:hover{opacity:.7}.practice-madlib__token--mode{color:var(--mode-mark);text-decoration-color:var(--mode-mark)}.practice-madlib__token--persona{color:var(--persona-mark);text-decoration-color:var(--persona-mark)}.practice-madlib__token--subject{color:var(--subject-mark);text-decoration-color:var(--subject-mark)}.practice-madlib__hint{font-family:var(--font-mono);font-size:.58rem;color:var(--ink-faint);letter-spacing:.04em}.card-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a191773;z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:0 0 env(safe-area-inset-bottom,0);animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.card-detail{background:var(--paper-card);border:1px solid var(--rule);border-bottom:none;border-radius:var(--radius-card) var(--radius-card) 0 0;width:100%;max-width:640px;padding:20px 22px 32px;box-shadow:0 -4px 24px #0000001f;animation:slideUp .22s ease-out;overflow-y:auto;max-height:75vh}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.card-detail__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.card-detail__label{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em}.card-detail__label--mode{color:var(--mode-mark)}.card-detail__label--persona{color:var(--persona-mark)}.card-detail__label--subject{color:var(--subject-mark)}.card-detail__close{background:none;border:none;cursor:pointer;font-size:.85rem;color:var(--ink-light);padding:4px 8px;line-height:1;border-radius:var(--radius-btn);transition:color .12s}.card-detail__close:hover{color:var(--ink)}.card-detail__title{font-size:1.2rem;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:10px}.card-detail__body{font-size:.875rem;color:var(--ink-mid);line-height:1.55;margin-bottom:12px}.card-detail__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.card-detail__list li{font-size:.8rem;color:var(--ink-mid);line-height:1.45;padding-left:14px;position:relative}.card-detail__list li:before{content:"—";position:absolute;left:0;color:var(--ink-faint)}.wake-lock-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;width:fit-content}.wake-lock-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--ink)}.wake-lock-toggle span{font-family:var(--font-mono);font-size:.65rem;color:var(--ink-light);text-transform:uppercase;letter-spacing:.08em;-webkit-user-select:none;user-select:none}.image-capture__retake{display:inline-flex;align-items:center;gap:4px;margin-top:10px;padding:6px 12px;background:var(--paper-inset);border:1px solid var(--rule);border-radius:var(--radius-btn);font-family:var(--font-body);font-size:.8rem;color:var(--ink-mid);cursor:pointer;transition:border-color .15s,color .15s}.image-capture__retake:hover{border-color:var(--ink-mid);color:var(--ink)}.practice-cards{display:flex;flex-direction:column;gap:8px}@keyframes timerFlash{0%{opacity:0}12%{opacity:.38}to{opacity:0}}.timer-flash{position:fixed;top:0;right:0;bottom:0;left:0;background:#fffbea;pointer-events:none;animation:timerFlash 2.2s ease-out forwards;z-index:200}.timer{display:flex;flex-direction:column;gap:8px}.timer__label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-light)}.timer__options{display:flex;gap:8px;flex-wrap:wrap}.timer--running{background:var(--paper-card);border:1px solid var(--rule);border-radius:var(--radius-card);padding:14px 18px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-card)}.timer--expired{border-color:var(--ink-mid);background:var(--paper-inset)}.timer--paused .timer__display{opacity:.45}.timer__display{font-family:var(--font-mono);font-size:2rem;font-weight:400;color:var(--ink);letter-spacing:.04em;line-height:1}.timer--expired .timer__display{color:var(--ink-mid)}.timer__sublabel{font-size:.75rem;color:var(--ink-light);margin-bottom:4px}.timer__controls{display:flex;gap:8px}.workspace{display:flex;flex-direction:column;gap:6px}.workspace__label{font-size:.85rem;font-weight:500;color:var(--ink)}.workspace__optional{font-weight:400;color:var(--ink-light)}.workspace__input{font-family:var(--font-body);font-size:.9rem;line-height:1.55;padding:12px 14px;border:1.5px solid var(--rule);border-radius:var(--radius-input);background:var(--paper-card);color:var(--ink);resize:vertical;outline:none;transition:border-color .15s}.workspace__input:focus{border-color:var(--ink)}.workspace__input::placeholder{color:var(--ink-faint)}.tip{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--paper-inset);border-radius:var(--radius-card);border:1px solid var(--rule-light)}.tip__text{font-size:.82rem;color:var(--ink-mid);line-height:1.5;font-style:italic;flex:1}.tip__next{font-family:var(--font-body);font-size:.75rem;color:var(--ink-light);background:none;border:none;cursor:pointer;white-space:nowrap;padding:0;flex-shrink:0}.tip__next:hover{color:var(--ink-mid)}.conclude__actions{display:flex;flex-direction:column;gap:10px;max-width:320px}.image-capture{display:flex;flex-direction:column;gap:16px}.image-capture__instruction{font-size:.88rem;color:var(--ink-mid)}.image-capture__actions{display:flex;gap:10px;flex-wrap:wrap}.image-capture--preview{gap:12px}.image-capture__preview{width:100%;max-height:360px;object-fit:contain;border:1px solid var(--rule);border-radius:var(--radius-card);background:var(--paper-inset);display:block}.reflection-list{display:flex;flex-direction:column;gap:16px}.reflection-item{display:flex;flex-direction:column;gap:6px}.reflection-item__prompt{font-size:.88rem;font-weight:500;color:var(--ink);line-height:1.4;font-style:italic}.reflection-item__input{font-family:var(--font-body);font-size:.88rem;line-height:1.5;padding:10px 12px;border:1.5px solid var(--rule);border-radius:var(--radius-input);background:var(--paper-card);color:var(--ink);resize:vertical;outline:none;transition:border-color .15s}.reflection-item__input:focus{border-color:var(--ink)}.reflection-item__input::placeholder{color:var(--ink-faint)}.text-input{font-family:var(--font-body);font-size:.9rem;padding:10px 12px;border:1.5px solid var(--rule);border-radius:var(--radius-input);background:var(--paper-card);color:var(--ink);outline:none;width:100%;transition:border-color .15s}.text-input:focus{border-color:var(--ink)}.text-input::placeholder{color:var(--ink-faint)}.field-group__optional{font-family:var(--font-body);font-size:.72rem;color:var(--ink-light);font-weight:400;text-transform:none;letter-spacing:0}.pdf-preview{width:100%;aspect-ratio:16 / 9;display:flex;background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-card);box-shadow:var(--shadow-card-lift);overflow:hidden}.pdf-preview__brief{position:relative;width:28%;flex-shrink:0;border-right:1px solid var(--rule);background:var(--paper-inset);padding:13% 7% 6%;display:flex;flex-direction:column;gap:4px;overflow:hidden}.pdf-preview__icon{position:absolute;top:5%;left:5%;width:30%;height:auto;filter:sepia(1) saturate(6) hue-rotate(188deg);pointer-events:none}.pdf-preview__wordmark{font-family:var(--font-display);font-size:clamp(.45rem,1.1vw,.65rem);font-weight:600;color:var(--ink);line-height:1}.pdf-preview__date,.pdf-preview__name{font-family:var(--font-mono);font-size:clamp(.38rem,.85vw,.55rem);color:var(--ink-mid);line-height:1}.pdf-preview__divider{height:1px;background:var(--rule);margin:3px 0;flex-shrink:0}.pdf-preview__field{display:flex;flex-direction:column;gap:1px}.pdf-preview__field-label{font-family:var(--font-mono);font-size:clamp(.3rem,.7vw,.48rem);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-light);line-height:1}.pdf-preview__field-value{font-size:clamp(.38rem,.9vw,.58rem);font-weight:600;color:var(--ink);line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.pdf-preview__field-value--focus{font-size:clamp(.4rem,.95vw,.62rem)}.pdf-preview__empty{color:var(--ink-faint);font-weight:400}.pdf-preview__image-area{flex:1;display:flex;align-items:center;justify-content:center;background:var(--paper);overflow:hidden;padding:2%}.pdf-preview__image{max-width:100%;max-height:100%;object-fit:contain;display:block}.pdf-preview__image-placeholder{font-family:var(--font-mono);font-size:clamp(.5rem,1.2vw,.7rem);color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em}.download-filename{font-size:.8rem;color:var(--ink-mid);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.download-filename__label{color:var(--ink-light)}.download-filename__value{font-family:var(--font-mono);font-size:.75rem;color:var(--ink);word-break:break-all}.error-message{font-size:.85rem;color:#8b3a3a;padding:10px 14px;background:#fdf0ee;border:1px solid #E8C4BF;border-radius:var(--radius-card)}
