:root{--bg: #fff8e7;--card-bg: #ffffff;--card-shadow: rgba(0, 0, 0, .08);--text: #333333;--accent: #5d4e37;--accent-light: #8b7355;--accent-highlight: #a89070;--link: #2c3e50;--success: #27ae60;--error: #e74c3c;--warning: #f39c12;--border: #e0d8c8;--btn-gradient-from: #f5f0e6;--btn-gradient-to: #e8e0d0;--btn-border: #c4b8a8;--progress-bg: #e8e0d0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:Georgia,Times New Roman,serif;background-color:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:2rem 1rem}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 8px var(--card-shadow);padding:1.5rem;margin-bottom:1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(180deg,var(--btn-gradient-from) 0%,var(--btn-gradient-to) 100%);border:2px solid var(--btn-border);border-radius:4px;box-shadow:0 2px 4px #0000001a;padding:.75rem 1.5rem;font-family:inherit;font-size:1rem;color:var(--accent);cursor:pointer;transition:background .15s,box-shadow .15s}.btn:hover{background:linear-gradient(180deg,#fff8e7 0%,var(--btn-gradient-from) 100%)}.btn:active{box-shadow:inset 0 2px 4px #0000001a}.btn--primary{background:linear-gradient(180deg,var(--accent-light) 0%,var(--accent) 100%);border-color:var(--accent);color:#fff}.btn--primary:hover{background:linear-gradient(180deg,var(--accent-highlight) 0%,var(--accent-light) 100%)}.progress{background:var(--progress-bg);border-radius:4px;height:20px;overflow:hidden}.progress__fill{background:linear-gradient(90deg,var(--accent-light) 0%,var(--accent-highlight) 100%);border-radius:4px;height:100%;transition:width .3s ease}.input{padding:.5rem .75rem;border:2px solid var(--border);border-radius:4px;font-family:inherit;font-size:1rem;color:var(--text);background:var(--card-bg)}.input:focus{outline:none;border-color:var(--accent-light)}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:1.2rem;height:1.2rem;flex-shrink:0;margin-right:.5rem;vertical-align:middle;position:relative;top:-.05em}.drop-zone{border:3px dashed var(--border);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.drop-zone--active{border-color:var(--accent-light);background:#8b73550d}.upload-hint h4{color:var(--accent);margin-bottom:.5rem;font-size:.95rem}.upload-hint__list{list-style:none;padding:0}.upload-hint__list li{font-size:.85rem;color:var(--accent-light);padding:.2rem 0}.upload-hint__list li:before{content:"・"}.shooting-guide__title{color:var(--accent);margin-bottom:.75rem;font-size:.95rem}.shooting-guide__item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;padding:.35rem 0}.shooting-guide__item--good{color:#155724}.shooting-guide__item--bad{color:#721c24}.shooting-guide__icon{display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.shooting-guide__icon--good{background:#d4edda;color:var(--success);border:1px solid var(--success)}.shooting-guide__icon--bad{background:#f8d7da;color:var(--error);border:1px solid var(--error)}.drop-zone__hint{font-size:.8rem;color:var(--accent-light);opacity:.7;margin-top:.25rem}.steps{display:flex;justify-content:center;gap:1rem;margin:2rem 0;flex-wrap:wrap}.step{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--accent)}.step__number{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;font-size:.85rem;font-family:system-ui,sans-serif;line-height:1}.step__arrow{color:var(--btn-border);font-size:1.2rem}.message{padding:.75rem 1rem;border-radius:4px;margin-bottom:.5rem;font-size:.9rem}.message--warning{background:#fff3cd;border:1px solid var(--warning);color:#856404}.message--error{background:#f8d7da;border:1px solid var(--error);color:#721c24}.message--info{background:#d1ecf1;border:1px solid #17a2b8;color:#0c5460}.message--success{background:#d4edda;border:1px solid var(--success);color:#155724}.header{background:var(--card-bg);border-bottom:2px solid var(--border);box-shadow:0 2px 4px var(--card-shadow)}.header__inner{max-width:960px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between}.header__logo{font-family:Courier New,monospace;font-size:1.4rem;font-weight:700;color:var(--accent);text-decoration:none;letter-spacing:1px}.header__nav{display:flex;gap:.5rem}.header__link{display:inline-block;padding:.4rem .8rem;font-family:inherit;font-size:.9rem;color:var(--accent);text-decoration:none;border-radius:4px;transition:background .15s}.header__link:hover{background:var(--btn-gradient-from)}.header__link--active{background:var(--btn-gradient-to);font-weight:700}.footer{text-align:center;padding:1.5rem 1rem;border-top:1px solid var(--border);color:var(--accent-light);font-size:.85rem}.footer__inner{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.footer__link{color:var(--accent-light);text-decoration:none}.footer__link:hover{color:var(--accent);text-decoration:underline}.footer__sep{opacity:.4}.footer__copy{opacity:.8}.footer__build{opacity:.6;font-family:ui-monospace,SF Mono,Menlo,Cascadia Code,Consolas,Liberation Mono,monospace;font-size:.85em}.footer__sub{font-size:.75rem;margin-top:.25rem;opacity:.8}.about-page{margin:-2rem -1rem}.about-page h2{margin-bottom:1rem;color:var(--accent)}.about-page h3{color:var(--accent);margin-bottom:.5rem}.about-page p{margin-bottom:.5rem}.about-section{padding:3rem 1rem}.about-section:nth-child(2n){background:var(--card-bg)}.about-section:nth-child(odd){background:var(--bg)}.about-section__inner{max-width:960px;margin:0 auto}.about-section__title{text-align:center;color:var(--accent);margin-bottom:1.5rem}.not-found{margin-top:2rem;text-align:center}.not-found__actions{margin-top:1rem}.about-hero{padding:4rem 1rem 3rem}.about-separator{height:4px;background:repeating-linear-gradient(90deg,var(--accent) 0px,var(--accent) 4px,transparent 4px,transparent 8px);margin:1.5rem auto 0;max-width:200px}.about-workflow{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.about-workflow__step{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:100px}.about-workflow__icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;background:var(--card-bg);border:2px solid var(--border);border-radius:8px;box-shadow:0 2px 4px var(--card-shadow)}.about-workflow__label{font-weight:700;color:var(--accent);font-size:.95rem;margin-top:.25rem}.about-workflow__desc{font-size:.8rem;color:var(--accent-light)}.about-workflow__arrow{display:flex;align-items:center;padding:0 .25rem;margin-top:-1.5rem}.about-chars{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.about-chars__group{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:1rem;box-shadow:0 2px 4px var(--card-shadow)}.about-chars__title{font-weight:700;color:var(--accent);font-size:.9rem;margin-bottom:.5rem}.about-chars__sample{font-size:1.1rem;color:var(--text);line-height:1.8;letter-spacing:.1em;font-family:cursive,serif}.about-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.about-feature-icon{display:flex;align-items:center;justify-content:center}.about-author-card{display:flex;align-items:center;gap:1.5rem;max-width:400px;margin:0 auto;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:1.5rem;box-shadow:0 4px 8px var(--card-shadow)}.about-author-card__avatar{border-radius:50%;border:2px solid var(--border);flex-shrink:0}.about-author-card__info{display:flex;flex-direction:column;gap:.25rem}.about-author{font-size:1.1rem;font-weight:700;color:var(--accent)}.about-links{display:flex;gap:1rem;margin-top:.5rem;flex-wrap:wrap}.about-links a{color:var(--link);text-decoration:none}.about-links a:hover{text-decoration:underline}.hero__title{font-size:1.8rem;color:var(--accent);margin-bottom:.5rem}.hero__desc{margin-bottom:1.5rem}.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.template-page h2,.upload-page h2{margin-bottom:1rem;color:var(--accent)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.25rem;font-weight:700;color:var(--accent)}.template-page__info{margin:1rem 0;font-size:.9rem;color:var(--accent-light)}.template-page__note{margin:.5rem 0 1rem;padding:.5rem .75rem;border-left:3px solid var(--accent-light);background:#8b73550f;font-size:.85rem;color:var(--accent);line-height:1.5}.progress-wrapper{display:flex;flex-direction:column;gap:.25rem}.progress-label{font-size:.9rem;font-weight:700;color:var(--accent)}.progress-text{font-size:.8rem;text-align:right;color:var(--accent-light)}.scan-grid__summary{display:flex;gap:.5rem;align-items:baseline;margin-bottom:.75rem;flex-wrap:wrap}.scan-grid__stat{font-size:.85rem;color:var(--accent-light)}.scan-grid__stat--found{font-weight:700;color:var(--success)}.scan-grid__stat--excluded{color:var(--error)}.scan-grid__hint{font-size:.85rem;color:var(--accent-light);opacity:.8;margin-bottom:.75rem;padding:.4rem .6rem;border-left:3px solid var(--accent-light);background:#ffffff08}.scan-grid__page{margin-bottom:1rem;border-bottom:1px solid var(--border);padding-bottom:.75rem}.scan-grid__page:last-child{border-bottom:none;margin-bottom:0}.scan-grid__page-header{display:flex;gap:.75rem;align-items:center;margin-bottom:.5rem}.scan-grid__page-thumb{height:100px;border:1px solid var(--border);flex-shrink:0;cursor:pointer;transition:opacity .15s}.scan-grid__page-thumb:hover{opacity:.8}.scan-grid__page-info h4{color:var(--accent);margin-bottom:.25rem}.scan-grid__page-stat{font-size:.85rem;color:var(--accent-light)}.scan-grid__chars{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:0}.scan-grid__cell{position:relative;display:flex;flex-direction:column;align-items:center;border:1px solid var(--border);padding:1px;min-height:44px;background:var(--card-bg);cursor:pointer;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.scan-grid__cell--found{border-color:var(--success);background:#f0faf3}.scan-grid__cell--found:hover{background:#d8f0dd}.scan-grid__cell--empty{border-color:var(--error);background:#fdf0f0;cursor:default}.scan-grid__cell--imported{border-color:#999;background:#f5f5f5}.scan-grid__cell--imported:hover{background:#e8e8e8}.scan-grid__cell--excluded{border-color:#ccc;background:#f0f0f0;opacity:.5}.scan-grid__cell--excluded:hover{opacity:.7}.scan-grid__cell-char{font-size:.65rem;color:var(--accent-light);line-height:1}.scan-grid__cell-img{width:36px;height:36px;object-fit:contain;image-rendering:pixelated}.scan-grid__cell-miss,.scan-grid__cell-excluded-mark{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;line-height:1;color:var(--error);opacity:.5;pointer-events:none}.scan-grid__modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.scan-grid__modal{position:relative;background:var(--card-bg);border-radius:8px;padding:1rem;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.scan-grid__modal-close{position:absolute;top:.5rem;right:.75rem;font-size:1.5rem;background:none;border:none;cursor:pointer;color:var(--accent-light);line-height:1}.scan-grid__modal-title{font-size:.9rem;color:var(--accent);margin-bottom:.5rem}.scan-grid__modal-img{max-width:85vw;max-height:80vh;object-fit:contain;image-rendering:auto;border:1px solid var(--border);border-radius:4px}@media(max-width:768px){.main{padding:1rem .75rem}.steps{flex-direction:column;align-items:center}.step__arrow{transform:rotate(90deg)}.about-page{margin:-1rem -.75rem}.about-workflow{flex-direction:column;gap:.25rem}.about-workflow__arrow{transform:rotate(90deg);margin-top:0;padding:.25rem 0}}
