*{margin:0;padding:0}
.ribbonWrap,.bannerContent,.ftWrap,.ftContent{box-sizing:border-box}
body{font-family:'Rubik',sans-serif;background:linear-gradient(135deg,#FCFEE9 0%,#fff 100%);color:#2a2a2a;line-height:1.6}
.topRibbon{background:linear-gradient(90deg,#0F576B 0%,#1a6d85 100%);padding:12px 0;box-shadow:0 2px 8px #0f576b26}
.ribbonWrap{max-width:1200px;margin:0 auto;padding:0 20px}
.mainNv{display:flex;gap:32px;justify-content:center;flex-wrap:wrap}
.mainNv .nvLink{color:#FCFEE9;text-decoration:none;font-size:15px;font-weight:400;padding:6px 12px;transition:background .2s ease,color .2s ease;border-radius:6px}
.mainNv .nvLink:hover{background:#fcfee91f;color:#fff}
.brandBanner{background:linear-gradient(135deg,#F6515D 0%,#ff6b77 50%,#F6515D 100%);padding:42px 0;box-shadow:0 4px 16px #f6515d33}
.bannerContent{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;gap:28px}
.logoBox{flex-shrink:0}
.siteLogo{width:110px;height:110px;display:block;background:#ffffff26;padding:14px;border-radius:8px;box-shadow:0 6px 18px #00000026}
.companyInfo{flex-grow:1}
.brandName{font-size:38px;font-weight:700;color:#fff;margin-bottom:6px;text-shadow:2px 2px 6px #0003}
.tagLine{font-size:16px;color:#FCFEE9;font-weight:400}
footer{background:linear-gradient(180deg,#0F576B 0%,#0a3d4d 100%);padding:38px 0 24px;margin-top:60px;box-shadow:0 -4px 14px #0f576b2e}
.ftWrap{max-width:1200px;margin:0 auto;padding:0 20px}
.ftContent{display:flex;flex-direction:column;gap:24px}
.ftLinks{display:flex;gap:28px;justify-content:center;flex-wrap:wrap;padding-bottom:18px;border-bottom:1px solid #fcfee933}
.ftLink{color:#FCFEE9;text-decoration:none;font-size:14px;transition:color .2s ease}
.ftLink:hover{color:#F6515D}
.ftContact{text-align:center}
.contactItem{color:#FCFEE9;font-size:14px;margin-bottom:6px}
.ftCopy{text-align:center;padding-top:14px;border-top:1px solid #fcfee926}
.ftCopy p{color:#fcfee9bf;font-size:13px}
.cookieBox{display:none;position:fixed;bottom:24px;left:24px;width:420px;max-width:calc(100vw - 48px);background:#fff;border-radius:8px;box-shadow:0 8px 24px #00000040;z-index:10000;opacity:0;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease}
.cookieBox.showing{opacity:1;transform:translateY(0)}
.ckContent{padding:24px}
.ckTitle{font-size:20px;font-weight:600;color:#0F576B;margin-bottom:10px}
.ckText{font-size:14px;color:#555;margin-bottom:18px;line-height:1.5}
.ckSections{margin-bottom:20px}
.ckSection{border-bottom:1px solid #e5e5e5}
.ckToggle{width:100%;background:none;border:none;padding:12px 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:14px;font-weight:500;color:#2a2a2a;font-family:'Rubik',sans-serif}
.ckToggle:hover{color:#F6515D}
.ckArrow{font-size:12px;transition:transform .2s ease}
.ckDetail{max-height:0;overflow:hidden;transition:max-height .3s ease}
.ckDetail.open{max-height:120px;padding-bottom:12px}
.ckDetail p{font-size:13px;color:#666;line-height:1.5}
.ckActions{display:flex;gap:12px}
.ckBtn{flex:1;padding:12px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s ease,transform .1s ease;font-family:'Rubik',sans-serif}
.ckAccept{background:linear-gradient(135deg,#F6515D 0%,#ff6b77 100%);color:#fff;box-shadow:0 4px 12px #f6515d40}
.ckAccept:hover{background:linear-gradient(135deg,#e5404c 0%,#f55a66 100%)}
.ckDecline{background:#f0f0f0;color:#555}
.ckDecline:hover{background:#e0e0e0}
.ckBtn:active{transform:scale(0.98)}
@media (max-width: 768px) {
.bannerContent{flex-direction:column;text-align:center}
.brandName{font-size:30px}
.tagLine{font-size:15px}
.mainNv{gap:16px}
.mainNv .nvLink{font-size:14px;padding:5px 10px}
.ftLinks{flex-direction:column;align-items:center;gap:14px}
.cookieBox{left:12px;bottom:12px;width:calc(100vw - 24px)}
.ckContent{padding:20px}
.ckActions{flex-direction:column}
}
@media (max-width: 480px) {
.siteLogo{width:85px;height:85px}
.brandName{font-size:24px}
.tagLine{font-size:13px}
}
.legal-area{max-width:1200px;margin:0 auto;padding:60px 20px;background:#FCFEE9}
.legal-area h1{font-size:42px;line-height:1.2;color:#0F576B;margin:0 0 40px;font-weight:700;letter-spacing:-.5px}
.legal-area h2{font-size:32px;line-height:1.3;color:#0F576B;margin:50px 0 24px;font-weight:600;border-left:4px solid #F6515D;padding-left:20px}
.legal-area h3{font-size:24px;line-height:1.4;color:#0F576B;margin:40px 0 20px;font-weight:600}
.legal-area h4{font-size:20px;line-height:1.4;color:#0F576B;margin:30px 0 16px;font-weight:600}
.legal-area h5{font-size:18px;line-height:1.4;color:#0F576B;margin:24px 0 12px;font-weight:600}
.legal-area h6{font-size:16px;line-height:1.4;color:#0F576B;margin:20px 0 12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.legal-area p{font-size:17px;line-height:1.7;color:#333;margin:0 0 20px;max-width:800px}
.legal-area ul{margin:0 0 24px;padding:0 0 0 24px;list-style-type:none}
.legal-area ul li{font-size:17px;line-height:1.7;color:#333;margin:0 0 12px;padding-left:28px;position:relative}
.legal-area ul li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:8px;background:#F6515D;border-radius:50%}
.legal-area ol{margin:0 0 24px;padding:0 0 0 24px;counter-reset:policy-counter;list-style:none}
.legal-area ol li{font-size:17px;line-height:1.7;color:#333;margin:0 0 12px;padding-left:32px;position:relative;counter-increment:policy-counter}
.legal-area ol li::before{content:counter(policy-counter) ".";position:absolute;left:0;top:0;color:#F6515D;font-weight:700;font-size:17px}
.legal-area ul ul,.legal-area ol ul,.legal-area ul ol,.legal-area ol ol{margin:12px 0}
.legal-area ul ul li::before{width:6px;height:6px;background:#0F576B;top:13px}
.legal-area strong,.legal-area b{font-weight:700;color:#0F576B}
.legal-area a{color:#F6515D;text-decoration:underline;transition:all .25s ease;font-weight:500}
.legal-area a:hover{color:#0F576B;text-decoration:none}
.legal-area a:focus{outline:2px solid #F6515D;outline-offset:2px;border-radius:2px}
.legal-area div{margin:0 0 20px}
.legal-area div p:last-child{margin-bottom:0}
.legal-area h1 + p,.legal-area h2 + p,.legal-area h3 + p,.legal-area h4 + p,.legal-area h5 + p,.legal-area h6 + p{margin-top:0}
@media (max-width: 768px) {
.legal-area{padding:40px 16px}
.legal-area h1{font-size:32px;margin-bottom:30px}
.legal-area h2{font-size:26px;margin:40px 0 20px;padding-left:16px}
.legal-area h3{font-size:22px;margin:32px 0 16px}
.legal-area h4{font-size:19px;margin:24px 0 14px}
.legal-area h5{font-size:17px;margin:20px 0 12px}
.legal-area h6{font-size:15px}
.legal-area p,.legal-area ul li,.legal-area ol li{font-size:16px;line-height:1.65}
.legal-area ul{padding-left:20px}
.legal-area ol{padding-left:20px}
.legal-area ul li{padding-left:24px}
.legal-area ol li{padding-left:28px}
}
@media (max-width: 480px) {
.legal-area{padding:30px 12px}
.legal-area h1{font-size:28px;margin-bottom:24px}
.legal-area h2{font-size:24px;margin:32px 0 16px;padding-left:12px;border-left-width:3px}
.legal-area h3{font-size:20px}
.legal-area p,.legal-area ul li,.legal-area ol li{font-size:15px}
}
.heroWrap{background:linear-gradient(135deg,#FCFEE9 0%,#fcfee966 100%);padding:80px 20px;position:relative;overflow:hidden}
.heroWrap::before{content:'';position:absolute;top:-20%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,#f6515d26,transparent 70%);border-radius:50%;pointer-events:none}
.heroInner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.heroTxt h1{font-size:48px;line-height:1.2;color:#0F576B;margin:0 0 24px;font-weight:700}
.heroTxt p{font-size:18px;line-height:1.6;color:#333;margin:0 0 32px}
.heroTxt .btnPrim{display:inline-block;padding:14px 32px;background:linear-gradient(90deg,#F6515D,#0F576B);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:transform 0.3s,box-shadow .3s;box-shadow:0 4px 12px #f6515d4d}
.heroTxt .btnPrim:hover{transform:translateY(-2px);box-shadow:0 8px 20px #f6515d66}
.heroImg{position:relative}
.heroImg img{width:100%;height:auto;border-radius:10px;box-shadow:0 8px 24px #0f576b33;filter:brightness(1.05)}
.schedWrap{padding:80px 20px;background:#fff}
.schedInner{max-width:1200px;margin:0 auto}
.schedInner h2{font-size:36px;color:#0F576B;margin:0 0 16px;font-weight:700}
.schedInner > p{font-size:17px;line-height:1.7;color:#555;margin:0 0 48px;max-width:800px}
.schedGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.schedCard{background:linear-gradient(135deg,#FCFEE9,#fff);padding:32px;border-radius:8px;box-shadow:0 4px 16px #00000014;transition:transform 0.3s,box-shadow .3s;border-left:4px solid #F6515D}
.schedCard:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001f}
.schedCard h3{font-size:22px;color:#0F576B;margin:0 0 12px;font-weight:600}
.schedCard p{font-size:16px;line-height:1.6;color:#666;margin:0}
.contWrap{padding:80px 20px;background:linear-gradient(180deg,#fff 0%,#FCFEE9 100%)}
.contInner{max-width:1200px;margin:0 auto}
.contInner h2{font-size:36px;color:#0F576B;margin:0 0 16px;font-weight:700}
.contInner > p{font-size:17px;line-height:1.7;color:#555;margin:0 0 48px}
.contFlex{display:flex;gap:40px;align-items:flex-start}
.contLeft{flex:1}
.contLeft img{width:100%;height:auto;border-radius:10px;box-shadow:0 6px 18px #0f576b26}
.contRight{flex:1}
.contList{list-style:none;padding:0;margin:0}
.contList li{padding:20px 0;border-bottom:1px solid #0f576b26;font-size:16px;color:#333;position:relative;padding-left:32px}
.contList li::before{content:'→';position:absolute;left:0;color:#F6515D;font-weight:700;font-size:20px}
.contList li:last-child{border-bottom:none}
.probWrap{padding:80px 20px;background:#fff}
.probInner{max-width:1200px;margin:0 auto}
.probInner h2{font-size:36px;color:#0F576B;margin:0 0 16px;font-weight:700}
.probInner > p{font-size:17px;line-height:1.7;color:#555;margin:0 0 48px}
.probAccordion{max-width:900px}
.probItem{margin-bottom:16px;border:2px solid #FCFEE9;border-radius:8px;overflow:hidden}
.probItem input[type="checkbox"]{display:none}
.probLabel{display:block;padding:20px 24px;background:linear-gradient(90deg,#FCFEE9,#fff);cursor:pointer;font-size:18px;font-weight:600;color:#0F576B;position:relative;transition:background .3s}
.probLabel::after{content:'+';position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:24px;color:#F6515D;transition:transform .3s}
.probItem input[type="checkbox"]:checked + .probLabel::after{transform:translateY(-50%) rotate(45deg)}
.probItem input[type="checkbox"]:checked + .probLabel{background:linear-gradient(90deg,#F6515D,#0F576B);color:#fff}
.probItem input[type="checkbox"]:checked + .probLabel::after{color:#fff}
.probCont{max-height:0;overflow:hidden;transition:max-height .4s ease;background:#fff}
.probItem input[type="checkbox"]:checked ~ .probCont{max-height:400px}
.probCont p{padding:20px 24px;margin:0;font-size:16px;line-height:1.7;color:#555}
.feedWrap{padding:80px 20px;background:linear-gradient(135deg,#FCFEE9 0%,#fcfee94d 100%)}
.feedInner{max-width:1200px;margin:0 auto}
.feedInner h2{font-size:36px;color:#0F576B;margin:0 0 16px;font-weight:700}
.feedInner > p{font-size:17px;line-height:1.7;color:#555;margin:0 0 48px}
.feedGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.feedCard{background:#fff;padding:32px;border-radius:8px;box-shadow:0 4px 16px #00000014;position:relative;border-top:3px solid #F6515D}
.feedCard::before{content:'"';position:absolute;top:16px;left:16px;font-size:64px;color:#f6515d26;font-family:serif;line-height:1}
.feedCard p{font-size:16px;line-height:1.7;color:#555;margin:0 0 20px;position:relative;z-index:1}
.feedCard .feedAuth{font-size:15px;color:#0F576B;font-weight:600;margin:0}
.actWrap{padding:80px 20px;background:#fff}
.actInner{max-width:1200px;margin:0 auto}
.actInner h2{font-size:36px;color:#0F576B;margin:0 0 16px;font-weight:700}
.actInner > p{font-size:17px;line-height:1.7;color:#555;margin:0 0 48px}
.actTimeline{position:relative;padding-left:60px}
.actTimeline::before{content:'';position:absolute;left:20px;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#F6515D,#0F576B)}
.actEvent{position:relative;margin-bottom:48px}
.actEvent::before{content:'';position:absolute;left:-48px;top:8px;width:16px;height:16px;background:#F6515D;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 3px #f6515d4d}
.actEvent h4{font-size:20px;color:#0F576B;margin:0 0 8px;font-weight:600}
.actEvent p{font-size:16px;line-height:1.6;color:#666;margin:0}
.actEvent .actDate{display:inline-block;font-size:14px;color:#F6515D;background:#FCFEE9;padding:4px 12px;border-radius:6px;margin-bottom:8px;font-weight:600}
.ctaWrap{padding:80px 20px;background:linear-gradient(135deg,#0F576B,#F6515D);text-align:center}
.ctaInner{max-width:800px;margin:0 auto}
.ctaInner h2{font-size:36px;color:#fff;margin:0 0 16px;font-weight:700}
.ctaInner p{font-size:18px;line-height:1.7;color:#fffffff2;margin:0 0 32px}
.ctaInner .btnSec{display:inline-block;padding:16px 40px;background:#fff;color:#0F576B;text-decoration:none;border-radius:8px;font-weight:600;font-size:17px;transition:transform 0.3s,box-shadow .3s;box-shadow:0 6px 18px #0003}
.ctaInner .btnSec:hover{transform:translateY(-3px);box-shadow:0 10px 26px #0000004d}
@media (max-width: 968px) {
.heroInner{grid-template-columns:1fr;gap:40px}
.heroTxt h1{font-size:36px}
.schedGrid{grid-template-columns:1fr}
.contFlex{flex-direction:column}
.feedGrid{grid-template-columns:1fr}
.actTimeline{padding-left:40px}
.actEvent::before{left:-28px}
}
@media (max-width: 640px) {
.heroWrap{padding:60px 20px}
.heroTxt h1{font-size:28px}
.heroTxt p{font-size:16px}
.schedWrap,.contWrap,.probWrap,.feedWrap,.actWrap,.ctaWrap{padding:60px 20px}
.schedInner h2,.contInner h2,.probInner h2,.feedInner h2,.actInner h2,.ctaInner h2{font-size:28px}
.probLabel{font-size:16px;padding:16px 20px}
.probLabel::after{right:20px}
}
.ctWrap{max-width:1200px;margin:0 auto;padding:0 20px}
.titleZone{position:relative;padding:80px 20px;text-align:center;margin-bottom:60px}
.circleBack{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:450px;height:450px;border-radius:50%;background:linear-gradient(135deg,#f6515d1f,#0f576b1f);z-index:1;box-shadow:0 8px 24px #0f576b26}
.titleZone .picFrame{position:relative;z-index:2;display:inline-block;margin-bottom:30px}
.titleZone .picFrame img{width:180px;height:180px;border-radius:50%;object-fit:cover;border:4px solid #F6515D;box-shadow:inset 0 4px 8px #0f576b33 0 6px 16px #f6515d40}
.titleZone .txtCenter{position:relative;z-index:2}
.titleZone h1{font-size:2.8rem;color:#0F576B;margin-bottom:16px;font-weight:700}
.titleZone .subline{font-size:1.15rem;color:#333;line-height:1.6;max-width:600px;margin:0 auto}
.detailsRow{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-bottom:70px}
.infoBox{background:linear-gradient(145deg,#FCFEE9,#fff);padding:35px 28px;border-radius:8px;box-shadow:0 4px 12px #0f576b1a;transition:transform 0.3s,box-shadow .3s}
.infoBox:hover{transform:translateY(-6px);box-shadow:0 8px 20px #f6515d33}
.infoBox .iconWrap{width:56px;height:56px;background:linear-gradient(135deg,#F6515D,#0F576B);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.infoBox .iconWrap svg{width:28px;height:28px;fill:#FCFEE9}
.infoBox h3{font-size:1.3rem;color:#0F576B;margin-bottom:12px;font-weight:600}
.infoBox .infoContent a{color:#F6515D;text-decoration:none;font-size:1.05rem;transition:color .3s;display:block;margin-bottom:8px}
.infoBox .infoContent a:hover{color:#0F576B}
.infoBox .infoContent p{color:#333;font-size:1.05rem;line-height:1.5;margin:0}
.formSection{background:linear-gradient(160deg,#0f576b0d,#fcfee9cc);padding:60px 40px;border-radius:10px;margin-bottom:70px;box-shadow:0 6px 18px #0f576b1f}
.formSection h2{font-size:2.2rem;color:#0F576B;margin-bottom:14px;font-weight:700}
.formSection .formIntro{font-size:1.1rem;color:#333;margin-bottom:40px;line-height:1.6}
.contactForm{max-width:700px}
.fldGroup{margin-bottom:28px}
.fldGroup label{display:block;font-size:1rem;color:#0F576B;margin-bottom:8px;font-weight:600}
.fldGroup input[type="text"],.fldGroup input[type="tel"]{width:100%;padding:14px 18px;font-size:1rem;border:2px solid #0F576B;border-radius:6px;background:#fff;transition:border-color 0.3s,box-shadow .3s}
.fldGroup input[type="text"]:focus,.fldGroup input[type="tel"]:focus{outline:none;border-color:#F6515D;box-shadow:0 0 0 3px #f6515d26}
.ratingZone{margin-bottom:28px}
.ratingZone .ratingLabel{display:block;font-size:1rem;color:#0F576B;margin-bottom:12px;font-weight:600}
.starGroup{display:flex;gap:12px;align-items:center}
.starGroup input[type="radio"]{display:none}
.starGroup label{cursor:pointer;font-size:2rem;color:#ddd;transition:color 0.3s,transform .2s}
.starGroup label:hover{transform:scale(1.15)}
.starGroup input[type="radio"]:checked ~ label,.starGroup label:hover,.starGroup label:hover ~ label{color:#F6515D}
.starGroup{display:flex;flex-direction:row-reverse;justify-content:flex-end}
.starGroup input[type="radio"]:checked ~ label{color:#F6515D}
.starGroup label:hover,.starGroup label:hover ~ label{color:#F6515D}
.privacyWrap{margin-bottom:28px}
.privacyWrap input[type="checkbox"]{margin-right:10px;width:18px;height:18px;cursor:pointer}
.privacyWrap label{font-size:.95rem;color:#333;cursor:pointer;display:inline}
.privacyWrap a{color:#F6515D;text-decoration:none;transition:color .3s}
.privacyWrap a:hover{color:#0F576B}
.submitWrap{text-align:left}
.submitWrap button{background:linear-gradient(135deg,#F6515D,#0F576B);color:#FCFEE9;padding:16px 48px;font-size:1.1rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;box-shadow:0 6px 14px #f6515d4d;transition:transform 0.3s,box-shadow .3s;z-index:10;position:relative}
.submitWrap button:hover{transform:translateY(-3px);box-shadow:0 10px 24px #0f576b66}
.submitWrap button:active{transform:translateY(0)}
.hoursBlock{background:#fff;padding:50px 40px;border-radius:10px;box-shadow:0 4px 16px #0f576b1a;margin-bottom:70px;border-left:6px solid #F6515D}
.hoursBlock h2{font-size:2rem;color:#0F576B;margin-bottom:30px;font-weight:700}
.scheduleGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}
.dayItem{display:flex;justify-content:space-between;padding:16px 20px;background:linear-gradient(120deg,#fcfee980,#0f576b0d);border-radius:6px;box-shadow:inset 0 2px 6px #0f576b14}
.dayItem .dayName{font-weight:600;color:#0F576B;font-size:1.05rem}
.dayItem .dayTime{color:#333;font-size:1.05rem}
.routeSection{background:linear-gradient(150deg,#f6515d14,#fcfee999);padding:60px 40px;border-radius:10px;text-align:center}
.routeSection h2{font-size:2rem;color:#0F576B;margin-bottom:18px;font-weight:700}
.routeSection .routeText{font-size:1.1rem;color:#333;line-height:1.6;max-width:750px;margin:0 auto 30px}
.routeSection .addressLine{font-size:1.15rem;color:#F6515D;font-weight:600;margin-bottom:30px}
.methodsRow{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}
.methodsRow .methodCard{background:#fff;padding:20px 28px;border-radius:8px;box-shadow:0 4px 12px #0f576b1f;transition:transform 0.3s,box-shadow .3s;min-width:160px}
.methodsRow .methodCard:hover{transform:translateY(-5px);box-shadow:0 8px 20px #f6515d33}
.methodsRow .methodCard svg{width:40px;height:40px;fill:#F6515D;margin-bottom:12px}
.methodsRow .methodCard p{font-size:1rem;color:#0F576B;font-weight:600;margin:0}
@media (max-width: 768px) {
.titleZone{padding:60px 20px}
.circleBack{width:320px;height:320px}
.titleZone .picFrame img{width:140px;height:140px}
.titleZone h1{font-size:2.2rem}
.titleZone .subline{font-size:1rem}
.detailsRow{grid-template-columns:1fr}
.formSection{padding:40px 24px}
.formSection h2{font-size:1.8rem}
.hoursBlock{padding:40px 24px}
.scheduleGrid{grid-template-columns:1fr}
.routeSection{padding:40px 24px}
.methodsRow{flex-direction:column;align-items:center}
.methodsRow .methodCard{width:100%;max-width:280px}
.starGroup{gap:8px}
.starGroup label{font-size:1.6rem}
}
@media (max-width: 480px) {
.titleZone h1{font-size:1.8rem}
.circleBack{width:280px;height:280px}
.titleZone .picFrame img{width:120px;height:120px}
}
.aboutWrap{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
.titleArea{display:grid;grid-template-columns:1fr 1.3fr;gap:50px;align-items:center;padding:80px 0 60px;position:relative}
.titleArea::before{content:'';position:absolute;top:-20px;left:-100px;width:240px;height:240px;background:radial-gradient(circle at center,#f6515d14,transparent 70%);border-radius:50%;z-index:1}
.titleArea::after{content:'';position:absolute;bottom:30px;right:-80px;width:160px;height:160px;background:linear-gradient(135deg,#0f576b0f,transparent);clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);z-index:1}
.titleTxt{position:relative;z-index:2}
.titleTxt h1{font-size:42px;line-height:1.2;color:#0F576B;margin:0 0 25px;font-weight:600}
.titleList{list-style:none;padding:0;margin:0 0 35px}
.titleList li{padding:14px 0 14px 40px;position:relative;font-size:16px;line-height:1.6;color:#333}
.titleList li::before{content:'';position:absolute;left:0;top:18px;width:24px;height:24px;background:linear-gradient(135deg,#F6515D,#0F576B);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}
.titleBtn{display:inline-block;padding:14px 36px;background:linear-gradient(135deg,#F6515D,#0F576B);color:#fff;text-decoration:none;border-radius:8px;font-size:16px;font-weight:500;transition:transform 0.3s,box-shadow .3s;box-shadow:0 4px 12px #f6515d33;z-index:10;position:relative}
.titleBtn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #f6515d4d}
.titleVisual{position:relative;z-index:2}
.titleVisual img{width:100%;height:420px;object-fit:cover;border-radius:10px;box-shadow:0 12px 36px #0f576b26;border:4px solid #fcfee999}
.storySection{padding:70px 0;background:linear-gradient(180deg,#fcfee94d,#fcfee91a);position:relative}
.storySection::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#F6515D,#0F576B,transparent)}
.storyContent{display:flex;flex-direction:row;gap:60px;align-items:flex-start}
.storyLeft{flex:1}
.storyLeft h2{font-size:36px;line-height:1.3;color:#F6515D;margin:0 0 30px;font-weight:600;position:relative;padding-bottom:18px}
.storyLeft h2::after{content:'';position:absolute;bottom:0;left:0;width:80px;height:4px;background:linear-gradient(90deg,#F6515D,#0F576B);border-radius:2px}
.storyLeft p{font-size:16px;line-height:1.7;color:#444;margin:0 0 20px}
.storyRight{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.statCard{background:#fff;padding:28px 20px;border-radius:8px;box-shadow:0 6px 18px #0f576b1a;text-align:center;transition:transform 0.3s,box-shadow .3s;position:relative;overflow:hidden}
.statCard::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#F6515D,#0F576B);transform:scaleX(0);transition:transform .3s;transform-origin:left}
.statCard:hover::before{transform:scaleX(1)}
.statCard:hover{transform:translateY(-4px);box-shadow:0 12px 28px #0f576b2e}
.statNum{font-size:44px;font-weight:700;color:#0F576B;margin:0 0 8px;line-height:1}
.statLabel{font-size:14px;color:#666;line-height:1.4}
.approachBlock{padding:70px 0}
.approachBlock h2{font-size:36px;line-height:1.3;color:#0F576B;margin:0 0 50px;text-align:center;font-weight:600}
.approachGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.approachItem{background:linear-gradient(135deg,#fcfee966,#fcfee91a);padding:40px 30px;border-radius:10px;border:2px solid transparent;transition:border-color 0.3s,transform .3s;position:relative;overflow:hidden}
.approachItem::before{content:'';position:absolute;top:-50%;right:-50%;width:200px;height:200px;background:radial-gradient(circle,#f6515d1a,transparent);border-radius:50%;transition:transform .5s}
.approachItem:hover::before{transform:translate(-30px,30px)}
.approachItem:hover{border-color:#F6515D;transform:translateY(-6px)}
.approachIcon{width:60px;height:60px;margin:0 0 20px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#F6515D,#0F576B);border-radius:50%;position:relative;z-index:2}
.approachIcon svg{width:32px;height:32px;fill:#fff}
.approachItem h3{font-size:20px;color:#0F576B;margin:0 0 14px;font-weight:600;position:relative;z-index:2}
.approachItem p{font-size:15px;line-height:1.6;color:#555;margin:0;position:relative;z-index:2}
.teamSegment{padding:70px 0;background:linear-gradient(180deg,#0f576b08,transparent);position:relative}
.teamSegment::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,#f6515d4d,transparent)}
.teamSegment h2{font-size:36px;line-height:1.3;color:#F6515D;margin:0 0 20px;text-align:center;font-weight:600}
.teamIntro{font-size:17px;line-height:1.6;color:#555;max-width:800px;margin:0 auto 50px;text-align:center}
.teamLayout{display:grid;grid-template-columns:1fr 1.2fr;gap:50px;align-items:center}
.teamImg img{width:100%;height:380px;object-fit:cover;border-radius:10px;box-shadow:0 10px 30px #0f576b1f}
.teamText h3{font-size:28px;color:#0F576B;margin:0 0 24px;font-weight:600}
.teamText p{font-size:16px;line-height:1.7;color:#444;margin:0 0 18px}
.teamList{list-style:none;padding:0;margin:30px 0 0}
.teamList li{padding:10px 0 10px 35px;position:relative;font-size:15px;color:#555;line-height:1.5}
.teamList li::before{content:'';position:absolute;left:0;top:14px;width:20px;height:20px;background:linear-gradient(135deg,#F6515D,#0F576B);border-radius:50%}
@media (max-width: 1024px) {
.titleArea{grid-template-columns:1fr;gap:40px;padding:60px 0 50px}
.titleTxt h1{font-size:36px}
.titleVisual img{height:350px}
.storyContent{flex-direction:column;gap:40px}
.approachGrid{grid-template-columns:1fr;gap:30px}
.teamLayout{grid-template-columns:1fr;gap:40px}
.teamImg img{height:320px}
}
@media (max-width: 768px) {
.aboutWrap{padding:0 16px}
.titleArea{padding:50px 0 40px}
.titleTxt h1{font-size:30px;margin-bottom:20px}
.titleList li{font-size:15px;padding-left:32px}
.titleVisual img{height:280px}
.storySection{padding:50px 0}
.storyLeft h2{font-size:28px}
.storyRight{grid-template-columns:1fr}
.approachBlock{padding:50px 0}
.approachBlock h2{font-size:28px;margin-bottom:35px}
.approachItem{padding:30px 20px}
.teamSegment{padding:50px 0}
.teamSegment h2{font-size:28px}
.teamIntro{font-size:16px;margin-bottom:35px}
.teamImg img{height:260px}
.teamText h3{font-size:24px}
}
.topWrap{max-width:1200px;margin:0 auto;padding:80px 20px 60px}
.topWrap .imgZone{width:100%;max-width:700px;margin:0 auto 40px;border-radius:8px;overflow:hidden;position:relative}
.topWrap .imgZone::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#f6515d1f,#0f576b14);pointer-events:none}
.topWrap .imgZone img{width:100%;height:auto;display:block;filter:brightness(1.02)}
.topWrap .txtContent{text-align:center;max-width:800px;margin:0 auto}
.topWrap .txtContent h1{font-size:2.8rem;color:#0F576B;margin-bottom:24px;line-height:1.2}
.topWrap .txtContent .subline{font-size:1.1rem;color:#555;line-height:1.7;margin-bottom:36px}
.topWrap .btnRow{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.topWrap .btnRow a{padding:14px 32px;text-decoration:none;border-radius:6px;font-size:1rem;font-weight:500;transition:all .3s;display:inline-block}
.topWrap .btnRow .primBtn{background:linear-gradient(135deg,#F6515D,#0F576B);color:#fff;box-shadow:0 4px 12px #f6515d40}
.topWrap .btnRow .primBtn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f6515d59}
.topWrap .btnRow .secBtn{background:transparent;color:#0F576B;border:2px solid #0F576B}
.topWrap .btnRow .secBtn:hover{background:#0F576B;color:#fff}
.checkWrap{background:linear-gradient(180deg,#FCFEE9 0%,#fcfee94d 100%);padding:70px 20px;position:relative}
.checkWrap::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,#F6515D,transparent)}
.checkWrap .innerBox{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.checkWrap .leftSide h2{font-size:2.2rem;color:#0F576B;margin-bottom:20px;line-height:1.3}
.checkWrap .leftSide .intro{font-size:1.05rem;color:#444;line-height:1.7;margin-bottom:32px}
.checkWrap .rightSide .itemList{display:flex;flex-direction:column;gap:24px}
.checkWrap .rightSide .chkItem{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 8px #0000000f;border-left:4px solid #F6515D;transition:transform .3s}
.checkWrap .rightSide .chkItem:hover{transform:translateX(6px)}
.checkWrap .rightSide .chkItem h4{font-size:1.25rem;color:#0F576B;margin-bottom:10px}
.checkWrap .rightSide .chkItem p{font-size:.95rem;color:#555;line-height:1.6;margin:0}
.techReq{max-width:1200px;margin:0 auto;padding:80px 20px}
.techReq h2{font-size:2.4rem;color:#0F576B;text-align:center;margin-bottom:48px;position:relative;display:inline-block;left:50%;transform:translateX(-50%)}
.techReq h2::after{content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:linear-gradient(90deg,#F6515D,#0F576B)}
.techReq .specGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.techReq .specCard{background:linear-gradient(135deg,#0f576b0d,#f6515d0d);padding:32px 24px;border-radius:10px;text-align:center;position:relative;overflow:hidden;transition:all .4s}
.techReq .specCard::before{content:'';position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,#f6515d14,transparent 70%);transition:transform .6s;transform:scale(0)}
.techReq .specCard:hover::before{transform:scale(1)}
.techReq .specCard .ico{width:64px;height:64px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#F6515D,#0F576B);border-radius:50%;position:relative;z-index:2}
.techReq .specCard .ico svg{width:32px;height:32px;fill:#fff}
.techReq .specCard h4{font-size:1.2rem;color:#0F576B;margin-bottom:12px;position:relative;z-index:2}
.techReq .specCard p{font-size:.95rem;color:#555;line-height:1.6;margin:0;position:relative;z-index:2}
.timeFlow{background:#fff;padding:70px 20px;position:relative}
.timeFlow::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#0F576B,transparent)}
.timeFlow .container{max-width:1000px;margin:0 auto}
.timeFlow h2{font-size:2.2rem;color:#0F576B;text-align:center;margin-bottom:56px}
.timeFlow .pathList{position:relative;padding-left:60px}
.timeFlow .pathList::before{content:'';position:absolute;left:20px;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#F6515D,#0F576B)}
.timeFlow .stepBox{position:relative;margin-bottom:48px;padding-left:32px}
.timeFlow .stepBox::before{content:'';position:absolute;left:-47px;top:8px;width:18px;height:18px;background:#F6515D;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 3px #f6515d33}
.timeFlow .stepBox h4{font-size:1.3rem;color:#0F576B;margin-bottom:10px}
.timeFlow .stepBox .numLabel{display:inline-block;background:linear-gradient(135deg,#F6515D,#0F576B);color:#fff;font-size:.8rem;font-weight:600;padding:4px 12px;border-radius:20px;margin-bottom:8px}
.timeFlow .stepBox p{font-size:1rem;color:#555;line-height:1.7;margin:0}
.finalBand{background:linear-gradient(135deg,#0F576B,#F6515D);padding:60px 20px;text-align:center}
.finalBand .innerWrap{max-width:900px;margin:0 auto}
.finalBand h3{font-size:2rem;color:#fff;margin-bottom:18px;line-height:1.3}
.finalBand .msg{font-size:1.1rem;color:#fffffff2;line-height:1.6;margin-bottom:32px}
.finalBand .actBtn{display:inline-block;padding:16px 40px;background:#FCFEE9;color:#0F576B;text-decoration:none;font-size:1.05rem;font-weight:600;border-radius:8px;transition:all .3s;box-shadow:0 4px 14px #00000026}
.finalBand .actBtn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000040;background:#fff}
@media (max-width: 768px) {
.topWrap{padding:50px 20px 40px}
.topWrap .txtContent h1{font-size:2rem}
.topWrap .txtContent .subline{font-size:1rem}
.topWrap .btnRow{flex-direction:column;align-items:stretch}
.topWrap .btnRow a{text-align:center}
.checkWrap .innerBox{grid-template-columns:1fr;gap:40px}
.techReq .specGrid{grid-template-columns:1fr;gap:24px}
.timeFlow .pathList{padding-left:40px}
.timeFlow .stepBox{padding-left:20px}
.finalBand h3{font-size:1.6rem}
.finalBand .msg{font-size:1rem}
}
@media (min-width: 769px) and (max-width: 1024px) {
.techReq .specGrid{grid-template-columns:repeat(2,1fr)}
}
.successWrap{max-width:1200px;margin:0 auto;padding:60px 20px}
.confirmationBox{background:linear-gradient(135deg,#FCFEE9 0%,#fff 100%);border-radius:8px;padding:80px 40px;text-align:center;box-shadow:0 4px 16px #0f576b14;position:relative;overflow:hidden}
.confirmationBox::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#F6515D 0%,#0F576B 100%)}
.confirmationBox::after{content:'';position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,#f6515d08 0%,transparent 70%);pointer-events:none}
.successIcon{width:120px;height:120px;margin:0 auto 32px;position:relative;z-index:1}
.successIcon svg{width:100%;height:100%;filter:drop-shadow(0 4px 12px #f6515d33)}
.confirmationBox h1{font-size:42px;font-weight:700;color:#0F576B;margin:0 0 20px;line-height:1.2;position:relative;z-index:1}
.confirmationBox .msgTxt{font-size:18px;line-height:1.7;color:#333;max-width:600px;margin:0 auto 40px;position:relative;z-index:1}
.detailsGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;max-width:900px;margin:50px auto 0;position:relative;z-index:1}
.infoCard{background:#fff;padding:28px;border-radius:6px;border-left:4px solid #F6515D;box-shadow:0 2px 8px #0000000f;transition:transform .3s ease,box-shadow .3s ease}
.infoCard:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0f576b1f}
.infoCard h3{font-size:16px;font-weight:600;color:#0F576B;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}
.infoCard p{font-size:15px;line-height:1.6;color:#555;margin:0}
.manifestoSection{max-width:1200px;margin:80px auto 0;padding:0 20px;display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:start}
.decorativeShape{position:relative;height:400px;background:linear-gradient(165deg,#0F576B 0%,#F6515D 100%);border-radius:8px;box-shadow:0 8px 24px #0f576b33;overflow:hidden}
.decorativeShape::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 35px,#ffffff08 35px,#ffffff08 70px);opacity:.6}
.decorativeShape::after{content:'';position:absolute;bottom:-30%;right:-30%;width:80%;height:80%;background:radial-gradient(circle,#fcfee926 0%,transparent 70%)}
.shapeIcon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:140px;height:140px;opacity:.25}
.shapeIcon svg{width:100%;height:100%}
.manifestoContent h2{font-size:36px;font-weight:700;color:#0F576B;margin:0 0 24px;line-height:1.3;position:relative;padding-left:20px}
.manifestoContent h2::before{content:'';position:absolute;left:0;top:8px;width:6px;height:60%;background:linear-gradient(180deg,#F6515D 0%,#0F576B 100%);border-radius:3px}
.manifestoContent .principle{margin-bottom:32px}
.manifestoContent .principle h3{font-size:20px;font-weight:600;color:#F6515D;margin:0 0 12px;line-height:1.4}
.manifestoContent .principle p{font-size:16px;line-height:1.7;color:#444;margin:0}
.actionRow{margin-top:50px;padding-top:40px;border-top:2px dashed #0f576b33;display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.btnPrimary{display:inline-block;padding:16px 36px;background:linear-gradient(135deg,#F6515D 0%,#d63d48 100%);color:#fff;text-decoration:none;font-size:16px;font-weight:600;border-radius:6px;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 12px #f6515d4d;z-index:10;position:relative}
.btnPrimary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f6515d66}
.btnSecondary{display:inline-block;padding:16px 36px;background:#fff;color:#0F576B;text-decoration:none;font-size:16px;font-weight:600;border-radius:6px;border:2px solid #0F576B;transition:background-color .2s ease,color .2s ease;z-index:10;position:relative}
.btnSecondary:hover{background-color:#0F576B;color:#fff}
@media (max-width: 968px) {
.manifestoSection{grid-template-columns:1fr;gap:40px}
.decorativeShape{height:280px}
.confirmationBox h1{font-size:32px}
.manifestoContent h2{font-size:28px}
}
@media (max-width: 640px) {
.successWrap{padding:40px 16px}
.confirmationBox{padding:50px 24px}
.confirmationBox h1{font-size:26px}
.confirmationBox .msgTxt{font-size:16px}
.detailsGrid{grid-template-columns:1fr;gap:16px}
.manifestoContent h2{font-size:24px}
.manifestoContent .principle h3{font-size:18px}
.actionRow{flex-direction:column;align-items:stretch}
.btnPrimary,.btnSecondary{width:100%;text-align:center}
}