:root{color:#29231f;font-synthesis:none;text-rendering:optimizelegibility;background:#faf6ee;font-family:Noto Sans JP,Hiragino Sans,Yu Gothic,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.85}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#faf6ee;min-width:320px;margin:0}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font:inherit}.site-header{z-index:10;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#faf6eee0;justify-content:space-between;align-items:center;gap:24px;width:min(1240px,100% - 64px);margin:0 auto;padding:30px 0 24px;display:flex;position:sticky;top:0}.site-logo{color:#342b25;letter-spacing:.005em;font-size:1rem;font-weight:700;line-height:1}.site-nav{color:#71685f;flex-wrap:wrap;justify-content:flex-end;gap:10px 26px;font-size:.88rem;font-weight:600;display:flex}.site-nav a:hover,.site-nav a.active,.link-list a:hover,.footer-links a:hover{color:#ad6651}.hero-section,.page-hero,.section{width:min(1240px,100% - 64px);margin:0 auto}.hero-section{grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);align-items:center;gap:clamp(48px,7vw,120px);min-height:calc(100svh - 98px);padding:clamp(54px,7vh,88px) 0 clamp(68px,8vh,104px);display:grid}.hero-copy{max-width:700px}.eyebrow{color:#a45f4c;letter-spacing:.16em;text-transform:uppercase;margin:0 0 18px;font-size:.72rem;font-weight:800}h1,h2,h3,p{margin-top:0}h1{color:#261f1a;letter-spacing:0;margin-bottom:28px;font-size:clamp(2.8rem,5vw,5rem);line-height:1.08}.hero-copy h1{font-size:clamp(3.15rem,5.2vw,4.75rem);line-height:1.04}h2{color:#2a231f;letter-spacing:0;margin-bottom:18px;font-size:clamp(2.1rem,3.8vw,3.7rem);line-height:1.12}h3{color:#332822;letter-spacing:0;margin-bottom:10px;font-size:1.08rem;line-height:1.4}.hero-copy>p:not(.eyebrow),.section-heading>p:not(.eyebrow),.page-hero p:not(.eyebrow),.about-content p,.activity-card p,.link-card p,.summary-card p,.work-card p,.footer-brand p{color:#6a6158}.hero-copy>p:not(.eyebrow){overflow-wrap:anywhere;max-width:560px;margin-bottom:0;font-size:clamp(1.03rem,1.4vw,1.18rem)}.hero-actions{flex-wrap:wrap;gap:14px;margin-top:44px;display:flex}.button{letter-spacing:.01em;border:1px solid #cdb4a6;border-radius:999px;justify-content:center;align-items:center;min-height:54px;padding:0 28px;font-size:.95rem;font-weight:800;display:inline-flex}.button.primary{color:#fff;background:#a85f4c;border-color:#a85f4c}.button.secondary{color:#60483f;background:0 0}.hero-visual{background:0 0;justify-content:center;align-items:center;display:flex;overflow:visible}.hero-visual img{object-fit:contain;background:0 0;width:100%;max-width:min(760px,114%);height:min(64vw,720px);min-height:540px}.section{padding:clamp(118px,12vw,178px) 0}.gallery-list-section{padding-top:40px}.page-hero{padding:78px 0 28px}.page-hero h1{margin-bottom:14px;font-size:clamp(1.9rem,3vw,2.7rem);line-height:1.18}.page-hero p:not(.eyebrow){overflow-wrap:anywhere;max-width:680px}.page-hero+.section{padding-top:clamp(46px,6vw,76px)}.section-heading{max-width:760px;margin-bottom:58px}.works-grid,.summary-grid,.activity-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(28px,3vw,42px);display:grid}.featured-works-grid-section .works-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(30px,3.4vw,48px)}.work-card,.summary-card,.activity-card,.link-card{background:#fffdf8c7;border:1px solid #e5d8cc;border-radius:6px;overflow:hidden;box-shadow:0 18px 46px #53382b0f}.summary-card,.activity-card,.link-card{padding:32px;display:block}.summary-card span{color:#ad6651;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;font-size:.75rem;font-weight:700;display:block}.work-labels{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.work-labels span{color:#a45f4c;letter-spacing:.08em;border:1px solid #0000;border-radius:999px;align-items:center;padding:4px 0;font-size:.72rem;font-weight:800;display:inline-flex}.work-labels .fanart-label{color:#73574c;background:#fff8f2;border-color:#dfd0c5;padding-inline:9px}.work-labels .tag-label{color:#71685f}.work-image-frame{cursor:zoom-in;background:#fff;border:1px solid #efe4da;border-radius:1px;justify-content:center;align-items:center;width:calc(100% - 32px);height:390px;margin:16px 16px 0;padding:0;transition:border-color .16s;display:flex}.work-image-frame:hover,.work-image-frame:focus-visible{border-color:#cdb4a6}.work-image-frame:focus-visible{outline-offset:3px;outline:3px solid #b96f5838}.work-image-frame img{object-fit:contain;object-position:center;width:100%;height:100%;padding:24px}.work-card-body{padding:28px 28px 30px}.work-card p,.about-content p,.section-heading p,.activity-card p{margin-bottom:0}.work-meta{gap:8px;margin:24px 0 0;display:grid}.work-meta div{border-top:1px solid #efe4da;justify-content:space-between;gap:16px;padding-top:8px;display:flex}.work-meta dt,.work-meta dd{color:#756a61;margin:0;font-size:.82rem}.work-meta dt{flex:none;font-weight:700}.work-meta dd{text-align:right}.image-modal-overlay{z-index:100;background:#181614ad;justify-content:center;align-items:center;padding:28px;display:flex;position:fixed;inset:0}.image-modal{background:#fff;border-radius:8px;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:clamp(24px,4vw,48px);width:min(1120px,100%);max-height:min(88vh,860px);padding:clamp(20px,3vw,36px);display:grid;position:relative;overflow:auto}.image-modal-close{z-index:1;color:#2c2926;cursor:pointer;background:#fffdf8;border:1px solid #d9c4b7;border-radius:999px;grid-column:1/-1;justify-content:center;justify-self:end;align-items:center;width:48px;height:48px;margin:-8px -8px -12px auto;font-size:1.7rem;line-height:1;display:inline-flex;position:sticky;top:0}.image-modal-close:hover,.image-modal-close:focus-visible{color:#ad6651;border-color:#b96f58}.image-modal-media{background:#fff;border:1px solid #efe4da;border-radius:6px;justify-content:center;align-items:center;min-height:420px;display:flex}.image-modal-media img{object-fit:contain;max-width:100%;max-height:min(68vh,680px)}.image-modal-body{align-self:center}.modal-labels{margin-bottom:12px}.image-modal-body h2{font-size:clamp(1.8rem,3vw,2.6rem)}.image-modal-body p{color:#6f6960}.fanart-rights-note{background:#fffdf8;border:1px solid #efe4da;border-radius:4px;margin:18px 0 0;padding:12px 14px;font-size:.9rem;line-height:1.75}.modal-meta{margin-top:24px}.modal-usage-note{background:#fffaf5;border:1px solid #efe4da;border-radius:4px;margin:22px 0 0;padding:14px 16px;font-size:.9rem;line-height:1.75}.about-section,.about-preview,.activity-section,.usage-policy-section{border-top:0;border-bottom:0}.about-section{grid-template-columns:.8fr 1.2fr;gap:clamp(28px,6vw,80px);display:grid}.profile-detail-section{grid-template-columns:minmax(0,1fr)}.profile-detail-section .about-content{max-width:900px}.about-preview{grid-template-columns:minmax(0,.9fr) minmax(0,.7fr);align-items:center;gap:clamp(40px,8vw,120px);display:grid}.about-preview:after{content:"";background:linear-gradient(#0000,#ac5f4c14,#0000);border-left:0;align-self:stretch;min-height:320px}.genre-list{flex-wrap:wrap;gap:12px;margin-top:34px;display:flex}.genre-list span{color:#73584f;background:#fffcf76b;border:1px solid #eadbd0;border-radius:999px;padding:9px 15px;font-size:.86rem;font-weight:800}.about-content{gap:18px;font-size:1.02rem;display:grid}.profile-list{gap:10px;margin:8px 0 0;display:grid}.profile-list div{border-top:1px solid #e5d8cc;grid-template-columns:minmax(120px,.34fr) minmax(0,1fr);gap:18px;padding-top:12px;display:grid}.profile-list dt,.profile-list dd{margin:0}.profile-list dt{color:#73574c;font-size:.88rem;font-weight:800}.profile-list dd{color:#4e463f}.notice-card{color:#6e463a;background:#fff9f4;border:1px solid #e5d8cc;border-radius:6px;padding:18px 20px;font-weight:700}.usage-policy-section{grid-template-columns:minmax(0,1fr);gap:clamp(28px,6vw,80px);display:grid}.usage-policy-card{background:#fffdf8ad;border:1px solid #e5d8cc;border-radius:6px;gap:16px;max-width:940px;padding:28px;display:grid}.contact-card{background:#fffdf8ad;border:1px solid #e5d8cc;border-radius:6px;gap:18px;width:100%;min-width:0;max-width:900px;padding:28px;display:grid}.contact-card p{color:#5f5850;overflow-wrap:anywhere;margin:0}.contact-list{gap:10px;margin:6px 0 0;display:grid}.contact-list div{border-top:1px solid #e5d8cc;grid-template-columns:minmax(96px,.22fr) minmax(0,1fr);gap:18px;padding-top:14px;display:grid}.contact-list dt,.contact-list dd{margin:0}.contact-list dt{color:#73574c;font-size:.88rem;font-weight:800}.contact-list dd{color:#342b25;overflow-wrap:anywhere;word-break:break-all;font-weight:700}.contact-note{font-size:.9rem}.usage-policy-card p{color:#5f5850;margin:0}.activity-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.site-overview-section{border-top:0}.overview-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:22px;display:grid}.overview-card{background:#fffdf8ad;border:1px solid #e5d8cc;border-radius:6px;padding:30px}.overview-card span{color:#a45f4c;margin-bottom:14px;font-size:1rem;font-weight:800;display:block}.overview-card p{color:#6a6158;margin:0}.activity-card{background:#fffdf8ad;min-height:210px}.activity-card h3{font-size:1.16rem}.links-section{text-align:center}.gallery-filter-section{width:min(1240px,100% - 64px);margin:0 auto;padding:18px 0 28px}.category-nav{flex-wrap:wrap;gap:10px;display:flex}.category-nav a{color:#60483f;background:#fffdf894;border:1px solid #dfd0c5;border-radius:999px;padding:10px 16px;font-size:.9rem;font-weight:800}.category-nav a.active{color:#fff;background:#a85f4c;border-color:#a85f4c}.empty-message{color:#6a6158;background:#fffdf89e;border:1px solid #e5d8cc;border-radius:6px;padding:24px}.category-error{margin-top:20px}.text-link{color:#a45f4c;margin-top:10px;font-weight:800;display:inline-flex}.links-section .section-heading{margin-left:auto;margin-right:auto}.link-list{text-align:left;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;display:grid}.link-list a{color:#473d36;font-weight:700}.link-card{background:#fffdf89e;min-height:188px}.link-card span{color:#a45f4c;margin-bottom:14px;font-size:1.18rem;font-weight:800;display:block}.link-card p{margin-bottom:0;font-size:.92rem;font-weight:500}.link-card small{color:#756d65;border-top:1px solid #e5d8cc;margin-top:24px;padding-top:12px;font-size:.8rem;font-weight:700;display:inline-flex}.official-link-note{color:#5f5850;text-align:left;background:#fffdf8b8;border:1px solid #e5d8cc;border-radius:6px;max-width:900px;margin:32px auto 0;padding:18px 20px}.site-footer{color:#716a62;border-top:1px solid #e5d8cc;gap:24px;width:min(1240px,100% - 64px);margin:0 auto;padding:76px 0 78px;display:grid}.footer-brand{max-width:760px}.footer-brand strong{color:#29231f;margin-bottom:12px;font-size:1.24rem;display:block}.footer-brand p{margin-bottom:0}.footer-links{flex-wrap:wrap;gap:10px 24px;font-size:.9rem;font-weight:800;display:flex}.footer-official-note{color:#5f5850;background:#fffdf8b8;border:1px solid #e5d8cc;border-radius:2px;max-width:760px;margin:0;padding:14px 16px;font-size:.9rem}.footer-notice{color:#6f6960;border-top:1px solid #e5d8cc;max-width:860px;margin:0;padding-top:18px;font-size:.9rem}@media (width<=920px){.site-header{flex-direction:column;align-items:flex-start}.site-nav{justify-content:flex-start}.hero-section,.works-grid,.summary-grid,.about-preview,.link-list,.overview-grid,.usage-policy-section,.about-section{grid-template-columns:1fr}.featured-works-grid-section .works-grid,.works-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.image-modal{grid-template-columns:1fr}.image-modal-media{min-height:360px}.hero-section{min-height:auto;padding-top:70px;padding-bottom:110px}.hero-visual img{max-width:100%;height:620px;min-height:480px}.activity-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=560px){.site-header,.hero-section,.page-hero,.section,.site-footer,.gallery-filter-section{width:min(100% - 32px,1240px)}.site-header{padding:20px 0 16px}.site-nav{gap:8px 14px;font-size:.86rem}.category-nav{scrollbar-width:none;flex-wrap:nowrap;padding-bottom:6px;overflow-x:auto}.category-nav::-webkit-scrollbar{display:none}.category-nav a{flex:none}h1{font-size:clamp(2.85rem,14vw,4.25rem);line-height:1.04}.hero-copy h1{font-size:clamp(1.95rem,8vw,2.28rem)}h2{font-size:clamp(2rem,10vw,3rem)}.hero-section{gap:34px;padding-top:58px;padding-bottom:104px}.hero-visual img{max-width:108%;height:520px;min-height:420px}.page-hero{padding-top:56px}.section{padding:104px 0}.section-heading{margin-bottom:42px}.hero-actions{gap:10px;margin-top:34px}.button{min-height:56px}.activity-grid,.featured-works-grid-section .works-grid,.works-grid{grid-template-columns:1fr}.work-image-frame{width:calc(100% - 28px);height:360px;margin:14px 14px 0}.work-card-body{padding:24px 22px 26px}.profile-list div,.contact-list div{grid-template-columns:1fr;gap:4px}.image-modal-overlay{min-height:100dvh;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom));align-items:stretch}.image-modal{width:min(100%,100vw - 24px);height:calc(100dvh - 24px - env(safe-area-inset-bottom));max-height:calc(100dvh - 24px - env(safe-area-inset-bottom));grid-template-rows:auto auto minmax(0,1fr);gap:14px;margin:auto;padding:14px;overflow:hidden}.image-modal-close{width:42px;height:42px;margin:-2px -2px -2px auto;font-size:1.45rem;position:sticky;top:0}.image-modal-media{min-height:0;max-height:min(45dvh,360px);padding:8px}.image-modal-media img{object-fit:contain;width:auto;max-height:min(45dvh,340px)}.image-modal-body{min-height:0;padding:0 2px calc(10px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch;align-self:stretch;overflow-y:auto}.button,.link-list a{width:100%}}
