:root{--paper:#f7efe3;--paper-strong:#fffaf0;--ink:#2c2923;--muted:#746b5d;--line:#d8c6ac;--sage:#5c806d;--sage-dark:#315f4d;--clay:#b8604f;--butter:#f2c65a;--mist:#e6efea;--shadow:#35271829}*{box-sizing:border-box}html{background:var(--paper);color:var(--ink);font-size:16px}body{letter-spacing:0;background:linear-gradient(90deg, #ffffff59 1px, transparent 1px), linear-gradient(#ffffff47 1px, transparent 1px), radial-gradient(circle at 18% 8%, #f2c65a3d, transparent 30%), radial-gradient(circle at 95% 24%, #5c806d2e, transparent 28%), var(--paper);background-size:26px 26px,26px 26px,auto,auto,auto;min-height:100vh;margin:0;font-family:Trebuchet MS,Gill Sans,Segoe UI,sans-serif;overflow-x:hidden}button,input{font:inherit}button{border:0}.app-shell{width:min(100%,430px);min-height:100vh;margin:0 auto;padding:18px 16px 28px}.top-strip{justify-content:space-between;align-items:center;gap:12px;padding:4px 0 14px;display:flex}.brand-mark{border:2px solid var(--ink);background:var(--butter);width:38px;height:38px;box-shadow:3px 3px 0 var(--ink);border-radius:6px;justify-content:center;align-items:center;font-family:Georgia,Times New Roman,serif;font-weight:700;display:inline-flex}.top-note{color:var(--muted);text-align:right;font-size:.78rem;line-height:1.3}.hero{padding:12px 0 18px}.eyebrow{color:var(--clay);margin:0 0 8px;font-size:.78rem;font-weight:700}h1{letter-spacing:0;margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(2.2rem,13vw,3.35rem);line-height:.96}.hero-copy{color:var(--muted);max-width:31ch;margin:14px 0 0;font-size:.98rem;line-height:1.65}.upload-panel,.result-sheet,.error-box{border:2px solid var(--ink);box-shadow:5px 5px 0 var(--shadow);background:#fffaf0db;border-radius:8px}.upload-panel{padding:14px}.file-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.drop-zone{border:2px dashed var(--line);background:linear-gradient(135deg, #e6efeabf, #fffaf0e6), var(--paper-strong);cursor:pointer;border-radius:6px;place-items:center;min-height:244px;display:grid;overflow:hidden}.drop-zone:focus-within,.drop-zone:hover{border-color:var(--sage-dark)}.empty-state{text-align:center;width:100%;padding:22px 16px}.empty-frame{aspect-ratio:4/5;border:2px solid var(--ink);background:linear-gradient(145deg, #fff9, #e6efeae6), var(--mist);border-radius:6px;width:min(62vw,220px);margin:0 auto 18px;position:relative;transform:rotate(-2deg)}.empty-frame:before{content:"";background:#f2c65ab8;border:1px solid #2c29233d;width:82px;height:24px;position:absolute;top:-14px;left:50%;transform:translate(-50%)rotate(4deg)}.empty-frame:after{content:"+";color:var(--sage-dark);place-items:center;font-size:4rem;font-weight:700;display:grid;position:absolute;inset:0}.upload-title{color:var(--ink);margin-bottom:6px;font-weight:800;display:block}.upload-hint{color:var(--muted);font-size:.88rem;line-height:1.45}.preview-image{object-fit:cover;width:100%;height:100%;max-height:356px;display:block}.action-row{grid-template-columns:1fr auto;gap:10px;margin-top:12px;display:grid}.action-row.single-action{grid-template-columns:1fr}.primary-button,.secondary-button{cursor:pointer;border-radius:6px;min-height:48px;font-weight:800}.primary-button{color:#fffaf0;background:var(--sage-dark);box-shadow:inset 0 -2px #00000038}.primary-button:disabled{color:#f6efe2;cursor:not-allowed;background:#9aa99f}.secondary-button{color:var(--ink);background:var(--butter);border:2px solid var(--ink);padding:0 14px}.error-box{color:#7c2d22;background:#fff1eb;margin-top:12px;padding:12px;font-size:.92rem;line-height:1.45}.loading-note{color:var(--muted);align-items:center;gap:10px;margin:14px 2px 0;font-size:.9rem;display:flex}.loading-dot{background:var(--clay);border-radius:50%;width:10px;height:10px;animation:1.1s ease-in-out infinite pulse}.generation-transition{z-index:30;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#f7efe3f0;background-image:linear-gradient(90deg,#ffffff47 1px,#0000 1px),linear-gradient(#ffffff3d 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:28px 28px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.transition-card{border:2px solid var(--ink);background:var(--paper-strong);text-align:center;border-radius:8px;width:min(86vw,340px);padding:20px 18px 18px;box-shadow:8px 8px #315f4d33}.transition-photo{aspect-ratio:4/5;border:2px solid var(--ink);background:var(--mist);border-radius:7px;width:min(60vw,230px);margin:0 auto 18px;position:relative;overflow:hidden;transform:rotate(-2deg)}.transition-photo img,.transition-photo>span:first-child{object-fit:cover;width:100%;height:100%;display:block}.transition-frame{pointer-events:none;border:2px solid #fffaf0d1;border-radius:5px;animation:1.4s ease-in-out infinite frame-breathe;position:absolute;inset:12px}.transition-scan{pointer-events:none;background:linear-gradient(90deg,#0000,#f2c65af5,#0000);height:6px;animation:1.45s ease-in-out infinite scan-card;position:absolute;top:0;left:0;right:0;box-shadow:0 0 18px #f2c65a8c}.transition-title{color:var(--ink);letter-spacing:0;margin:0;font-family:Georgia,Times New Roman,serif;font-size:1.42rem;line-height:1.15}.transition-copy{color:var(--muted);margin:8px 0 0;font-size:.92rem}.result-sheet{margin-top:18px;padding:16px}.result-header{border-bottom:2px solid var(--line);justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:12px;display:flex}.result-header h2{letter-spacing:0;margin:0;font-family:Georgia,Times New Roman,serif;font-size:1.65rem}.result-stamp{border:2px solid var(--clay);color:var(--clay);border-radius:6px;flex:none;padding:5px 7px;font-size:.72rem;font-weight:900;transform:rotate(4deg)}.section-block{border-bottom:1px solid var(--line);padding:15px 0}.section-block:last-child{border-bottom:0;padding-bottom:0}.section-block h3{color:var(--sage-dark);margin:0 0 10px;font-size:1rem}.trait-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.trait{border:1px solid var(--line);background:#ffffff73;border-radius:6px;min-width:0;padding:9px}.trait span{color:var(--muted);margin-bottom:3px;font-size:.72rem;display:block}.trait strong{overflow-wrap:anywhere;font-size:.94rem;display:block}.note-list{margin:0;padding:0;list-style:none}.note-list li{color:var(--ink);margin:8px 0;padding-left:18px;line-height:1.45;position:relative}.note-list li:before{content:"";background:var(--butter);border:1px solid var(--ink);border-radius:50%;width:8px;height:8px;position:absolute;top:.62em;left:0}.tag-row{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.tag{border:1px solid var(--sage-dark);color:var(--sage-dark);background:var(--mist);border-radius:6px;padding:5px 8px;font-size:.8rem;font-weight:800}.warm-comment{margin:0 0 12px;font-family:Georgia,Times New Roman,serif;font-size:1.28rem;line-height:1.45}.caption{border-left:4px solid var(--clay);color:var(--muted);background:#b8604f14;margin:0;padding:10px;line-height:1.45}.disclaimer{color:var(--muted);margin:0;font-size:.78rem;line-height:1.55}@keyframes pulse{0%,to{opacity:.55;transform:scale(.86)}50%{opacity:1;transform:scale(1.14)}}@keyframes scan-card{0%{opacity:0;transform:translateY(-18px)}16%{opacity:1}to{opacity:.26;transform:translateY(260px)}}@keyframes frame-breathe{0%,to{opacity:.62;transform:scale(.98)}50%{opacity:1;transform:scale(1.02)}}@keyframes spin{to{transform:rotate(360deg)}}.card-generation-panel,.generated-card-panel{border:2px solid var(--ink);box-shadow:5px 5px 0 var(--shadow);background:#fffaf0e6;border-radius:8px;margin-top:16px;padding:14px}.card-generation-panel h2,.generated-card-header h2{margin:0;font-family:Georgia,Times New Roman,serif;font-size:1.45rem;line-height:1.1}.card-generation-panel p,.generated-card-header p{color:var(--muted);margin:8px 0 0;font-size:.92rem;line-height:1.55}.card-generation-panel .primary-button{width:100%;margin-top:12px}.generated-card-frame{border:2px solid var(--ink);background:#fffaf0;border-radius:8px;width:100%;min-height:620px;margin-top:12px}.card-page-shell{background:#fffaf0;width:min(100%,430px);height:100dvh;margin:0 auto}.card-page-frame{background:#fffaf0;border:0;width:100%;height:100%;display:block}.card-route-state{width:min(100%,430px);min-height:100dvh;color:var(--muted);text-align:center;align-content:center;place-items:center;gap:14px;margin:0 auto;padding:24px;display:grid}.card-route-state p{margin:0}.card-route-spinner{border:3px solid var(--line);border-top-color:var(--sage-dark);border-radius:50%;width:44px;height:44px;animation:.85s linear infinite spin}.secondary-link{border:2px solid var(--ink);min-height:44px;color:var(--ink);background:var(--butter);border-radius:6px;justify-content:center;align-items:center;padding:0 18px;font-weight:800;text-decoration:none;display:inline-flex}
