@charset "utf-8";
@import url(''https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100..900&family=Noto+Serif+KR:wght@200..900&display=swap'');

.sub_wrap{background:linear-gradient(180deg,#f8f4ee 0%,#f4f1ea 180px,#f7f4ef 100%);}
.sub_hero{position:relative; min-height:440px; overflow:hidden; color:#fff; z-index:0;}
.sub_hero .sub_visual_img{position:absolute; inset:0; background-position:center center; background-repeat:no-repeat; background-size:cover; transform:scale(1.03);}
.sub_visual_img01{background-image:url("../images/sub/sub_visual01.jpg");}
.sub_visual_img02{background-image:url("../images/sub/sub_visual02.jpg");}
.sub_visual_img03{background-image:url("../images/sub/sub_visual03.jpg");}
.sub_visual_img04{background-image:url("../images/sub/sub_visual04.jpg");}
.sub_visual_img05{background-image:url("../images/sub/sub_visual05.jpg");}
.sub_visual_img06{background-image:url("../images/sub/sub_visual06.jpg");}
.sub_visual_img07{background-image:url("../images/sub/company_visual.jpg");}
.sub_hero_overlay{position:absolute; inset:0; background:linear-gradient(115deg,rgba(15,14,11,.42) 0%,rgba(15,14,11,.10) 48%,rgba(15,14,11,.24) 100%),linear-gradient(180deg,rgba(0,0,0,.01) 0%,rgba(0,0,0,.10) 100%);}
.sub_hero .inner{position:relative; z-index:1; min-height:440px; display:flex; align-items:flex-end;}
.sub_visual_txt{padding:0 0 78px; max-width:760px;}
.sub_hero_eyebrow{display:inline-flex; align-items:center; gap:10px; font-size:13px; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:rgba(255,255,255,.78);}
.sub_hero_eyebrow:before{content:''; width:42px; height:1px; background:rgba(255,255,255,.55);}
.sub_visual_txt h2{margin-top:18px; font-size:58px; line-height:1.08; letter-spacing:-0.04em; font-weight:800; color:#fff;}
.sub_visual_txt p{margin-top:18px; font-size:19px; line-height:1.8; color:rgba(255,255,255,.86);}
.sub_nav_section{position:relative; margin-top:-34px; z-index:5;}
.sub_nav_shell{padding:18px 22px; border-radius:22px; background:rgba(255,255,255,.94); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); box-shadow:0 16px 34px rgba(24,32,45,.08); border:1px solid rgba(255,255,255,.72); display:flex; gap:22px; align-items:flex-start;}
.sub_nav_group{flex:1; min-width:0;}
.sub_nav_group_secondary{padding-left:22px; border-left:1px solid rgba(31,36,48,.07);}
.sub_nav_label{display:block; margin-bottom:10px; font-size:11px; line-height:1; font-weight:800; letter-spacing:.18em; color:#8b7f6e;}
.sub_nav_depth1,.sub_nav_depth2{display:flex; flex-wrap:wrap; gap:8px;}
.sub_nav_depth1 li,.sub_nav_depth2 li{min-width:0;}
.sub_nav_depth1 a,.sub_nav_depth2 a{display:flex; align-items:center; justify-content:center; min-height:40px; padding:0 15px; border-radius:999px; border:1px solid rgba(31,36,48,.09); background:#fff; color:#2a2f38; font-size:14px; font-weight:600; box-shadow:0 6px 14px rgba(15,14,11,.03); transition:all .22s ease;}
.sub_nav_depth1 li.is-active a{background:linear-gradient(135deg,#b9975b 0%,#8f7242 100%); border-color:transparent; color:#fff; box-shadow:0 10px 18px rgba(143,114,66,.16);}
.sub_nav_depth2 li.is-active a{background:linear-gradient(135deg,#1f2937 0%,#334155 100%); border-color:transparent; color:#fff; box-shadow:0 10px 20px rgba(31,41,55,.18);}
.sub_nav_depth1 a:hover{transform:translateY(-2px); border-color:rgba(185,151,91,.35); background:rgba(185,151,91,.08); color:#8f7242;}
.sub_nav_depth2 a:hover{transform:translateY(-2px); border-color:rgba(51,65,85,.18); background:rgba(51,65,85,.08); color:#334155; box-shadow:0 8px 18px rgba(31,41,55,.08);}
.sub_nav_depth1 li.is-active a:hover,.sub_nav_depth2 li.is-active a:hover{color:#fff;}
.sub_main{padding:90px 0 110px;}
.sub_intro_block{display:grid; grid-template-columns:1.05fr .95fr; gap:30px; align-items:stretch;}
.sub_intro_copy,.sub_intro_card,.sub_contact_card,.sub_form_card,.sub_gallery_board{background:#fff; border:1px solid rgba(31,36,48,.08); border-radius:28px; box-shadow:0 18px 44px rgba(17,24,39,.06);}
.sub_intro_copy{padding:44px 42px;}
.sub_intro_copy h3{font-size:42px; line-height:1.18; letter-spacing:-0.04em; color:#101722; font-weight:800;}
.sub_intro_copy p{margin-top:18px; font-size:17px; line-height:1.85; color:#4f5866; font-weight:500;}
.sub_intro_copy p strong{font-weight:700; color:#8f7242;}
.sub_intro_card{padding:32px; background:linear-gradient(145deg,#111827 0%,#1d2533 55%,#2d3a4f 100%); color:#fff; display:flex; flex-direction:column; justify-content:space-between;}
.sub_intro_card strong{font-size:15px; letter-spacing:.14em; color:rgba(255,255,255,.68);}
.sub_intro_card ul{margin-top:24px; display:grid; gap:14px;}
.sub_intro_card li{padding:16px 18px; border-radius:18px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.09); font-size:16px; color:rgba(255,255,255,.88);}
.sub_section{margin-top:30px;}
.sub_product_showcase{display:grid; grid-template-columns:minmax(360px,.92fr) minmax(0,1.08fr); gap:28px; align-items:stretch; margin-bottom:30px;}
.sub_product_showcase > *{height:100%;}
.sub_product_visual{margin:0; height:100%; display:flex;}
.sub_product_visual_frame{margin:0; position:relative; overflow:hidden; flex:1 1 auto; min-height:360px; height:100%; border-radius:30px; border:1px solid rgba(31,36,48,.08); background:linear-gradient(135deg,#efe7da 0%,#ddd1bd 100%); box-shadow:0 22px 46px rgba(17,24,39,.10);}
.sub_product_visual_frame img{display:block; width:100%; height:100%; object-fit:cover;}
.sub_product_visual_badge{position:absolute; left:24px; top:24px; display:inline-flex; align-items:center; min-height:38px; padding:0 16px; border-radius:999px; background:rgba(17,24,39,.68); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); color:#fff; font-size:12px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; box-shadow:0 12px 24px rgba(17,24,39,.16);}
.sub_product_summary{min-height:360px; height:100%; padding:38px 36px; border-radius:30px; background:linear-gradient(180deg,#fff 0%,#faf7f1 100%); border:1px solid rgba(31,36,48,.08); box-shadow:0 18px 40px rgba(17,24,39,.06); display:flex; flex-direction:column; justify-content:center;}
.sub_product_summary strong{display:inline-flex; align-items:center; gap:10px; font-size:12px; font-weight:800; letter-spacing:.18em; color:#8f7242; text-transform:uppercase;}
.sub_product_summary strong:before{content:''; width:28px; height:1px; background:rgba(143,114,66,.45);}
.sub_product_summary h3{margin-top:18px; font-size:42px; line-height:1.16; letter-spacing:-0.04em; color:#141922;}
.sub_product_summary p{margin-top:16px; font-size:17px; line-height:1.85; color:#5b6470;}
.sub_product_keyword{color:#8f7242; font-weight:900;}
.sub_product_summary h3 .sub_product_keyword{font-size:1.04em; letter-spacing:-0.03em;}
.sub_product_summary_list{margin-top:22px; display:grid; gap:12px;}
.sub_product_summary_list li{padding:16px 18px; border-radius:18px; background:rgba(185,151,91,.08); border:1px solid rgba(185,151,91,.18); font-size:15px; line-height:1.7; color:#4f5663;}
.sub_product_detail{display:grid; grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr); gap:24px; align-items:stretch;}
.sub_product_detail_main,.sub_product_detail_side{min-width:0; height:100%;}
.sub_product_detail_main{padding:34px 32px; border-radius:28px; background:linear-gradient(180deg,#fff 0%,#faf7f1 100%); border:1px solid rgba(31,36,48,.08); box-shadow:0 18px 40px rgba(17,24,39,.06);}
.sub_product_detail_title{margin-bottom:18px;}
.sub_product_detail_title strong{display:inline-flex; align-items:center; gap:10px; font-size:12px; font-weight:800; letter-spacing:.18em; color:#8f7242; text-transform:uppercase;}
.sub_product_detail_title strong:before{content:''; width:26px; height:1px; background:rgba(143,114,66,.45);}
.sub_product_detail_title h4{margin-top:12px; font-size:30px; line-height:1.2; letter-spacing:-0.03em; color:#171c24;}
.sub_product_detail_side .sub_intro_card{height:100%;}
.sub_product_case_cta{margin-top:34px; margin-bottom:0; display:flex; align-items:center; justify-content:center; transform:translateY(38px);}
.sub_product_case_btn{position:relative; display:inline-flex; align-items:center; justify-content:center; gap:14px; min-width:260px; min-height:62px; padding:0 34px; border-radius:999px; background:linear-gradient(135deg,#1f2937 0%,#344255 100%); color:#fff; font-size:17px; font-weight:800; letter-spacing:-0.02em; box-shadow:0 18px 30px rgba(31,41,55,.24), 0 0 0 8px rgba(185,151,91,.10); transition:transform .25s ease, box-shadow .25s ease, background .25s ease, letter-spacing .25s ease; animation:subProductCaseGlow 2.6s ease-in-out infinite;}
.sub_product_case_btn:before{content:''; position:absolute; inset:-10px; border-radius:999px; background:radial-gradient(circle,rgba(185,151,91,.28) 0%,rgba(185,151,91,.14) 38%,rgba(185,151,91,0) 72%); z-index:-1; animation:subProductCasePulse 2.6s ease-in-out infinite;}
.sub_product_case_btn:after{content:'+'; display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.16); font-size:18px; font-weight:600; transition:transform .25s ease, background .25s ease;}
.sub_product_case_btn:hover{transform:translateY(-4px) scale(1.02); box-shadow:0 24px 38px rgba(31,41,55,.28), 0 0 0 10px rgba(185,151,91,.16); background:linear-gradient(135deg,#8f7242 0%,#c4a063 100%); color:#fff; letter-spacing:0;}
.sub_product_case_btn:hover:after{transform:rotate(90deg); background:rgba(255,255,255,.22);}
@keyframes subProductCaseGlow{
	0%,100%{box-shadow:0 18px 30px rgba(31,41,55,.24), 0 0 0 8px rgba(185,151,91,.10);}
	50%{box-shadow:0 22px 36px rgba(31,41,55,.28), 0 0 0 12px rgba(185,151,91,.15);}
}
@keyframes subProductCasePulse{
	0%,100%{transform:scale(.96); opacity:.7;}
	50%{transform:scale(1.04); opacity:1;}
}
.sub_section_title{margin-bottom:20px; display:flex; align-items:end; justify-content:space-between; gap:16px;}
.sub_section_title h4{font-size:30px; line-height:1.2; color:#171c24; letter-spacing:-0.03em;}
.sub_section_title p{font-size:15px; color:#6b7380;}
.sub_feature_grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px;}
.sub_feature_item{height:100%; padding:28px 26px; background:linear-gradient(180deg,#fff 0%,#f8f4ed 100%); border:1px solid rgba(31,36,48,.08); border-radius:24px;}
.sub_feature_item strong{display:block; font-size:24px; color:#171c24; letter-spacing:-0.04em;}
.sub_feature_item p{margin-top:12px; font-size:15px; line-height:1.8; color:#5e6572;}
.sub_bullet_list{display:grid; gap:14px;}
.sub_bullet_list li{position:relative; padding:22px 24px 22px 58px; background:#fff; border:1px solid rgba(31,36,48,.08); border-radius:22px; font-size:16px; line-height:1.8; color:#535c68;}
.sub_bullet_list li:before{content:''; position:absolute; left:22px; top:25px; width:22px; height:22px; border-radius:50%; background:linear-gradient(135deg,#b9975b 0%,#8f7242 100%); box-shadow:0 10px 20px rgba(143,114,66,.22);}
.sub_bullet_list li:after{content:''; position:absolute; left:30px; top:32px; width:6px; height:6px; border-radius:50%; background:#fff;}
.sub_contact_grid,.sub_estimate_grid{display:grid; grid-template-columns:1.08fr .92fr; gap:22px;}
.sub_contact_card,.sub_form_card,.sub_gallery_board{padding:34px 32px;}
.sub_map_layout{align-items:stretch;}
.sub_map_board{padding:28px; height:100%; display:flex; flex-direction:column;}
.sub_map_sidebar{display:flex; flex-direction:column; height:100%;}
.sub_map_embed{overflow:hidden; border-radius:24px; border:1px solid rgba(31,36,48,.08); background:#f7f4ef; box-shadow:0 16px 34px rgba(17,24,39,.06);}
.sub_map_embed .root_daum_roughmap{width:100% !important;}
.sub_map_embed .wrap_map{border:none !important;}
.sub_map_embed .wrap_controllers,
.sub_map_embed .border1,
.sub_map_embed .border2,
.sub_map_embed .border3,
.sub_map_embed .border4{display:none !important;}
.sub_map_sidebar .sub_contact_card{height:100%; display:flex; flex-direction:column; justify-content:space-between;}
.sub_contact_card dl{display:grid; grid-template-columns:110px 1fr; padding:14px 0; border-bottom:1px solid rgba(31,36,48,.08);}
.sub_contact_card dl:first-of-type{border-top:1px solid rgba(31,36,48,.08);}
.sub_contact_card dt{font-weight:700; color:#151a22;}
.sub_contact_card dd{color:#5e6572;}
.sub_cta_row{margin-top:24px; display:flex; flex-wrap:wrap; gap:12px;}
.sub_cta_row a{display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:0 20px; border-radius:999px; font-weight:700; font-size:15px;}
.sub_cta_primary{background:#1a2230; color:#fff;}
.sub_cta_kakao{background:#fee500; color:#231f20;}
.sub_contact_visual{position:relative; margin-top:26px; padding:24px; min-height:240px; border-radius:26px; overflow:hidden; background:
	radial-gradient(circle at 18% 18%, rgba(255,255,255,.42) 0%, rgba(255,255,255,0) 28%),
	linear-gradient(140deg,#1a2230 0%, #263247 52%, #d0ae73 140%);
	box-shadow:0 18px 36px rgba(17,24,39,.14);}
.sub_contact_visual_badge{display:inline-flex; align-items:center; min-height:34px; padding:0 14px; border-radius:999px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.88); font-size:12px; font-weight:800; letter-spacing:.18em; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);}
.sub_contact_visual_panel{position:absolute; inset:auto 24px 24px 24px; height:140px; border-radius:22px; background:linear-gradient(180deg,rgba(255,255,255,.12) 0%, rgba(255,255,255,.06) 100%); border:1px solid rgba(255,255,255,.12); overflow:hidden;}
.sub_contact_visual_glow{position:absolute; right:-10px; top:-12px; width:140px; height:140px; border-radius:50%; background:radial-gradient(circle,rgba(208,174,115,.34) 0%, rgba(208,174,115,0) 72%);}
.sub_contact_visual_orbit{position:absolute; border-radius:50%; border:1px solid rgba(255,255,255,.14);}
.sub_contact_visual_orbit01{width:170px; height:170px; right:-22px; top:-24px;}
.sub_contact_visual_orbit02{width:120px; height:120px; right:12px; top:8px;}
.sub_contact_visual_symbol{position:absolute; right:34px; bottom:26px; width:92px; height:92px; border-radius:28px; background:linear-gradient(180deg,rgba(255,255,255,.92) 0%, rgba(247,242,233,.88) 100%); box-shadow:0 18px 30px rgba(15,23,42,.20); transform:rotate(12deg);}
.sub_contact_visual_symbol_core{position:absolute; left:50%; top:50%; width:36px; height:36px; margin-left:-18px; margin-top:-18px; border-radius:50%; background:linear-gradient(135deg,#b9975b 0%, #8f7242 100%); box-shadow:0 0 0 10px rgba(185,151,91,.18);}
.sub_contact_visual_text{position:absolute; left:24px; bottom:24px; max-width:220px;}
.sub_contact_visual_text strong{display:block; color:#ffffff; font-size:22px; line-height:1.2; letter-spacing:-0.03em;}
.sub_contact_visual_text p{margin-top:8px; color:rgba(255,255,255,.78); font-size:13px; line-height:1.6; letter-spacing:-0.01em; text-transform:none;}
.sub_estimate_form{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px;}
.sub_estimate_form .full{grid-column:1 / -1;}
.sub_estimate_form label{display:block; margin-bottom:8px; font-size:14px; font-weight:700; color:#202632;}
.sub_estimate_form input,.sub_estimate_form select,.sub_estimate_form textarea{width:100%; border:1px solid rgba(31,36,48,.12); background:#fbfaf8; border-radius:16px; padding:15px 16px; font-size:15px; color:#29303a;}
.sub_estimate_form textarea{min-height:150px; resize:vertical;}
.sub_form_note{margin-top:16px; font-size:14px; color:#6b7380;}
.sub_form_submit{margin-top:20px; display:inline-flex; align-items:center; justify-content:center; min-width:190px; min-height:52px; border:none; border-radius:999px; background:linear-gradient(135deg,#b9975b 0%,#8f7242 100%); color:#fff; font-size:16px; font-weight:700;}
.sub_gallery_grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px;}
.sub_gallery_item{display:block; overflow:hidden; border-radius:24px; background:#fff; border:1px solid rgba(31,36,48,.08); box-shadow:0 16px 34px rgba(17,24,39,.06); color:inherit; transition:transform .24s ease, box-shadow .24s ease;}
.sub_gallery_item:hover{transform:translateY(-4px); box-shadow:0 22px 38px rgba(17,24,39,.1);}
.sub_gallery_item img{width:100%; height:280px; object-fit:cover;}
.sub_gallery_board_tall .sub_gallery_item img{height:340px;}
.sub_gallery_caption{padding:20px 22px 22px;}
.sub_gallery_caption strong{display:block; font-size:22px; color:#161c25;}
.sub_gallery_caption p{margin-top:8px; font-size:15px; line-height:1.75; color:#606977;}
.sub_case_view{display:grid; grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr); gap:28px; align-items:start;}
.sub_case_visual{overflow:hidden; border-radius:28px; border:1px solid rgba(31,36,48,.08); background:#fff; box-shadow:0 18px 40px rgba(17,24,39,.08);}
.sub_case_visual img{width:100%; height:100%; min-height:420px; object-fit:cover; display:block;}
.sub_case_summary{padding:34px 32px; background:linear-gradient(180deg,#ffffff 0%,#faf7f1 100%); border:1px solid rgba(31,36,48,.08); border-radius:28px; box-shadow:0 18px 40px rgba(17,24,39,.06);}
.sub_case_eyebrow{display:inline-flex; align-items:center; gap:10px; font-size:12px; font-weight:800; letter-spacing:.2em; color:#8f7242; text-transform:uppercase;}
.sub_case_eyebrow:before{content:''; width:28px; height:1px; background:rgba(143,114,66,.55);}
.sub_case_summary h3{margin-top:16px; font-size:40px; line-height:1.16; letter-spacing:-0.04em; color:#151a22;}
.sub_case_summary p{margin-top:16px; font-size:16px; line-height:1.85; color:#5e6673;}
.sub_case_meta{margin-top:26px; display:grid; gap:12px;}
.sub_case_meta dl{display:grid; grid-template-columns:100px 1fr; gap:10px; padding:12px 0; border-top:1px solid rgba(31,36,48,.08);}
.sub_case_meta dt{font-weight:700; color:#171c24;}
.sub_case_meta dd{color:#5d6672;}
.sub_case_section{margin-top:28px; padding:32px 30px; border-radius:28px; background:#fff; border:1px solid rgba(31,36,48,.08); box-shadow:0 16px 34px rgba(17,24,39,.05);}
.sub_case_section h4{font-size:28px; line-height:1.2; letter-spacing:-0.03em; color:#171c24;}
.sub_case_section p{margin-top:14px; font-size:16px; line-height:1.85; color:#5f6774;}
.sub_case_point_list{margin-top:18px; display:grid; gap:12px;}
.sub_case_point_list li{position:relative; padding:18px 18px 18px 52px; border-radius:20px; background:#faf7f1; border:1px solid rgba(31,36,48,.06); color:#545d69; line-height:1.75;}
.sub_case_point_list li:before{content:''; position:absolute; left:20px; top:25px; width:18px; height:18px; border-radius:50%; background:linear-gradient(135deg,#b9975b 0%,#8f7242 100%);}
.sub_case_nav_row{margin-top:26px; display:flex; justify-content:space-between; align-items:center; gap:16px;}
.sub_case_back{display:inline-flex; align-items:center; justify-content:center; min-height:46px; padding:0 20px; border-radius:999px; background:#1f2937; color:#fff; font-weight:700;}
.sub_case_category{font-size:14px; color:#7a8390;}
.sub_case_minimal{max-width:1120px; margin:0 auto;}
.sub_case_minimal_head{margin-bottom:28px;}
.sub_case_minimal_category{font-size:12px; font-weight:800; letter-spacing:.2em; text-transform:uppercase; color:#8f7242;}
.sub_case_minimal_head h3{margin-top:12px; font-size:42px; line-height:1.16; letter-spacing:-0.04em; color:#151a22;}
.sub_case_photo_stack{display:grid; gap:22px;}
.sub_case_photo{overflow:hidden; border-radius:18px; border:1px solid rgba(31,36,48,.08); background:#fff; box-shadow:0 18px 38px rgba(17,24,39,.06);}
.sub_case_photo img{display:block; width:100%; height:clamp(320px, 48vw, 620px); object-fit:cover;}
.sub_case_minimal_nav{margin-top:28px; display:flex; justify-content:center;}
.sub_notice_board{padding:34px 32px;}
.sub_notice_embed{margin-top:8px; border:1px dashed rgba(31,36,48,.18); border-radius:24px; background:linear-gradient(180deg,#fcfbf8 0%,#f7f4ee 100%); overflow:hidden;}
.sub_notice_embed_head{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:18px 22px; border-bottom:1px solid rgba(31,36,48,.08); background:rgba(255,255,255,.7);}
.sub_notice_embed_head strong{font-size:13px; letter-spacing:.18em; color:#8f7242;}
.sub_notice_embed_head span{font-size:14px; color:#69717d;}
.sub_notice_embed_body{padding:28px 22px; min-height:220px; display:flex; align-items:center; justify-content:center; background-image:linear-gradient(rgba(31,36,48,.03) 1px, transparent 1px); background-size:100% 32px;}
.sub_notice_embed_body code{display:block; width:100%; max-width:760px; padding:22px 24px; border-radius:18px; background:#1f2937; color:#f8fafc; font-size:14px; line-height:1.9; box-shadow:0 18px 36px rgba(17,24,39,.16);}
.sub_notice_toolbar{display:flex; justify-content:flex-end; margin-bottom:14px; font-size:14px; color:#6b7380;}
.sub_notice_toolbar strong{color:#171c24;}
.sub_notice_table{border-top:2px solid #1f2937; border-bottom:1px solid rgba(31,36,48,.1);}
.sub_notice_head,.sub_notice_row{display:grid; grid-template-columns:100px 1fr 140px; align-items:center; gap:16px;}
.sub_notice_head{padding:16px 18px; background:#f8f5ef; color:#5f6672; font-size:14px; font-weight:700;}
.sub_notice_row{padding:18px; border-top:1px solid rgba(31,36,48,.08); color:#202632; background:#fff; transition:background-color .2s ease, transform .2s ease;}
.sub_notice_row:hover{background:#fbfaf8; transform:translateY(-1px);}
.sub_notice_row .col_no{font-weight:700; color:#8f7242;}
.sub_notice_row .col_title{font-size:15px; line-height:1.65; color:#202632;}
.sub_notice_row .col_date{font-size:14px; color:#7b8491;}
.sub_notice_row.is-pinned{background:rgba(185,151,91,.06);}
.sub_notice_empty{margin-top:20px; padding:18px 20px; border-radius:18px; background:#f8f5ef; color:#66707d; font-size:14px; line-height:1.8;}

@media screen and (max-width:1400px){
	.wrap,.header_wrap01{min-width:0;}
	.inner{width:100%; padding:0 22px;}
	.sub_visual_txt h2{font-size:48px;}
	.sub_intro_block,.sub_contact_grid,.sub_estimate_grid,.sub_product_showcase,.sub_product_detail{grid-template-columns:1fr;}
}

@media screen and (max-width:1200px){
	.sub_nav_shell{flex-direction:column; gap:14px;}
	.sub_nav_group_secondary{padding-left:0; border-left:none; border-top:1px solid rgba(31,36,48,.08); padding-top:14px;}
	.sub_feature_grid,.sub_gallery_grid{grid-template-columns:1fr 1fr;}
}

@media screen and (max-width:1024px){
	.sub_hero{min-height:360px;}
	.sub_hero .inner{min-height:360px;}
	.sub_visual_txt{padding-bottom:58px;}
	.sub_visual_txt h2{font-size:40px;}
	.sub_visual_txt p{font-size:17px;}
	.sub_main{padding:72px 0 88px;}
	.sub_intro_copy,.sub_intro_card,.sub_contact_card,.sub_form_card,.sub_gallery_board{padding:28px 24px;}
	.sub_product_summary,.sub_product_detail_main{padding:30px 24px;}
	.sub_feature_grid,.sub_gallery_grid,.sub_estimate_form,.sub_case_view{grid-template-columns:1fr;}
	.sub_map_sidebar{height:auto;}
	.sub_map_sidebar .sub_contact_card{height:auto;}
	.sub_notice_board{padding:28px 24px;}
	.sub_notice_embed_head{padding:16px 18px;}
	.sub_notice_embed_body{padding:22px 18px;}
	.sub_case_summary,.sub_case_section{padding:28px 24px;}
	.sub_case_visual img{min-height:340px;}
	.sub_case_minimal_head h3{font-size:36px;}
}

@media screen and (max-width:768px){
	.inner{padding:0 16px;}
	.sub_hero{min-height:300px;}
	.sub_hero .inner{min-height:300px;}
	.sub_visual_txt h2{font-size:32px;}
	.sub_visual_txt p{font-size:15px; line-height:1.7;}
	.sub_nav_section{margin-top:-18px;}
	.sub_nav_shell{padding:14px 14px 16px; border-radius:18px; gap:12px;}
	.sub_nav_group_secondary{padding-top:12px;}
	.sub_nav_label{margin-bottom:8px; font-size:10px; letter-spacing:.16em;}
	.sub_nav_depth1,.sub_nav_depth2{gap:7px;}
	.sub_nav_depth1 a,.sub_nav_depth2 a{min-height:36px; padding:0 13px; font-size:13px; font-weight:600;}
	.sub_intro_copy h3{font-size:30px;}
	.sub_product_showcase > *{height:auto;}
	.sub_product_visual{display:block;}
	.sub_product_visual_frame,.sub_product_summary{min-height:300px;}
	.sub_product_visual_frame{border-radius:22px;}
	.sub_product_visual_badge{left:16px; top:16px; min-height:34px; padding:0 13px; font-size:11px;}
	.sub_product_summary,.sub_product_detail_main{padding:24px 20px; border-radius:22px;}
	.sub_product_summary h3{font-size:32px;}
	.sub_product_summary p{font-size:15px; line-height:1.75;}
	.sub_product_summary_list li{padding:14px 15px; border-radius:16px; font-size:14px;}
	.sub_product_detail_title h4{font-size:24px;}
	.sub_product_case_cta{margin-top:26px; margin-bottom:0; transform:translateY(34px);}
	.sub_product_case_btn{width:100%; min-width:0; min-height:56px; padding:0 22px; font-size:15px;}
	.sub_section_title{display:block;}
	.sub_section_title p{margin-top:8px;}
	.sub_contact_card dl{grid-template-columns:1fr; gap:4px;}
	.sub_contact_visual{padding:20px; min-height:200px; border-radius:22px;}
	.sub_contact_visual_panel{left:20px; right:20px; bottom:20px; height:118px; border-radius:18px;}
	.sub_contact_visual_symbol{width:74px; height:74px; right:20px; bottom:20px; border-radius:22px;}
	.sub_contact_visual_symbol_core{width:28px; height:28px; margin-left:-14px; margin-top:-14px; box-shadow:0 0 0 8px rgba(185,151,91,.18);}
	.sub_contact_visual_text{left:18px; bottom:18px; max-width:170px;}
	.sub_contact_visual_text strong{font-size:18px;}
	.sub_contact_visual_text p{font-size:11px;}
	.sub_case_summary h3{font-size:30px;}
	.sub_case_meta dl{grid-template-columns:1fr; gap:4px;}
	.sub_case_section h4{font-size:24px;}
	.sub_case_nav_row{display:block;}
	.sub_case_category{display:block; margin-top:10px;}
	.sub_case_minimal_head{margin-bottom:20px;}
	.sub_case_minimal_head h3{font-size:30px;}
	.sub_case_photo_stack{gap:16px;}
	.sub_case_photo{border-radius:14px;}
	.sub_case_photo img{height:clamp(240px, 58vw, 420px);}
	.sub_notice_embed_head{display:block;}
	.sub_notice_embed_head span{display:block; margin-top:6px;}
	.sub_notice_head{display:none;}
	.sub_notice_row{grid-template-columns:1fr; gap:8px; padding:16px 14px;}
	.sub_notice_row .col_no{font-size:13px;}
	.sub_notice_row .col_title{font-size:14px;}
	.sub_notice_row .col_date{font-size:13px;}
	.sub_notice_embed_body{min-height:180px;}
	.sub_notice_embed_body code{font-size:13px; padding:18px 16px;}
}

body.drawer-open .sub_nav_section,
.sub_nav_section.nav-hidden{
	opacity:0;
	visibility:hidden;
	pointer-events:none;
	z-index:-1 !important;
}

body.drawer-open .sub_hero,
.sub_hero.hero-hidden{
	opacity:0;
	visibility:hidden;
	pointer-events:none;
	z-index:-1 !important;
}

body.drawer-open .sub_nav_shell,
.sub_nav_section.nav-hidden .sub_nav_shell{
	transform:translateY(12px);
}

@media screen and (max-width:600px){
	.sub_visual_txt{padding-bottom:44px;}
	.sub_visual_txt h2{font-size:28px;}
	.sub_intro_copy,.sub_intro_card,.sub_contact_card,.sub_form_card,.sub_gallery_board{padding:24px 18px;}
	.sub_feature_item{padding:22px 18px;}
	.sub_bullet_list li{padding:18px 18px 18px 48px;}
	.sub_gallery_item img{height:220px;}
	.sub_gallery_board_tall .sub_gallery_item img{height:270px;}
}

@media screen and (max-width:420px){
	.sub_nav_shell{padding:12px 12px 14px; border-radius:16px;}
	.sub_nav_label{margin-bottom:8px;}
	.sub_nav_depth1 a,.sub_nav_depth2 a{min-height:34px; padding:0 12px; font-size:12px;}
	.sub_contact_card,.sub_form_card,.sub_gallery_board,.sub_intro_copy,.sub_intro_card{border-radius:20px;}
	.sub_section_title h4{font-size:24px;}
}
