@import url('https://fonts.googleapis.com/css2?family=DotGothic16&family=Noto+Sans+JP:wght@400;600;700;900&display=swap');
.site-header--no-brand{justify-content:flex-end}
:root{--b-navy:#101522;--b-deep:#080c15;--b-blue:#153553;--b-cream:#fff8e8;--b-gold:#f3bd3b;--b-wood:#9f5b32;--b-pixel:'DotGothic16',sans-serif;--b-sans:'Noto Sans JP',sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;color:#182839;background:var(--b-cream);font-family:var(--b-sans);line-height:1.85}a{color:inherit}.site-header{position:absolute;z-index:20;top:0;left:0;width:100%;display:flex;align-items:center;justify-content:space-between;padding:22px clamp(20px,5vw,72px);color:#fff}.site-brand{display:flex;align-items:center;gap:12px;color:#fff;text-decoration:none;font:700 20px var(--b-pixel)}.site-brand__mark{display:grid;place-items:center;width:38px;height:38px;border:2px solid #fff;background:#0e5790;box-shadow:4px 4px 0 #00152b}.site-nav{display:flex;gap:30px;font-size:13px;font-weight:700}.site-nav a{text-decoration:none;border-bottom:1px solid transparent}.site-nav a:hover{border-color:#fff}.building-inner{width:min(1120px,calc(100% - 48px));margin:auto}.building-hero{position:relative;display:grid;align-items:end;min-height:670px;overflow:hidden;padding:150px 0 95px;color:#fff;background:radial-gradient(circle at 50% 95%,#315a70 0,#182b3f 30%,#0c111c 72%)}.building-hero:before{content:"";position:absolute;inset:0;opacity:.22;background-image:linear-gradient(90deg,transparent 47%,rgba(255,255,255,.1) 48%,rgba(255,255,255,.1) 52%,transparent 53%),linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:72px 72px,100% 36px;clip-path:polygon(0 14%,12% 4%,24% 14%,37% 3%,50% 15%,64% 3%,77% 13%,89% 4%,100% 14%,100% 100%,0 100%)}.building-hero:after{content:"";position:absolute;left:50%;bottom:-130px;width:660px;height:330px;border:20px solid rgba(243,189,59,.22);border-radius:50% 50% 0 0;transform:translateX(-50%);box-shadow:0 0 80px rgba(243,189,59,.12)}.building-hero__glow{position:absolute;left:50%;bottom:0;width:180px;height:270px;background:linear-gradient(90deg,transparent,rgba(255,198,89,.25),transparent);transform:translateX(-50%);filter:blur(10px)}.building-hero__inner{position:relative;z-index:2}.building-back{display:inline-block;margin-bottom:55px;color:#d7e2e8;font:700 13px var(--b-pixel);text-underline-offset:6px}.building-eyebrow{margin:0 0 12px;color:var(--b-gold);font:700 11px var(--b-sans);letter-spacing:.22em}.building-hero h1{margin:0;font:900 clamp(62px,10vw,126px)/1 var(--b-pixel);letter-spacing:.04em;text-shadow:7px 7px 0 #02050a}.building-hero__lead{margin:28px 0 0;font:700 clamp(20px,3vw,35px)/1.55 var(--b-pixel)}.building-section{padding:100px 0}.building-section h2,.building-contact h2{margin:0 0 42px;font:700 clamp(30px,4vw,46px)/1.5 var(--b-pixel)}.building-section--intro{color:#fff;background:var(--b-deep)}.building-intro-grid{display:grid;grid-template-columns:220px 1fr;gap:65px;align-items:start}.building-npc{position:relative;height:320px;border:3px solid #fff;background:linear-gradient(#173b58 0 70%,#442f25 70%);box-shadow:10px 10px 0 #24344a}.building-npc:before{content:"";position:absolute;inset:16px;background:repeating-linear-gradient(90deg,transparent 0 25px,rgba(255,255,255,.06) 26px 28px)}.building-npc span{position:absolute;left:50%;bottom:42px;width:72px;height:112px;background:#1b6a9e;transform:translateX(-50%);box-shadow:inset 0 -26px #173750}.building-npc span:before{content:"";position:absolute;left:11px;top:-55px;width:50px;height:54px;border:5px solid #fff;background:#e8ac6b;box-shadow:inset 0 14px #523425}.building-npc span:after{content:"";position:absolute;left:-24px;bottom:40px;width:120px;height:10px;background:#d7d2b8;box-shadow:0 8px #70513b}.building-dialogue{position:relative;padding:30px 34px;border:3px solid #fff;border-radius:4px;background:#101522;box-shadow:0 0 0 7px #101522,0 0 0 9px #fff}.building-dialogue:before{content:"";position:absolute;left:-24px;top:45px;border:12px solid transparent;border-right-color:#fff}.building-dialogue__name{margin:-3px 0 16px;color:var(--b-gold);font:700 17px var(--b-pixel)}.building-dialogue p:last-child{margin:0;font:700 18px/1.9 var(--b-pixel)}.building-intro{margin-top:50px;color:#cfd8df}.building-intro p{margin:0 0 18px}.building-section--services{background:#f6ead0}.building-service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.building-service-grid article{min-height:145px;padding:23px;border:2px solid var(--b-navy);background:#fff;box-shadow:6px 6px 0 var(--b-navy)}.building-service-grid span{color:#a06b3d;font:700 12px var(--b-pixel)}.building-service-grid h3{margin:28px 0 0;font:700 16px/1.55 var(--b-pixel)}.building-section--works{background:#fffaf0}.building-works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.building-works-grid article{border:1px solid #d6c8af;background:#fff}.building-work-image{display:grid;place-items:center;aspect-ratio:16/10;overflow:hidden;color:#fff;background:var(--b-blue);font-size:40px;text-decoration:none}.building-work-image img{width:100%;height:100%;object-fit:cover;transition:.25s}.building-work-image:hover img{transform:scale(1.04)}.building-works-grid article>p,.building-works-grid article>h3{margin-right:20px;margin-left:20px}.building-works-grid article>p{margin-top:20px;margin-bottom:0;color:#9f6d43;font-size:10px;letter-spacing:.16em}.building-works-grid article>h3{margin-top:7px;margin-bottom:22px;font-size:15px}.building-works-grid h3 a{text-decoration:none}.building-work-placeholder{border:0}.building-contact{padding:110px 0;color:#fff;background:var(--b-navy);text-align:center}.building-contact p:not(.building-eyebrow){color:#c9d5de}.building-button{display:inline-flex;align-items:center;justify-content:center;min-height:62px;margin:24px 0;padding:14px 30px;border:3px solid #fff;color:var(--b-navy);background:var(--b-gold);box-shadow:7px 7px 0 #000;font:700 16px var(--b-pixel);text-decoration:none;transition:.18s}.building-button:hover{transform:translate(-2px,-2px);box-shadow:9px 9px 0 #000}.building-contact__back{display:block;width:max-content;margin:24px auto 0;color:#d0dbe3;font:700 13px var(--b-pixel);text-underline-offset:6px}.site-footer{padding:42px 24px;color:#aabac7;background:#050812;text-align:center}.site-footer p{color:#fff}.site-footer nav{display:flex;justify-content:center;flex-wrap:wrap;gap:25px;margin:18px}.site-footer a{font-size:12px}
@media(max-width:900px){.site-nav{display:none}.building-intro-grid{grid-template-columns:160px 1fr;gap:40px}.building-npc{height:280px}.building-service-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:650px){.building-inner{width:min(100% - 36px,1120px)}.building-hero{min-height:570px;padding:120px 0 70px}.building-hero h1{font-size:58px}.building-back{margin-bottom:40px}.building-section{padding:72px 0}.building-intro-grid{grid-template-columns:1fr}.building-npc{width:150px;height:210px;margin:auto}.building-dialogue:before{display:none}.building-dialogue{padding:24px 20px}.building-dialogue p:last-child{font-size:15px}.building-service-grid{grid-template-columns:1fr 1fr;gap:12px}.building-service-grid article{min-height:125px;padding:17px}.building-service-grid h3{margin-top:20px;font-size:13px}.building-works-grid{grid-template-columns:1fr}.building-contact{padding:80px 0}.site-footer{padding-bottom:90px}}

/* Ver.6: WEB工房 室内探索マップ */
body.is-room-modal-open{overflow:hidden}#web-about,#web-services,#web-works,#web-contact{scroll-margin-top:20px}.rpg-room{padding:74px 0 56px;color:#fff;background:#0a111b}.rpg-room__heading{width:min(1120px,calc(100% - 48px));margin:0 auto 32px;text-align:center}.rpg-room__heading h2{margin:0;font:700 clamp(28px,4vw,44px)/1.5 var(--b-pixel)}.rpg-room__heading>p:last-child{margin:8px 0 0;color:#aebdca;font-size:13px}.rpg-room__scroll{overflow-x:auto;overscroll-behavior-inline:contain;scrollbar-color:var(--b-gold) #05080d;scrollbar-width:thin}.rpg-room__inner{position:relative;width:min(1180px,100%);min-width:900px;aspect-ratio:16/9;margin:auto;overflow:hidden;border-top:8px solid #06090f;border-bottom:8px solid #06090f;background:repeating-linear-gradient(90deg,transparent 0 78px,rgba(58,29,17,.38) 79px 82px),repeating-linear-gradient(0deg,#7c4b2c 0 38px,#6a3f25 39px 42px);box-shadow:inset 0 0 70px rgba(0,0,0,.7)}.rpg-room__inner:before{content:"";position:absolute;z-index:1;left:0;right:0;top:0;height:31%;border-bottom:10px solid #3d2418;background:repeating-linear-gradient(90deg,#25394a 0 76px,#1a2a38 77px 80px),repeating-linear-gradient(0deg,transparent 0 36px,rgba(255,255,255,.05) 37px 40px);box-shadow:0 12px 0 rgba(0,0,0,.25)}.rpg-room__wall{position:absolute;z-index:2;left:8%;right:8%;top:4%;height:21%;pointer-events:none}.rpg-room__wall i{position:absolute;top:0;width:12%;height:70%;border:5px solid #5f3a25;background:linear-gradient(#8dd2d1,#d5efdf 55%,#48769b 56%);box-shadow:5px 6px 0 rgba(0,0,0,.35)}.rpg-room__wall i:nth-child(1){left:8%}.rpg-room__wall i:nth-child(2){left:44%}.rpg-room__wall i:nth-child(3){right:8%}.rpg-room__rug{position:absolute;z-index:1;left:32%;top:43%;width:36%;height:43%;border:7px solid #d7a738;background:repeating-linear-gradient(45deg,#224d69 0 18px,#173b58 19px 36px);box-shadow:0 8px 0 rgba(0,0,0,.25)}.rpg-room-object{position:absolute;z-index:5;display:flex;flex-direction:column;align-items:center;gap:4px;padding:0;border:0;color:#fff;background:transparent;cursor:pointer;transition:transform .18s,filter .18s}.rpg-room-object:hover,.rpg-room-object:focus-visible{z-index:8;transform:translateY(-7px);filter:drop-shadow(0 0 12px rgba(243,189,59,.95));outline:none}.rpg-room-object:focus-visible .rpg-room-object__label{outline:3px solid var(--b-gold);outline-offset:3px}.rpg-room-object__sprite{display:grid;place-items:center;width:94px;height:94px;border:4px solid #392219;background:#9b6741;box-shadow:inset 0 -15px rgba(0,0,0,.18),6px 7px 0 rgba(0,0,0,.38);font-size:46px;line-height:1}.rpg-room-object__label{min-width:max-content;padding:5px 9px;border:2px solid #fff;background:#101522;box-shadow:3px 3px 0 #000;font:700 11px var(--b-pixel)}.rpg-room-object--npc{left:23%;top:43%}.rpg-room-object--npc .rpg-room-object__sprite{border:0;background:transparent;box-shadow:none;font-size:64px}.rpg-room-object--shelf{right:10%;top:23%}.rpg-room-object--shelf .rpg-room-object__sprite{width:145px;height:115px;background:#6d3f25}.rpg-room-object--board{left:8%;top:16%}.rpg-room-object--board .rpg-room-object__sprite{width:130px;height:100px;background:#a87742}.rpg-room-object--counter{right:21%;top:60%}.rpg-room-object--counter .rpg-room-object__sprite{width:155px;height:80px;background:#744126}.rpg-room-object--door{left:50%;top:22%;transform:translateX(-50%)}.rpg-room-object--door:hover,.rpg-room-object--door:focus-visible{transform:translate(-50%,-7px)}.rpg-room-object--door .rpg-room-object__sprite{width:105px;height:140px;background:#3f271d}.rpg-room__hint{display:none;margin:15px 20px 0;color:#aebdca;font-size:12px}.rpg-room-modal{position:fixed;z-index:1100;inset:0;display:grid;place-items:center;padding:20px;visibility:hidden;opacity:0;transition:opacity .2s,visibility .2s}.rpg-room-modal[aria-hidden="false"]{visibility:visible;opacity:1}.rpg-room-modal__overlay{position:absolute;inset:0;background:rgba(0,4,10,.84);backdrop-filter:blur(4px)}.rpg-room-modal__window{position:relative;width:min(570px,100%);max-height:calc(100dvh - 40px);overflow:auto;padding:30px;border:3px solid #fff;border-radius:4px;color:#fff;background:#101522;box-shadow:0 0 0 7px #101522,0 0 0 10px #fff,14px 14px 0 rgba(0,0,0,.5);transform:scale(.96) translateY(10px);transition:transform .2s}.rpg-room-modal[aria-hidden="false"] .rpg-room-modal__window{transform:scale(1)}.rpg-room-modal__window h2{margin:0 42px 18px 0;font:900 30px var(--b-pixel)}.rpg-room-modal__window>p:not(.building-eyebrow){color:#d7e1e8}.rpg-room-modal__close{position:absolute;right:12px;top:12px;width:38px;height:38px;border:1px solid #fff;color:#fff;background:transparent;font-size:26px;cursor:pointer}.rpg-room-modal__button{display:inline-flex;min-height:52px;margin-top:15px;padding:11px 22px;align-items:center;border:2px solid #fff;color:#101522;background:var(--b-gold);box-shadow:5px 5px 0 #000;font:700 14px var(--b-pixel);text-decoration:none}
.building-intro__title{margin:0 0 24px!important;font:700 clamp(27px,4vw,40px)/1.5 var(--b-pixel)!important}
@media(max-width:768px){.rpg-room{padding:60px 0 42px}.rpg-room__scroll{scroll-padding-inline:16px}.rpg-room__inner{width:960px;min-width:960px;margin-left:0;margin-right:0}.rpg-room__hint{display:block}.rpg-room-object__label{font-size:12px}}
@media(max-width:600px){.rpg-room__heading{width:calc(100% - 36px)}.rpg-room-modal__window{padding:26px 20px}.rpg-room-modal__window h2{font-size:25px}.rpg-room-modal__button{width:100%;justify-content:center;text-align:center}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.rpg-room-object,.rpg-room-modal,.rpg-room-modal__window{transition:none}}

/* Ver.6.5: 生成画像＋HTMLホットスポットのWEB工房マップ。Ver.6プロトタイプCSSは上に保持。 */
.rpg-room-map{width:100%;padding:74px 0 56px;color:#fff;background:#070c14}.rpg-room-map__heading{width:min(1120px,calc(100% - 48px));margin:0 auto 32px;text-align:center}.rpg-room-map__heading h2{margin:0;font:700 clamp(28px,4vw,44px)/1.5 var(--b-pixel)}.rpg-room-map__heading>p:last-child{margin:8px 0 0;color:#aebdca;font-size:13px}.rpg-room-map__scroll{width:100%;overflow-x:auto;overscroll-behavior-inline:contain;scrollbar-color:var(--b-gold) #05080d;scrollbar-width:thin}.rpg-room-map__wrap{position:relative;width:min(100%,1536px);margin:0 auto;overflow:hidden;background:#080d15}.rpg-room-map__image{display:block;width:100%;height:auto}.room-point{position:absolute;z-index:3;width:30px;height:30px;padding:0;border:3px solid #fff;border-radius:50%;color:#fff;background:var(--b-gold);box-shadow:0 0 0 5px rgba(16,21,34,.88),0 0 20px 7px rgba(243,189,59,.75);cursor:pointer;transform:translate(-50%,-50%);animation:room-point-pulse 2s ease-in-out infinite;transition:transform .18s,filter .18s}.room-point:after{content:"";position:absolute;inset:6px;border:2px solid #101522;border-radius:50%}.room-point span{position:absolute;left:50%;bottom:39px;min-width:max-content;padding:7px 11px;border:2px solid #fff;border-radius:4px;color:#fff;background:rgba(16,21,34,.94);box-shadow:4px 4px 0 rgba(0,0,0,.55);font:700 12px var(--b-pixel);transform:translateX(-50%)}.room-point:hover,.room-point:focus-visible{z-index:6;outline:3px solid #7ee0e2;outline-offset:5px;filter:brightness(1.16);transform:translate(-50%,-62%) scale(1.12)}.room-point--web-npc{left:22%;top:31%}.room-point--web-services{left:52%;top:28%}.room-point--web-works{left:20%;top:72%}.room-point--web-contact{left:76%;top:69%}.room-point--web-exit{left:82%;top:22%}.rpg-room-map__hint{display:none;margin:15px 20px 0;color:#aebdca;font-size:12px}@keyframes room-point-pulse{50%{box-shadow:0 0 0 5px rgba(16,21,34,.88),0 0 9px 3px rgba(243,189,59,.5)}}
@media(max-width:768px){.rpg-room-map{padding:60px 0 42px}.rpg-room-map__scroll{scroll-padding-inline:16px}.rpg-room-map__wrap{width:1200px;max-width:none;margin:0}.room-point{width:34px;height:34px}.room-point span{padding:7px 10px;font-size:13px}.rpg-room-map__hint{display:block}}
@media(max-width:600px){.rpg-room-map__heading{width:calc(100% - 36px)}}
@media(prefers-reduced-motion:reduce){.room-point{animation:none;transition:none}}

/* Ver.6.6: WEB工房を室内マップだけで完結させる */
.screen-reader-text{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.site-header--room{position:relative;background:#050812}.rpg-room-map--web{display:block;min-height:0;padding:40px 0 24px}.rpg-room-map--web .rpg-room-map__scroll{width:100%}.rpg-room-map--web .rpg-room-map__wrap{position:relative;width:min(100%,1400px);max-width:1400px;margin:0 auto}.rpg-room-map--web .rpg-room-map__image{display:block;width:100%;height:auto}.rpg-room-map--web .rpg-room-map__hint{display:none}.rpg-room-intro{max-width:900px;margin:0 auto 32px;padding:0 24px;text-align:center}.rpg-room-intro h1{margin:0;font:900 clamp(32px,5vw,56px)/1.35 var(--b-pixel);text-shadow:4px 4px 0 #000}.rpg-room-intro__catch{margin:12px 0 14px;font:700 20px/1.7 var(--b-pixel)}.rpg-room-intro__text{margin:0;color:#cbd7df;font-size:16px}.rpg-room-intro__guide{margin:18px 0 0;color:var(--b-gold);font:700 12px var(--b-pixel)}.rpg-room-intro__guide span{display:none}.room-point{display:block;text-decoration:none}.rpg-room-modal__list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:20px 0 6px;padding:0;list-style:none}.rpg-room-modal__list li{padding:8px 10px;border:1px solid #536275;background:#080c15;font:700 12px var(--b-pixel)}button.rpg-room-modal__button{cursor:pointer}.site-footer--rpg{padding:12px 24px;color:#718391;background:#050812}
@media(max-width:768px){.rpg-room-map--web{padding:32px 0 16px}.rpg-room-map--web .rpg-room-map__scroll{overflow-x:auto}.rpg-room-map--web .rpg-room-map__wrap{width:1000px;max-width:none}.rpg-room-map--web .rpg-room-map__hint{margin-bottom:0}.rpg-room-intro{margin-bottom:24px}.rpg-room-intro__guide span{display:block;margin-top:8px}.rpg-room-intro__text br{display:none}}
@media(max-width:600px){.rpg-room-modal__list{grid-template-columns:1fr}.site-footer--rpg{padding:10px 90px 70px 18px}}

/* Ver.6.7.2: WEB工房の余白とフッターを濃紺で最下部へ揃える */
html{min-height:100%;background:#07101b}body.rpg-building-page--web{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:#07101b}body.rpg-building-page--web>#main-content{flex:1 0 auto;background:#07101b}body.rpg-building-page--web .rpg-building--web-workshop{background:#07101b}body.rpg-building-page--web .site-footer--rpg{flex-shrink:0;margin-top:auto;background:#070b15}
