*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Hiragino Sans,Noto Sans JP,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}.site-header{border-bottom:1px solid #ccc;justify-content:space-between;align-items:center;padding:16px;display:flex}.header__left,.header__right{flex:1}.header__left{justify-content:flex-start;display:flex}.header__center{text-align:center;color:#666;flex:2;font-size:.9rem}.header__expiry-label{margin-right:.25em}.header__right{justify-content:flex-end;display:flex}.site-footer{text-align:center;color:#666;border-top:1px solid #ccc;padding:24px 16px}.footer-links{flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;display:flex}.footer-links-row{justify-content:center;gap:1.5rem;display:flex}.footer-links a{text-decoration:underline}.footer-links a:hover{text-decoration:none}.container{max-width:1200px;margin:0 auto;padding:0 16px}.container--narrow{max-width:800px;margin:0 auto;padding:0 16px}.page-section{padding:32px 16px}.page-section.container{text-align:center}.page-section--large{padding:48px 16px}.site-description{color:#fff;text-align:left;background-color:#001f3f;border-radius:8px;width:100%;max-width:800px;margin-top:40px;margin-bottom:16px;padding:16px;font-size:.95rem;line-height:1.6;display:inline-block}.dropdown{position:relative}.dropdown__menu{z-index:100;background:#fff;border:1px solid #ccc;border-radius:4px;min-width:200px;padding:8px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 6px #0000001a}.dropdown__menu--left{left:0;right:auto}.dropdown__user-info{margin-bottom:8px;padding:4px 8px}.dropdown__user-name{font-weight:500}.dropdown__expiry{color:#666;margin-top:4px;font-size:.8rem}.dropdown__item{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;width:100%;padding:8px;display:flex}.dropdown__item:hover{background:#f5f5f5}.dropdown__item--tag{justify-content:space-between}.dropdown__item--danger{color:#dc2626}.dropdown__item--danger:hover{background:#fef2f2}.dropdown__tag-list{max-height:300px;overflow-y:auto}.tag-count{color:#666;background-color:#f0f0f0;border-radius:4px;padding:2px 6px;font-size:.8rem}.article-list{text-align:left;flex-direction:column;gap:24px;max-width:800px;margin-top:24px;margin-left:auto;margin-right:auto;display:flex}.article-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;transition:box-shadow .2s;display:block;overflow:hidden}.article-card:hover{box-shadow:0 4px 12px #00000014}.article-card__image-wrapper{flex-shrink:0;width:150px;position:relative}.article-card__content{flex-grow:1;padding:16px}.article-card__content h2{margin-bottom:8px;font-size:1.1rem}.article-card__content p{color:#666;font-size:.9rem}.article-card__tags{color:#666;align-items:center;gap:8px;margin-top:12px;font-size:.8rem;display:flex}.article-card__footer{background-color:#f8f9fa;border-top:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.article-card__badge{border-radius:4px;padding:4px 8px;font-size:.8rem;font-weight:500}.article-card__badge--paid{color:#005f99;background-color:#e6f7ff}.article-card__badge--free{color:#555;background-color:#f0f0f0}.article-card__date{color:#666;font-size:.8rem}.article__header{border-bottom:1px solid #eee;margin-bottom:24px;padding-bottom:16px}.article__header h1{margin-bottom:16px;font-size:1.8rem;line-height:1.3}.article__meta{color:#666;flex-wrap:wrap;gap:16px;font-size:.9rem;display:flex}.article__tags{flex-wrap:wrap;align-items:center;gap:4px;display:inline-flex}.article__tag-link{text-decoration:underline #ccc;transition:all .2s}.article__tag-link:hover{color:#000;text-decoration-color:#000}.article__content{margin-top:24px;font-size:.95rem;line-height:1.8}.article__content h2{border-bottom:1px solid #e2e8f0;margin:48px 0 24px;padding-bottom:8px;font-size:1.6rem}.article__content h3{margin:32px 0 16px;font-size:1.3rem}.article__content hr{border:none;border-top:1px solid #e2e8f0;margin:48px 0}.article__content a{color:#2563eb;text-underline-offset:2px;text-decoration:underline 1px}.article__content a:hover{color:#1d4ed8;text-decoration:none}.article__content pre{background-color:#f4f4f4;border-radius:6px;margin:1.5em 0;padding:16px;font-size:.9em;overflow-x:auto}.article__content :not(pre)>code{background-color:#f4f4f4;border-radius:4px;padding:2px 4px;font-size:.9em}@media (min-width:481px){.article__content img{max-width:500px;margin:0 auto;display:block}}.article__content table{border-collapse:collapse;width:100%;margin:1.5em 0;font-size:.9em}.article__content thead{background-color:#f8f9fa}.article__content th,.article__content td{text-align:left;border:1px solid #e2e8f0;padding:10px 12px}.article__content th{background-color:#f1f5f9;font-weight:600}.article__content tbody tr:nth-child(2n){background-color:#fafafa}.article__content tbody tr:hover{background-color:#f0f4f8}.separator{border:none;border-top:1px solid #ccc;margin:32px 0}.article__footer-actions{text-align:center;margin-top:32px}.comment-list{margin-top:16px}.comment{border:1px solid #ccc;margin-bottom:8px;padding:12px}.comment__header{color:#666;justify-content:space-between;margin-bottom:8px;display:flex}.comment p{overflow-wrap:break-word}.comment-form{margin-top:24px}.comment-form__textarea{width:100%;min-height:80px;padding:8px}.comment-form__submit{margin-top:8px;padding:8px 16px}.paywall{text-align:center;border:1px solid #ccc;max-width:100%;margin:0 auto;padding:48px}.paywall__article-title{color:#6c757d;margin-bottom:1rem;padding:0 1rem;font-size:.95rem;font-weight:500;line-height:1.4}.paywall__icon{font-size:48px}.paywall__price{font-size:32px;font-weight:700}.paywall__pricing{margin:24px 0}.paywall__error{color:red}.payment-result{text-align:center;max-width:400px;margin:0 auto;padding:48px}.payment-result__card{border:1px solid #ccc;padding:24px}.payment-result__icon--success{color:green}.payment-result__icon--cancel{color:#666}.payment-result__actions{margin-top:24px}.payment-result__benefits{text-align:left;margin-top:16px}.admin-page{max-width:800px;margin:0 auto;padding:48px 16px}.admin-page__header{border-bottom:1px solid #eee;margin-bottom:24px;padding-bottom:24px}.admin-notice{background-color:#f8f9fa;border:1px solid #ccc;border-radius:4px;gap:12px;margin-top:16px;padding:12px;display:flex}.admin-notice__title{font-weight:700}.form-card{border:1px solid #ccc;padding:16px}.form-card__header,.form-group{margin-bottom:16px}.form-label{margin-bottom:4px;display:block}.form-textarea{width:100%;padding:8px}.notification{border:1px solid;justify-content:space-between;margin-bottom:16px;padding:12px;display:flex}.notification--success{background:#f0fff0;border-color:green}.notification--error{background:#fff0f0;border-color:red}.generated-result{border:1px solid #ccc;margin-top:24px;padding:16px}.generated-result__header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.generated-result__image{margin-bottom:24px}.generated-result__image-title{align-items:center;gap:8px;margin-bottom:16px;display:flex}.generated-result__image-container{aspect-ratio:16/9;position:relative}.markdown-preview{border:1px solid #eee;padding:16px}.btn{cursor:pointer;white-space:nowrap;color:#333;box-sizing:border-box;background:#fff;border:1px solid #ccc;align-items:center;height:38px;padding:8px 12px;display:inline-flex}.btn-icon{cursor:pointer;box-sizing:border-box;background:0 0;border:none;justify-content:center;align-items:center;height:38px;padding:5px;display:flex}.btn--primary{justify-content:center;width:100%;padding:12px 24px}.btn--secondary{justify-content:center;width:100%;padding:8px 16px}.btn--with-icon{align-items:center;gap:8px;display:inline-flex}.btn--link{padding:12px 24px;display:inline-block}.btn--home{color:#fff;background-color:#001f3f;border-color:#001f3f;transition:opacity .2s}.btn--home:hover{opacity:.9;color:#fff}.loading{text-align:center;padding:48px}.loading-inline{justify-content:center;align-items:center;gap:8px;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spin{animation:1s linear infinite spin}.pagination{justify-content:center;margin-top:32px;display:flex}.pagination__list{border:1px solid #ccc;border-radius:4px;padding:0;list-style:none;display:flex;overflow:hidden}.pagination__item+.pagination__item{border-left:1px solid #ccc}.pagination__link{color:#333;padding:8px 12px;text-decoration:none;transition:background-color .2s;display:block}.pagination__link:hover{background-color:#f5f5f5}.pagination__link.active{color:#fff;cursor:default;background-color:#333;font-weight:700}.pagination__link.disabled{color:#ccc;cursor:not-allowed}.text-muted{opacity:.5;white-space:nowrap;padding:7px 12px;font-size:.875rem}.loading-spinner{color:#666;animation:1s linear infinite spin}.error-text{color:red}.receipt-link{justify-content:center;align-items:center;gap:8px;display:flex}.benefit-list{text-align:left;margin-top:16px}.payment-result__receipt{margin-top:24px}.payment-result__message{margin:24px 0}.form-group__label{margin-bottom:4px;display:block}.form-group__textarea{width:100%;padding:8px}.generated-result__image{aspect-ratio:16/9;position:relative}.generated-result__image-section{margin-bottom:24px}.generated-result__preview{border:1px solid #eee;padding:16px}.btn--full{width:100%}.btn--primary+.btn--secondary{margin-top:8px}@media (max-width:480px){.container--narrow{padding-left:16px;padding-right:16px}.page-section--large{padding-top:24px;padding-bottom:24px}.article__header h1{font-size:1.4rem}.article__content h2{margin:32px 0 16px;font-size:1.4rem}.article__content h3{margin:24px 0 16px;font-size:1.2rem}}.login-modal-backdrop{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.login-modal{background:#fff;border-radius:8px;width:100%;max-width:480px;max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 4px 20px #00000026}.login-modal__title{text-align:center;margin-bottom:16px;font-size:1.25rem;font-weight:700}.login-modal__terms-box{text-align:left;background-color:#f9f9f9;border:1px solid #ccc;height:200px;margin-bottom:16px;padding:1rem;font-size:.8rem;line-height:1.5;overflow-y:auto}.login-modal__notice{text-align:center;color:#666;margin-bottom:16px;font-size:.85rem}.login-modal__close-btn{color:#666;cursor:pointer;background:0 0;border:none;width:100%;margin-top:8px;padding:8px;font-size:.9rem;display:block}.login-modal__close-btn:hover{color:#333;text-decoration:underline}@media (max-width:480px){.paywall{margin:0 8px;padding:24px 12px}.login-modal{padding:16px}.login-modal__terms-box{height:150px;padding:.75rem;font-size:.75rem}}
