:root{--color-bg: #f8f6f3;--color-bg-alt: #efece8;--color-text: #1f1f1f;--color-text-muted: #5c5c5c;--color-accent: #0d7377;--color-accent-hover: #0a5c5f;--color-accent-soft: rgba(13, 115, 119, .12);--color-border: #e5e2de;--color-drawer-bg: #ffffff;--font-sans: "Noto Sans JP", sans-serif;--font-serif: "Shippori Mincho", "Noto Sans JP", serif;--font-logo: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--shadow-soft: 0 4px 24px rgba(0, 0, 0, .06);--shadow-menu: 0 8px 32px rgba(0, 0, 0, .12);--radius: 12px;--radius-sm: 8px;--header-h: 56px;--transition: .25s ease}@font-face{font-family:Noto Sans JP;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/site/noto-sans-jp-japanese-400-normal-BKjIVDG1.woff2) format("woff2")}@font-face{font-family:Noto Sans JP;font-style:normal;font-weight:700;font-display:swap;src:url(/assets/site/noto-sans-jp-japanese-700-normal-pBXQJX7r.woff2) format("woff2")}@font-face{font-family:Outfit;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/site/outfit-latin-400-normal-CQm_KAGb.woff2) format("woff2")}@font-face{font-family:Outfit;font-style:normal;font-weight:700;font-display:swap;src:url(/assets/site/outfit-latin-700-normal-DH66iFdQ.woff2) format("woff2")}@font-face{font-family:Shippori Mincho;font-style:normal;font-weight:700;font-display:swap;src:url(/assets/site/shippori-mincho-japanese-700-normal-BS6Lhmvd.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/site/jetbrains-mono-latin-400-normal-BrRFx4uz.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/assets/site/jetbrains-mono-latin-500-normal-BybgyI72.woff2) format("woff2")}.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:0 16px 0 20px;background:#f8f6f3e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);z-index:100;--header-control-height: 44px}.logo{flex-shrink:0;font-family:var(--font-logo);font-weight:700;font-size:1.2rem;letter-spacing:.08em;color:var(--color-accent);text-decoration:none;transition:color var(--transition)}.logo:hover{color:var(--color-accent-hover)}.logo:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:2px}.header-actions{display:flex;align-items:center;justify-content:flex-end;flex:1;min-width:0;gap:10px}.header-controls{display:flex;align-items:center;flex-shrink:0;gap:14px}.header-catalog-link{font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-decoration:none;padding:0 10px;height:var(--header-control-height);display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);white-space:nowrap;flex-shrink:1;min-width:0;border:1px solid var(--color-border);background:#ffffff73;box-sizing:border-box;transition:color var(--transition),background var(--transition),border-color var(--transition)}.header-catalog-link:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-soft)}.header-catalog-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(max-width:380px){.header-catalog-link{padding:0 6px;font-size:.74rem}}.lang-switcher{display:inline-flex;align-items:stretch;margin:0;padding:0;height:var(--header-control-height);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-drawer-bg);overflow:hidden;box-sizing:border-box}.lang-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0;padding:0 12px;border:none;border-radius:0;background:transparent;font-family:inherit;font-size:.85rem;font-weight:500;line-height:normal;color:var(--color-text-muted);cursor:pointer;min-width:2.5rem;min-height:0;flex:0 0 auto;align-self:stretch;display:flex;align-items:center;justify-content:center;transition:color var(--transition),background var(--transition),font-weight .12s ease;-webkit-tap-highlight-color:transparent;box-sizing:border-box}.lang-btn+.lang-btn{border-left:1px solid var(--color-border)}.lang-btn:hover{color:var(--color-accent);background:var(--color-accent-soft)}.lang-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px;position:relative;z-index:1}.lang-btn[aria-checked=true]{color:var(--color-accent);font-weight:600;background:var(--color-accent-soft)}.menu-trigger{flex-shrink:0;width:var(--header-control-height);height:var(--header-control-height);padding:0;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),border-color var(--transition);-webkit-tap-highlight-color:transparent;box-sizing:border-box}.menu-trigger:hover{border-color:var(--color-border);background:var(--color-accent-soft)}.menu-trigger:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.menu-trigger[aria-expanded=true] .menu-icon{background:transparent}.menu-trigger[aria-expanded=true] .menu-icon:before{top:0;transform:rotate(45deg)}.menu-trigger[aria-expanded=true] .menu-icon:after{bottom:0;transform:rotate(-45deg)}.menu-icon,.menu-icon:before,.menu-icon:after{display:block;width:22px;height:2px;background:var(--color-text);border-radius:1px;transition:transform var(--transition),background var(--transition)}.menu-icon{position:relative}.menu-icon:before,.menu-icon:after{content:"";position:absolute;left:0}.menu-icon:before{top:-7px}.menu-icon:after{bottom:-7px}.nav-drawer{position:fixed;inset:0;z-index:200;visibility:hidden;pointer-events:none;transition:visibility var(--transition)}.nav-drawer[data-open=true]{visibility:visible;pointer-events:auto}.nav-backdrop{position:absolute;inset:0;background:#0006;opacity:0;transition:opacity var(--transition)}.nav-drawer[data-open=true] .nav-backdrop{opacity:1}.nav-panel{position:absolute;top:0;right:0;width:min(320px,88vw);height:100%;background:var(--color-drawer-bg);box-shadow:var(--shadow-menu);display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition)}.nav-drawer[data-open=true] .nav-panel{transform:translate(0)}.nav-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--color-border)}.nav-title{font-weight:700;font-size:1rem;color:var(--color-text)}.nav-close{width:40px;height:40px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;font-size:1.5rem;line-height:1;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.nav-close:hover{background:var(--color-accent-soft);color:var(--color-text)}.nav-close:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.app-list{list-style:none;margin:0;padding:16px 12px;overflow-y:auto;flex:1;background:var(--color-drawer-bg)}.app-list li{margin-bottom:8px}.app-card{display:block;padding:16px;border-radius:var(--radius);background:var(--color-bg);border:1px solid var(--color-border);text-decoration:none;color:inherit;transition:border-color var(--transition),background var(--transition)}.app-card:hover{border-color:var(--color-accent);background:var(--color-accent-soft)}.app-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.app-card-icon{font-size:1.5rem;display:block;margin-bottom:6px}.app-card-name{font-weight:700;font-size:1rem;display:block;color:var(--color-text)}.app-card-desc{font-size:.8rem;color:var(--color-text-muted);display:block;margin-top:2px}.app-list li.nav-filter-slot{margin-bottom:12px}.nav-filter-slot{position:sticky;top:-16px;margin-top:-16px;padding:16px 0 12px;z-index:2;list-style:none;background:var(--color-drawer-bg);border-bottom:1px solid var(--color-border);box-shadow:0 1px 0 0 var(--color-drawer-bg),0 4px 0 0 var(--color-drawer-bg)}.nav-filter-input{width:100%;box-sizing:border-box;padding:10px 12px;font-size:.9rem;font-family:inherit;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.nav-filter-input::-moz-placeholder{color:#9a9690}.nav-filter-input::placeholder{color:#9a9690}.nav-filter-input:hover{border-color:#d4cfc8}.nav-filter-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.nav-group-label{margin-top:16px;margin-bottom:4px;padding:0 4px}.nav-group-label-text{font-size:.75rem;font-weight:600;color:var(--color-text-muted);letter-spacing:.04em}tools-site-footer{display:block}.footer{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:24px 20px;text-align:center;border-top:1px solid var(--color-border);background:var(--color-drawer-bg)}.footer p{margin:0;font-size:.8rem;color:var(--color-text-muted)}.footer-copyright{margin:0}.footer-copyright small{font-size:.72rem;line-height:1.4;color:var(--color-text-muted)}.footer a{color:var(--color-accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.2em}.footer a:hover{text-decoration-thickness:2px}.footer a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){.header,.nav-drawer,.nav-panel,.menu-icon,.menu-icon:before,.menu-icon:after{transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--color-text);background:var(--color-bg);min-height:100vh;display:flex;flex-direction:column}.skip-link{position:absolute;z-index:1000;top:0;left:0;padding:12px 20px;font-size:1rem;font-weight:600;color:var(--color-text);background:var(--color-drawer-bg);border:2px solid var(--color-accent);border-radius:0 0 var(--radius-sm) 0;text-decoration:none;transform:translateY(calc(-100% - 4px));transition:transform .2s ease}.skip-link:focus{transform:translateY(0);outline:none}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-h));margin-top:var(--header-h);padding:40px 24px 60px;text-align:center;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-30%;right:-20%;width:70%;height:70%;background:radial-gradient(ellipse at center,var(--color-accent-soft) 0%,transparent 70%);pointer-events:none}.hero-catch{font-family:var(--font-serif);font-size:clamp(1.75rem,5vw,2.5rem);font-weight:700;line-height:1.4;color:var(--color-text);margin:0 0 .5em;letter-spacing:.02em;position:relative}.hero-lead{font-size:clamp(1.1rem,2.5vw,1.35rem);font-weight:500;color:var(--color-text);margin:0 0 .25em;position:relative}.hero-sub{font-size:1rem;color:var(--color-text-muted);margin:0 0 1.25em;position:relative}.hero-tagline{font-size:clamp(.9rem,2vw,1rem);color:var(--color-text-muted);max-width:32ch;margin:0 auto 2rem;line-height:1.7;position:relative}.hero-cta{position:relative}.btn-cta{display:inline-block;padding:14px 28px;font-size:1rem;font-weight:600;font-family:inherit;color:#fff;background:var(--color-accent);border:none;border-radius:var(--radius);text-decoration:none;box-shadow:var(--shadow-soft);cursor:pointer;transition:background var(--transition),transform .15s ease}.btn-cta:hover{background:var(--color-accent-hover);transform:translateY(-1px)}.btn-cta:active{transform:translateY(0)}.btn-cta:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.about{padding:32px 24px 48px;background:var(--color-bg-alt);text-align:center}.about-text{max-width:42ch;margin:0 auto;font-size:.95rem;color:var(--color-text-muted);line-height:1.75}.about-catalog{margin:1.5rem 0 0;text-align:center}.about-catalog-link{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .15rem .28rem;font-size:.875rem;font-weight:600;letter-spacing:.02em;color:var(--color-accent);text-decoration:none;border-radius:0;border-bottom:1px solid transparent;transition:color var(--transition),border-color var(--transition),transform .2s ease}.about-catalog-link:after{content:">";flex-shrink:0;font-size:.95em;font-weight:600;line-height:1;color:inherit;opacity:.85;transition:transform .2s ease}.about-catalog-link:hover{color:var(--color-accent-hover);border-bottom-color:currentColor}.about-catalog-link:hover:after{transform:translate(2px)}.about-catalog-link:active{color:var(--color-accent-hover)}.about-catalog-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px}@media(prefers-reduced-motion:reduce){.about-catalog-link,.about-catalog-link:after{transition-duration:.01ms!important}.about-catalog-link:hover:after{transform:none}}#main-content{scroll-margin-top:var(--header-h)}#apps{scroll-margin-top:calc(var(--header-h) + 12px)}.tools-directory-page{flex:1;display:flex;flex-direction:column;margin-top:var(--header-h)}.tools-directory.tools-directory--page{flex:1;border-top:none}.tools-directory{padding:0 0 56px;background:linear-gradient(180deg,var(--color-bg-alt) 0%,var(--color-bg) 48%);border-top:1px solid var(--color-border)}.tools-directory-inner{max-width:1120px;margin:0 auto;padding:40px 24px 0}.tools-directory-header{text-align:center;margin-bottom:2rem}.tools-directory-title{font-family:var(--font-serif);font-size:clamp(1.35rem,3.5vw,1.65rem);font-weight:700;letter-spacing:.04em;color:var(--color-text);margin:0 0 .65rem}.tools-directory-lead{margin:0 auto;max-width:min(30rem,100%);font-size:.95rem;color:var(--color-text-muted);line-height:1.65}.tools-directory-toolbar{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.75rem}.tools-search-wrap{max-width:420px;margin:0 auto;width:100%}.tools-search-label{display:block;text-align:left}.tools-search-label-text{display:block;font-size:.8rem;font-weight:600;color:var(--color-text-muted);margin-bottom:.4rem;letter-spacing:.02em}.tools-search-input{width:100%;padding:12px 16px;font-size:1rem;font-family:inherit;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-drawer-bg);color:var(--color-text);box-shadow:var(--shadow-soft);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.tools-search-input::-moz-placeholder{color:#9a9690}.tools-search-input::placeholder{color:#9a9690}.tools-search-input:hover{border-color:#d4cfc8}.tools-search-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.tools-tag-row{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.tools-tag{padding:8px 14px;font-size:.82rem;font-weight:600;font-family:inherit;color:var(--color-text-muted);background:var(--color-drawer-bg);border:1px solid var(--color-border);border-radius:999px;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition);-webkit-tap-highlight-color:transparent}.tools-tag:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft)}.tools-tag:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.tools-tag[aria-pressed=true]{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.tools-tag[aria-pressed=true]:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.tools-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.tools-grid>li{margin:0}.tools-card{display:flex;flex-direction:column;height:100%;min-height:7.5rem;padding:1.15rem 1.2rem;border-radius:var(--radius);background:var(--color-drawer-bg);border:1px solid var(--color-border);text-decoration:none;color:inherit;box-shadow:var(--shadow-soft);transition:border-color var(--transition),box-shadow var(--transition),transform .15s ease}.tools-card:hover{border-color:var(--color-accent);box-shadow:0 8px 28px #0d73771f;transform:translateY(-2px)}.tools-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.tools-card-icon{font-size:1.45rem;line-height:1;margin-bottom:.5rem}.tools-card-name{font-weight:700;font-size:1rem;color:var(--color-text);margin-bottom:.35rem;letter-spacing:.02em}.tools-card-desc{font-size:.82rem;line-height:1.55;color:var(--color-text-muted);flex:1}.tools-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:.75rem}.tools-card-badge{font-size:.68rem;font-weight:600;padding:3px 8px;border-radius:6px;background:var(--color-bg-alt);color:var(--color-text-muted);letter-spacing:.02em}.tools-empty{text-align:center;font-size:.95rem;color:var(--color-text-muted);margin:2rem 0 0;line-height:1.65}.tools-directory-footnote{text-align:center;font-size:.85rem;color:var(--color-text-muted);margin:2.25rem 0 0;line-height:1.6}.tools-directory-footnote a{color:var(--color-accent);text-decoration:none;font-weight:600}.tools-directory-footnote a:hover{text-decoration:underline}@media(max-width:600px){.tools-directory-inner{padding-top:32px}}.faq-page{margin-top:var(--header-h);padding:32px 24px 48px;max-width:640px;margin-left:auto;margin-right:auto}.faq-header{text-align:center;margin-bottom:2rem}.faq-header h1{font-family:var(--font-serif);font-size:clamp(1.5rem,4vw,1.75rem);font-weight:700;margin:0 0 .5rem;color:var(--color-text)}.faq-lead{font-size:.95rem;color:var(--color-text-muted);margin:0}.faq-toc{margin-bottom:2.5rem;padding:1.25rem;background:var(--color-bg-alt);border-radius:var(--radius);border:1px solid var(--color-border)}.faq-toc-title{font-weight:700;font-size:.9rem;margin:0 0 .75rem;color:var(--color-text)}.faq-toc ul{margin:0;padding-left:1.25rem;list-style:disc}.faq-toc li{margin-bottom:.35rem}.faq-toc a{display:inline-flex;align-items:baseline;gap:.4rem;color:var(--color-accent);text-decoration:none}.faq-toc a:hover{text-decoration:underline}.faq-toc-icon{font-size:1.15rem;line-height:1;flex-shrink:0}.faq-section{margin-bottom:2.5rem;scroll-margin-top:calc(var(--header-h) + 1rem)}.faq-section h2{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;font-size:1.25rem;font-weight:700;margin:0 0 .5rem;padding-bottom:.35rem;border-bottom:2px solid var(--color-accent);color:var(--color-text)}.faq-section-icon{font-size:1.35rem;line-height:1;flex-shrink:0}.faq-section-desc{font-size:.9rem;color:var(--color-text-muted);margin:0 0 1.25rem;line-height:1.6}.faq-dl{margin:0}.faq-dl dt{font-weight:600;font-size:.95rem;margin:1rem 0 .35rem;color:var(--color-text)}.faq-dl dt:first-child{margin-top:0}.faq-dl dd{margin:0;padding-left:.5rem;font-size:.9rem;line-height:1.7;color:var(--color-text-muted)}.faq-dl dd strong{color:var(--color-text);font-weight:700}.faq-dl dd code{font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;font-size:.88em;padding:.12em .35em;border-radius:var(--radius-sm, 4px);background:var(--color-drawer-bg, rgba(0, 0, 0, .06))}.faq-dl dd+dt{margin-top:1.25rem}.faq-page+tools-site-footer .footer a{color:var(--color-accent);text-decoration:none}.faq-page+tools-site-footer .footer a:hover{text-decoration:underline}.legal-page{margin-top:var(--header-h);padding:32px 24px 48px;max-width:640px;margin-left:auto;margin-right:auto}.legal-header{text-align:center;margin-bottom:2rem}.legal-header h1{font-family:var(--font-serif);font-size:clamp(1.5rem,4vw,1.75rem);font-weight:700;margin:0 0 .5rem;color:var(--color-text)}.legal-lead{font-size:.95rem;color:var(--color-text-muted);margin:0}.legal-section{margin-bottom:2rem;scroll-margin-top:calc(var(--header-h) + 1rem)}.legal-section h2{font-size:1.15rem;font-weight:700;margin:0 0 .75rem;padding-bottom:.35rem;border-bottom:2px solid var(--color-accent);color:var(--color-text)}.legal-section p,.legal-section li{font-size:.9rem;line-height:1.75;color:var(--color-text);margin:0 0 .75rem}.legal-section ul{margin:0 0 .75rem;padding-left:1.5rem}.legal-section li{margin-bottom:.35rem}.legal-page+tools-site-footer .footer a{color:var(--color-accent);text-decoration:none}.legal-page+tools-site-footer .footer a:hover{text-decoration:underline}.legal-page.contact-page{max-width:36rem}.contact-form{margin:1rem 0}.contact-form-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;margin:0;padding:0}.contact-form-field{margin-bottom:1.25rem}.contact-form-field label{display:block;font-weight:500;margin-bottom:.35rem;color:var(--color-text)}.contact-form-field .required{color:var(--color-accent);font-size:.875em}.contact-form-field input,.contact-form-field textarea{width:100%;max-width:100%;padding:.5rem .6rem;font-size:1rem;font-family:inherit;border:1px solid #ccc;border-radius:4px;background:#fff;box-sizing:border-box}.contact-form-field input:focus,.contact-form-field textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f633}.contact-form-field textarea{resize:vertical;min-height:6rem}.contact-form-submit{margin-top:1.5rem}.contact-form-submit button{padding:.6rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;color:#fff;background:var(--color-accent);border:none;border-radius:6px;cursor:pointer;transition:background .15s ease,transform .1s ease}.contact-form-submit button:hover{background:var(--color-accent-hover, #2563eb)}.contact-form-submit button:active{transform:scale(.98)}.contact-form-submit button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.charcount-page{margin-top:var(--header-h);padding:32px 24px 56px;max-width:1040px;margin-left:auto;margin-right:auto}.charcount-header{margin-bottom:1.5rem}.charcount-header h1{font-family:var(--font-serif);font-size:clamp(1.4rem,4vw,1.85rem);font-weight:700;margin:0 0 .4rem;color:var(--color-text)}.charcount-lead{margin:0;font-size:.95rem;color:var(--color-text-muted);line-height:1.7}.charcount-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:14px;align-items:start}.charcount-panel{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;min-width:0;align-items:stretch}.charcount-results-panel{position:sticky;top:calc(var(--header-h, 56px) + 8px);align-self:start;z-index:10;background:var(--color-bg-alt)}.charcount-textarea{width:100%;min-height:320px;resize:vertical;padding:12px 14px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;font-size:1rem;line-height:1.7;font-family:var(--font-sans);outline:none;box-sizing:border-box;flex:1 1 auto}.charcount-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.charcount-textarea{scrollbar-width:none}.charcount-textarea::-webkit-scrollbar{width:0;height:0}.charcount-textarea::-webkit-scrollbar-track{background:transparent}.charcount-textarea::-webkit-scrollbar-thumb{background:transparent}.charcount-textarea::-webkit-scrollbar-thumb:hover{background:transparent}.charcount-limit-note{width:100%;margin-top:10px;font-size:.85rem;color:var(--color-text-muted);line-height:1.4;overflow-wrap:anywhere;word-break:break-all;white-space:normal;max-width:100%;box-sizing:border-box;display:block;min-width:0;flex-shrink:1}.charcount-limit-note.is-limit{color:#b91c1c;font-weight:600}.charcount-metrics{display:grid;grid-template-columns:1fr;gap:10px;flex:1 1 auto}.charcount-metric{background:#fff;border:1px solid var(--color-border);border-radius:10px;padding:12px 14px}.charcount-metric-label{font-size:.85rem;font-weight:600;color:var(--color-text-muted);margin-bottom:6px}.charcount-metric-value{font-size:1.05rem;font-weight:800;color:var(--color-text)}@media(max-width:860px){.tools-grid,.charcount-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:.01ms!important}}.lottery-page{--lottery-surface: #ffffff;--lottery-ink: #0e1718;--lottery-muted: #5a6568;--lottery-stage-bg: linear-gradient(145deg, #0a2528 0%, #0d3539 42%, #082022 100%);--lottery-glow: rgba(13, 115, 119, .35);--lottery-gold: #d4a84b;--lottery-gold-soft: rgba(212, 168, 75, .2);--lottery-radius: 16px;flex:1;padding:calc(var(--header-h) + 28px) 24px 56px;max-width:720px;margin:0 auto;width:100%}.lottery-hero{margin-bottom:28px}.lottery-hero h1{font-family:var(--font-serif);font-size:clamp(1.65rem,4.5vw,2.15rem);font-weight:700;letter-spacing:.04em;color:var(--lottery-ink);margin:0 0 12px;line-height:1.35}.lottery-lead{margin:0;font-size:1rem;color:var(--lottery-muted);line-height:1.75}.lottery-card{background:var(--lottery-surface);border:1px solid var(--color-border);border-radius:var(--lottery-radius);box-shadow:var(--shadow-soft);padding:24px 22px 26px;margin-bottom:20px}.lottery-card-title{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent);margin:0 0 16px}.lottery-mode{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}.lottery-mode-btn{flex:1;min-width:140px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--color-border);background:var(--color-bg-alt);color:var(--lottery-ink);font-family:inherit;font-size:.95rem;font-weight:600;padding:12px 16px;border-radius:12px;cursor:pointer;transition:border-color var(--transition),background var(--transition),box-shadow var(--transition)}.lottery-mode-btn:hover{border-color:#0d737759}.lottery-mode-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.lottery-mode-btn.is-active{border-color:var(--color-accent);background:var(--color-accent-soft);box-shadow:0 0 0 1px #0d737726}.lottery-panel{display:none;animation:lottery-fade .35s ease}.lottery-panel.is-visible{display:block}@keyframes lottery-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.lottery-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:8px}@media(max-width:520px){.lottery-field-row{grid-template-columns:1fr}}.lottery-label{display:block;font-size:.85rem;font-weight:600;color:var(--lottery-muted);margin-bottom:6px}.lottery-input{width:100%;font-family:inherit;font-size:1.05rem;padding:11px 14px;border:1px solid var(--color-border);border-radius:10px;background:#fff;color:var(--lottery-ink);transition:border-color .2s ease,box-shadow .2s ease}.lottery-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.lottery-textarea{min-height:160px;resize:vertical;line-height:1.55}.lottery-hint{font-size:.8rem;color:var(--lottery-muted);margin:8px 0 0}.lottery-delay-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:20px;padding-top:18px;border-top:1px dashed var(--color-border)}.lottery-delay-row label{font-weight:600;font-size:.92rem;color:var(--lottery-ink)}.lottery-delay-input{width:88px}.lottery-actions{margin-top:22px}.lottery-btn-primary{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;font-family:inherit;font-size:1.05rem;font-weight:700;letter-spacing:.06em;padding:15px 22px;border:none;border-radius:12px;cursor:pointer;color:#fff;background:linear-gradient(160deg,var(--color-accent) 0%,#095a5d 100%);box-shadow:0 6px 20px var(--lottery-glow);transition:transform .15s ease,box-shadow .2s ease}.lottery-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 26px #0d737766}.lottery-btn-primary:active:not(:disabled){transform:translateY(0)}.lottery-btn-primary:disabled{opacity:.45;cursor:not-allowed}.lottery-btn-secondary{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin-top:12px;width:100%;font-family:inherit;font-size:.95rem;font-weight:600;padding:12px;border:2px solid var(--color-border);border-radius:12px;background:transparent;color:var(--color-accent);cursor:pointer;transition:background .2s ease,border-color .2s ease}.lottery-btn-secondary:hover{background:var(--color-accent-soft);border-color:#0d737759}.lottery-btn-secondary:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.lottery-btn-secondary[hidden]{display:none}.lottery-stage-wrap{margin-top:8px}.lottery-stage-label{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--lottery-muted);margin:0 0 10px}.lottery-stage{position:relative;min-height:200px;border-radius:var(--lottery-radius);background:var(--lottery-stage-bg);box-shadow:inset 0 1px #ffffff0f,0 16px 40px #08202259;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:32px 24px}.lottery-stage:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -10%,var(--lottery-glow),transparent 55%),radial-gradient(circle at 100% 100%,rgba(212,168,75,.08),transparent 45%);pointer-events:none}.lottery-stage-inner{position:relative;z-index:1;text-align:center;width:100%}.lottery-placeholder{font-size:.95rem;color:#ffffff73;letter-spacing:.08em;font-weight:500}.lottery-result-display{font-family:var(--font-serif);font-size:clamp(1.75rem,7vw,2.75rem);font-weight:700;color:#fff;line-height:1.25;word-break:break-word;margin:0;text-shadow:0 2px 24px rgba(0,0,0,.35);transition:opacity .2s ease,filter .2s ease}.lottery-result-display.is-suspense{opacity:.88;filter:blur(.5px)}.lottery-result-display.is-reveal{color:#fefaf0;text-shadow:0 0 40px var(--lottery-gold-soft),0 2px 20px rgba(0,0,0,.4)}@media(prefers-reduced-motion:reduce){.lottery-result-display.is-suspense{filter:none}.lottery-panel{animation:none}}.lottery-message{margin-top:14px;font-size:.88rem;min-height:1.4em;color:#b42318;font-weight:500}.lottery-message:empty{display:none}.hidden{display:none}.italic{font-style:italic}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}
