@import "https://cdn.jsdelivr.net/npm/@fontsource/rubik@latest/400.css";
@import "https://cdn.jsdelivr.net/npm/@fontsource/rubik@latest/500.css";
@import "https://cdn.jsdelivr.net/npm/@fontsource/rubik@latest/600.css";
@import "https://cdn.jsdelivr.net/npm/@fontsource/rubik@latest/700.css";
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'Rubik',sans-serif;line-height:1.6;color:#2a2a2a;background:#fafafa}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
.headerNav{background:linear-gradient(110deg,#590C97 0%,#7a1fb8 50%,#590C97 100%);padding:14px 0;position:relative;z-index:100}
.headerNav .navWrapper{max-width:1400px;margin:0 auto;padding:0 24px;display:flex;justify-content:flex-end;align-items:center}
.headerNav .mainMenu{display:flex;gap:32px;align-items:center}
.headerNav .mainMenu a{color:#fff;font-size:15px;font-weight:500;padding:8px 0;transition:opacity 180ms ease-in-out;position:relative}
.headerNav .mainMenu a:hover{opacity:.85}
.headerBrand{background:linear-gradient(135deg,#f8f8f8 0%,#fff 100%);padding:26px 0;position:relative;box-shadow:0 4px 12px #590c9714}
.headerBrand .brandBox{max-width:1400px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:center;gap:18px}
.headerBrand .logoContainer{width:95px;height:95px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000f;padding:12px}
.headerBrand .logoContainer img{width:100%;height:100%;object-fit:contain}
.headerBrand .companyName{font-size:34px;font-weight:700;color:#590C97;letter-spacing:-.5px}
.footerMain{background:linear-gradient(135deg,#2a2a2a 0%,#1a1a1a 100%);color:#e0e0e0;padding:58px 0 24px;margin-top:80px}
.footerMain .footerGrid{max-width:1400px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:42px}
.footerMain .footerAbout h3{color:#F423BC;font-size:22px;margin-bottom:18px;font-weight:600}
.footerMain .footerAbout p{line-height:1.9;color:#c8c8c8;font-size:15px}
.footerMain .footerSection h4{color:#4DC2EE;font-size:18px;margin-bottom:16px;font-weight:600}
.footerMain .footerLinks{display:flex;flex-direction:column;gap:11px}
.footerMain .footerLinks a{color:#c8c8c8;font-size:14px;transition:color 170ms ease-in-out;display:inline-block}
.footerMain .footerLinks a:hover{color:#F423BC}
.footerMain .contactItem{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;line-height:1.8}
.footerMain .contactItem .lnr{color:#4DC2EE;font-size:18px;margin-top:2px}
.footerMain .contactItem p{color:#c8c8c8;font-size:14px}
.footerMain .footerBottom{max-width:1400px;margin:0 auto;padding:22px 24px 0;border-top:1px solid #3a3a3a;text-align:center;color:#999;font-size:13px}
.cookieConsent{position:fixed;bottom:24px;left:24px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;max-width:420px;padding:26px;z-index:9999;display:none;animation:slideUp 320ms ease-out}
.cookieConsent.show{display:block}
@keyframes slideUp {
from{transform:translateY(100%);opacity:0}
to{transform:translateY(0);opacity:1}
}
.cookieConsent.hide{animation:slideDown 280ms ease-in forwards}
@keyframes slideDown {
from{transform:translateY(0);opacity:1}
to{transform:translateY(100%);opacity:0}
}
.cookieConsent h3{font-size:19px;color:#2a2a2a;margin-bottom:12px;font-weight:600}
.cookieConsent p{font-size:14px;color:#5a5a5a;line-height:1.7;margin-bottom:18px}
.cookieConsent .policyLink{color:#590C97;text-decoration:underline;transition:color 160ms ease}
.cookieConsent .policyLink:hover{color:#F423BC}
.cookieButtons{display:flex;gap:10px;margin-bottom:14px}
.cookieButtons button{flex:1;padding:11px 20px;border:none;border-radius:50px;font-size:14px;font-weight:600;cursor:pointer;transition:all 200ms ease;font-family:'Rubik',sans-serif}
.cookieButtons .acceptBtn{background:linear-gradient(90deg,#590C97 0%,#7a1fb8 100%);color:#fff}
.cookieButtons .acceptBtn:hover{background:linear-gradient(90deg,#7a1fb8 0%,#590C97 100%)}
.cookieButtons .declineBtn{background:#e8e8e8;color:#2a2a2a}
.cookieButtons .declineBtn:hover{background:#d4d4d4}
.settingsToggle{background:none;border:none;color:#590C97;font-size:13px;cursor:pointer;text-decoration:underline;padding:0;font-family:'Rubik',sans-serif;font-weight:500;transition:color 160ms ease}
.settingsToggle:hover{color:#F423BC}
.cookieSettings{display:none;margin-top:16px;padding-top:16px;border-top:1px solid #e8e8e8}
.cookieSettings.active{display:block}
.cookieCategory{margin-bottom:14px;padding:12px;background:#f8f8f8;border-radius:8px}
.cookieCategory label{display:flex;align-items:center;gap:10px;font-size:14px;color:#2a2a2a;cursor:pointer;font-weight:500}
.cookieCategory input[type="checkbox"]{width:18px;height:18px;cursor:pointer}
.cookieCategory input[type="checkbox"]:disabled{cursor:not-allowed}
.cookieCategory .categoryDesc{font-size:12px;color:#6a6a6a;margin-top:6px;line-height:1.6;margin-left:28px}
.saveSettings{width:100%;padding:11px 20px;border:none;border-radius:50px;background:#4DC2EE;color:#fff;font-size:14px;font-weight:600;cursor:pointer;margin-top:12px;font-family:'Rubik',sans-serif;transition:background 200ms ease}
.saveSettings:hover{background:#3ab0d6}
.manageCookies{background:none;border:none;color:#590C97;font-size:13px;cursor:pointer;text-decoration:underline;padding:0;font-family:'Rubik',sans-serif;font-weight:500;transition:color 160ms ease}
.manageCookies:hover{color:#F423BC}
@media (max-width: 768px) {
.headerNav .navWrapper{justify-content:center}
.headerNav .mainMenu{flex-wrap:wrap;gap:20px;justify-content:center}
.headerBrand .companyName{font-size:26px}
.headerBrand .logoContainer{width:75px;height:75px}
.footerMain .footerGrid{grid-template-columns:1fr;gap:36px}
.cookieConsent{left:12px;right:12px;bottom:12px;max-width:none;padding:20px}
.cookieButtons{flex-direction:column}
}
.rules-section{max-width:1400px;margin:0 auto;padding:80px 20px;background:#fff}
.rules-section p{font-size:16px;line-height:1.8;color:#333;margin:0 0 24px;max-width:900px}
.rules-section p:last-child{margin-bottom:0}
.rules-section a{color:#590C97;text-decoration:underline;transition:all .2s ease-in-out}
.rules-section a:hover{color:#F423BC;text-decoration:none}
.rules-section a:focus{outline:2px solid #4DC2EE;outline-offset:2px}
.rules-section table{width:100%;max-width:900px;border-collapse:collapse;margin:32px 0;background:#fff;box-shadow:0 2px 8px #590c9714;border-radius:8px;overflow:hidden}
.rules-section thead{background:linear-gradient(135deg,#590C97 0%,#F423BC 100%)}
.rules-section thead tr{border:none}
.rules-section thead th{color:#fff;font-weight:600;text-align:left;padding:16px 20px;font-size:15px;letter-spacing:.3px}
.rules-section tbody tr{border-bottom:1px solid #e8e8e8;transition:background .15s ease-in-out}
.rules-section tbody tr:last-child{border-bottom:none}
.rules-section tbody tr:hover{background:#4dc2ee0d}
.rules-section tbody td{padding:16px 20px;font-size:15px;line-height:1.6;color:#333}
.rules-section th{font-weight:600}
.rules-section td{font-weight:400}
.rules-section hr{border:none;height:1px;background:linear-gradient(90deg,#590c971a 0%,#f423bc33 50%,#4dc2ee1a 100%);margin:48px 0;max-width:900px}
.rules-section div{margin:0 0 32px}
.rules-section div:last-child{margin-bottom:0}
@media (max-width: 768px) {
.rules-section{padding:60px 16px}
.rules-section p{font-size:15px;line-height:1.7;margin-bottom:20px}
.rules-section table{font-size:14px;margin:24px 0;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.rules-section thead th{padding:12px 14px;font-size:14px;white-space:nowrap}
.rules-section tbody td{padding:12px 14px;font-size:14px}
.rules-section hr{margin:32px 0}
.rules-section div{margin-bottom:24px}
}
@media (max-width: 480px) {
.rules-section{padding:40px 12px}
.rules-section p{font-size:14px;margin-bottom:18px}
.rules-section table{font-size:13px;margin:20px 0}
.rules-section thead th{padding:10px 12px;font-size:13px}
.rules-section tbody td{padding:10px 12px;font-size:13px}
.rules-section hr{margin:28px 0}
}
.titleHero{position:relative;height:480px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(70deg,#590C97 0%,#F423BC 50%,#4DC2EE 100%)}
.titleHero::before{content:'';position:absolute;inset:0;background-image:url(./visual_storage/IMG-6972.jpg);background-size:cover;background-position:center;filter:grayscale(20%) sepia(10%);opacity:.28;z-index:1}
.titleHero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,#590c9766 0%,#000000b3 100%);z-index:2}
.titleHero .contentWrap{position:relative;z-index:3;text-align:center;max-width:920px;margin:0 auto;padding:0 24px}
.titleHero .mainHead{font-size:52px;font-weight:700;color:#fff;margin:0 0 18px;line-height:1.2;letter-spacing:-.5px}
.titleHero .subText{font-size:19px;color:#ffffffeb;margin:0;line-height:1.6;font-weight:400}
.storySection{padding:90px 24px;background:linear-gradient(135deg,#f8f7fc 0%,#fef8fd 100%)}
.storySection .wrapContainer{max-width:1400px;margin:0 auto}
.storySection .gridLayout{display:grid;grid-template-columns:repeat(12,1fr);gap:48px;align-items:start}
.storySection .textColumn{grid-column:1 / 8}
.storySection .visualColumn{grid-column:8 / 13;position:relative}
.storySection .sectionLabel{font-size:14px;font-weight:600;color:#590C97;text-transform:uppercase;letter-spacing:1.2px;margin:0 0 16px;display:inline-block;position:relative}
.storySection .sectionLabel::after{content:'';position:absolute;left:0;bottom:-6px;width:42px;height:3px;background:linear-gradient(90deg,#F423BC 0%,#4DC2EE 100%);border-radius:2px}
.storySection .mainTitle{font-size:42px;font-weight:700;color:#1a1a1a;margin:0 0 28px;line-height:1.25}
.storySection .narrative{font-size:17px;line-height:1.7;color:#3d3d3d;margin:0 0 22px}
.storySection .narrative:last-of-type{margin-bottom:0}
.storySection .highlightBox{background:#fff;padding:32px;border-radius:8px;margin:36px 0 0;box-shadow:0 2px 12px #590c9714;border-left:4px solid #F423BC}
.storySection .highlightBox .boxTitle{font-size:20px;font-weight:600;color:#1a1a1a;margin:0 0 14px}
.storySection .highlightBox .boxText{font-size:16px;line-height:1.6;color:#4d4d4d;margin:0}
.storySection .imgStack{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.storySection .imgStack .imgItem{position:relative;border-radius:10px;overflow:hidden;box-shadow:0 4px 18px #0000001f;transition:transform 180ms ease-in-out,box-shadow 180ms ease-in-out}
.storySection .imgStack .imgItem:hover{transform:translateY(-6px);box-shadow:0 8px 24px #590c972e}
.storySection .imgStack .imgItem img{width:100%;height:240px;object-fit:cover;display:block}
.storySection .imgStack .imgItem:nth-child(1){grid-column:1 / 2;margin-top:32px}
.storySection .imgStack .imgItem:nth-child(2){grid-column:2 / 3}
.storySection .imgStack .imgItem:nth-child(3){grid-column:1 / 3}
.storySection .decorCircle{position:absolute;width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,#f423bc26 0%,#4dc2ee26 100%);top:-40px;right:-60px;z-index:-1;filter:blur(40px)}
.approachBlock{padding:96px 24px;background:#fff;position:relative}
.approachBlock::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:100%;max-width:800px;height:1px;background:linear-gradient(90deg,transparent 0%,#590c9733 50%,transparent 100%)}
.approachBlock .container{max-width:1400px;margin:0 auto}
.approachBlock .headerArea{text-align:center;margin:0 0 64px}
.approachBlock .topLabel{font-size:14px;font-weight:600;color:#4DC2EE;text-transform:uppercase;letter-spacing:1.4px;margin:0 0 12px}
.approachBlock .bigTitle{font-size:44px;font-weight:700;color:#1a1a1a;margin:0 0 20px;line-height:1.2}
.approachBlock .intro{font-size:18px;line-height:1.65;color:#4d4d4d;max-width:740px;margin:0 auto}
.approachBlock .principleGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.approachBlock .principleCard{background:linear-gradient(135deg,#fafafa 0%,#f4f4f9 100%);border-radius:10px;padding:40px 28px;position:relative;overflow:hidden;transition:all 200ms ease-in-out;border:1px solid #590c9714}
.approachBlock .principleCard::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#590C97 0%,#F423BC 50%,#4DC2EE 100%);transform:scaleX(0);transform-origin:left;transition:transform 220ms ease-in-out}
.approachBlock .principleCard:hover::before{transform:scaleX(1)}
.approachBlock .principleCard:hover{transform:translateY(-4px);box-shadow:0 6px 20px #590c971f}
.approachBlock .cardIcon{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#590C97 0%,#F423BC 100%);display:flex;align-items:center;justify-content:center;margin:0 0 24px}
.approachBlock .cardIcon svg{width:28px;height:28px;fill:#fff}
.approachBlock .cardTitle{font-size:22px;font-weight:600;color:#1a1a1a;margin:0 0 14px}
.approachBlock .cardDesc{font-size:16px;line-height:1.65;color:#555;margin:0}
@media (max-width: 1024px) {
.storySection .gridLayout{grid-template-columns:1fr;gap:56px}
.storySection .textColumn,.storySection .visualColumn{grid-column:1 / -1}
.approachBlock .principleGrid{grid-template-columns:1fr;gap:24px}
.titleHero .mainHead{font-size:42px}
}
@media (max-width: 768px) {
.titleHero{height:380px}
.titleHero .mainHead{font-size:36px}
.titleHero .subText{font-size:17px}
.storySection{padding:64px 20px}
.storySection .mainTitle{font-size:32px}
.storySection .imgStack{grid-template-columns:1fr}
.storySection .imgStack .imgItem:nth-child(1){grid-column:1 / -1;margin-top:0}
.storySection .imgStack .imgItem:nth-child(2),.storySection .imgStack .imgItem:nth-child(3){grid-column:1 / -1}
.approachBlock{padding:72px 20px}
.approachBlock .bigTitle{font-size:34px}
.approachBlock .headerArea{margin:0 0 48px}
}
.titleWrap{position:relative;padding:90px 20px;overflow:hidden;background:linear-gradient(135deg,#590C97 0%,#F423BC 55%,#4DC2EE 100%)}
.titleWrap .contentHolder{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:60px}
.titleWrap .textArea{flex:1;color:#fff}
.titleWrap .textArea h1{font-size:3.2rem;line-height:1.2;margin-bottom:24px;font-weight:700}
.titleWrap .textArea .subtitle{font-size:1.15rem;line-height:1.6;opacity:.95;max-width:580px}
.titleWrap .imageClip{flex:0 0 420px;height:420px;position:relative}
.titleWrap .imageClip img{width:100%;height:100%;object-fit:cover;filter:saturate(0.7);clip-path:polygon(20% 0%,100% 0%,80% 100%,0% 100%)}
.titleWrap .frameLines{position:absolute;inset:-12px;border:2px solid #ffffff4d;pointer-events:none;clip-path:polygon(20% 0%,100% 0%,80% 100%,0% 100%)}
.scheduleSection{padding:80px 20px;background:#fafafa}
.scheduleSection .sectionInner{max-width:1400px;margin:0 auto}
.scheduleSection .sectionHead{text-align:center;margin-bottom:60px}
.scheduleSection .sectionHead h2{font-size:2.5rem;color:#1a1a1a;margin-bottom:16px;font-weight:700;position:relative;display:inline-block}
.scheduleSection .sectionHead h2::after{content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:60px;height:3px;background:linear-gradient(90deg,#590C97,#F423BC)}
.scheduleSection .sectionHead .intro{font-size:1.05rem;color:#555;line-height:1.7;max-width:720px;margin:20px auto 0}
.scheduleSection .rhythmGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}
.scheduleSection .rhythmCard{background:#fff;padding:32px;border-radius:8px;box-shadow:0 2px 12px #0000000f;transition:transform .2s ease,box-shadow .2s ease;border-top:4px solid #590C97}
.scheduleSection .rhythmCard:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0000001a}
.scheduleSection .rhythmCard .iconBox{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#590C97,#F423BC);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.scheduleSection .rhythmCard .iconBox .lnr{color:#fff;font-size:1.6rem}
.scheduleSection .rhythmCard h3{font-size:1.35rem;color:#1a1a1a;margin-bottom:12px;font-weight:600}
.scheduleSection .rhythmCard p{font-size:.95rem;color:#666;line-height:1.6}
.qualitySection{padding:80px 20px;background:#fff}
.qualitySection .qualityWrap{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.qualitySection .visualArea{position:relative}
.qualitySection .visualArea img{width:100%;height:480px;object-fit:cover;border-radius:12px;box-shadow:0 8px 24px #590c9726}
.qualitySection .contentArea h2{font-size:2.4rem;color:#1a1a1a;margin-bottom:24px;font-weight:700}
.qualitySection .contentArea h2::before{content:'';display:block;width:50px;height:4px;background:linear-gradient(90deg,#F423BC,#4DC2EE);margin-bottom:16px}
.qualitySection .contentArea .description{font-size:1.05rem;color:#555;line-height:1.7;margin-bottom:32px}
.qualitySection .standardList{list-style:none;padding:0;margin:0}
.qualitySection .standardList li{padding:18px 0;border-bottom:1px solid #eee;display:flex;align-items:start;gap:16px}
.qualitySection .standardList li:last-child{border-bottom:none}
.qualitySection .standardList li .lnr{color:#590C97;font-size:1.3rem;flex-shrink:0;margin-top:2px}
.qualitySection .standardList li .itemText{flex:1}
.qualitySection .standardList li .itemText strong{display:block;font-size:1.1rem;color:#1a1a1a;margin-bottom:6px}
.qualitySection .standardList li .itemText span{font-size:.95rem;color:#666;line-height:1.6}
.certificateSection{padding:80px 20px;background:linear-gradient(180deg,#f5f0fa 0%,#fff 100%)}
.certificateSection .certInner{max-width:1400px;margin:0 auto}
.certificateSection .topArea{text-align:center;margin-bottom:50px}
.certificateSection .topArea h2{font-size:2.5rem;color:#1a1a1a;margin-bottom:16px;font-weight:700}
.certificateSection .topArea .lead{font-size:1.05rem;color:#555;line-height:1.7;max-width:680px;margin:0 auto}
.certificateSection .docGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.certificateSection .docCard{background:#fff;padding:40px 32px;border-radius:10px;text-align:center;box-shadow:0 4px 16px #00000014;transition:all .25s ease;position:relative;overflow:hidden}
.certificateSection .docCard::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#590C97,#F423BC,#4DC2EE);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.certificateSection .docCard:hover::before{transform:scaleX(1)}
.certificateSection .docCard:hover{transform:translateY(-6px);box-shadow:0 8px 24px #0000001f}
.certificateSection .docCard .docIcon{width:72px;height:72px;margin:0 auto 24px;border-radius:50%;background:linear-gradient(135deg,#590c971a,#f423bc1a);display:flex;align-items:center;justify-content:center}
.certificateSection .docCard .docIcon .lnr{font-size:2rem;color:#590C97}
.certificateSection .docCard h3{font-size:1.3rem;color:#1a1a1a;margin-bottom:14px;font-weight:600}
.certificateSection .docCard p{font-size:.95rem;color:#666;line-height:1.6}
.researchSection{padding:90px 20px;background:#fff}
.researchSection .researchContainer{max-width:1400px;margin:0 auto}
.researchSection .sectionTitle{text-align:center;margin-bottom:60px}
.researchSection .sectionTitle h2{font-size:2.6rem;color:#1a1a1a;margin-bottom:20px;font-weight:700;position:relative;display:inline-block}
.researchSection .sectionTitle h2::after{content:'';position:absolute;bottom:-10px;left:0;right:0;height:3px;background:linear-gradient(90deg,#4DC2EE,#F423BC)}
.researchSection .sectionTitle .tagline{font-size:1.05rem;color:#555;line-height:1.7;max-width:700px;margin:24px auto 0}
.researchSection .dataFlow{display:flex;gap:50px;align-items:stretch}
.researchSection .imagePanel{flex:0 0 480px}
.researchSection .imagePanel img{width:100%;height:520px;object-fit:cover;border-radius:10px;box-shadow:0 6px 20px #0000001a}
.researchSection .analyticsPanel{flex:1;display:flex;flex-direction:column;gap:24px}
.researchSection .metricBox{background:linear-gradient(120deg,#fafafa 0%,#f5f5f5 100%);padding:28px 32px;border-radius:8px;border-left:5px solid #590C97;transition:all .2s ease}
.researchSection .metricBox:nth-child(2){border-left-color:#F423BC}
.researchSection .metricBox:nth-child(3){border-left-color:#4DC2EE}
.researchSection .metricBox:hover{transform:translateX(8px);box-shadow:0 4px 16px #00000014}
.researchSection .metricBox h4{font-size:1.25rem;color:#1a1a1a;margin-bottom:12px;font-weight:600;display:flex;align-items:center;gap:10px}
.researchSection .metricBox h4 .lnr{color:#590C97;font-size:1.4rem}
.researchSection .metricBox p{font-size:.95rem;color:#666;line-height:1.65}
.researchSection .metricBox .dataValue{display:block;font-size:2rem;font-weight:700;color:#590C97;margin-top:14px;letter-spacing:-.5px}
.ctaBlock{padding:70px 20px;background:linear-gradient(135deg,#590C97 0%,#F423BC 100%);text-align:center}
.ctaBlock .ctaContent{max-width:800px;margin:0 auto}
.ctaBlock h2{font-size:2.4rem;color:#fff;margin-bottom:20px;font-weight:700}
.ctaBlock .ctaText{font-size:1.1rem;color:#fffffff2;line-height:1.7;margin-bottom:36px}
.ctaBlock .btnPrimary{display:inline-block;padding:16px 44px;background:#fff;color:#590C97;font-size:1.1rem;font-weight:600;border-radius:6px;text-decoration:none;transition:all .2s ease;box-shadow:0 4px 12px #00000026;position:relative;z-index:10}
.ctaBlock .btnPrimary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040;background:#f5f5f5}
@media (max-width: 1024px) {
.titleWrap .contentHolder{flex-direction:column;gap:40px}
.titleWrap .imageClip{flex:0 0 350px;height:350px}
.titleWrap .textArea h1{font-size:2.6rem}
.qualitySection .qualityWrap{grid-template-columns:1fr;gap:50px}
.certificateSection .docGrid{grid-template-columns:repeat(2,1fr)}
.researchSection .dataFlow{flex-direction:column}
.researchSection .imagePanel{flex:0 0 auto}
}
@media (max-width: 768px) {
.titleWrap{padding:60px 20px}
.titleWrap .textArea h1{font-size:2.2rem}
.titleWrap .imageClip{flex:0 0 280px;height:280px}
.scheduleSection .rhythmGrid{grid-template-columns:1fr}
.scheduleSection{padding:60px 20px}
.qualitySection{padding:60px 20px}
.qualitySection .visualArea img{height:320px}
.certificateSection .docGrid{grid-template-columns:1fr;gap:30px}
.certificateSection{padding:60px 20px}
.researchSection{padding:60px 20px}
.researchSection .imagePanel img{height:300px}
.ctaBlock{padding:50px 20px}
.ctaBlock h2{font-size:2rem}
}
@media (max-width: 480px) {
.titleWrap .textArea h1{font-size:1.9rem}
.scheduleSection .sectionHead h2,.qualitySection .contentArea h2,.certificateSection .topArea h2,.researchSection .sectionTitle h2{font-size:2rem}
.ctaBlock h2{font-size:1.7rem}
}
.contactHero{position:relative;min-height:520px;display:flex;align-items:center;overflow:hidden;background:linear-gradient(135deg,#590C97 0%,#F423BC 100%)}
.contactHero .heroImage{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.15}
.contactHero .heroOverlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,#590c97b3 0%,#f423bcd9 100%)}
.contactHero .heroContent{position:relative;z-index:2;max-width:1400px;width:90%;margin:0 auto;padding:80px 0}
.contactHero .heroTitle{font-size:3.2rem;font-weight:700;color:#fff;margin:0 0 24px;line-height:1.2}
.contactHero .heroTitle .accent{color:#4DC2EE;position:relative;display:inline-block}
.contactHero .heroTitle .accent::after{content:'';position:absolute;bottom:-6px;left:0;width:100%;height:3px;background:#4DC2EE;opacity:.6}
.contactHero .heroDesc{font-size:1.25rem;color:#fffffff2;max-width:680px;line-height:1.6;margin:0}
.contactMain{max-width:1400px;width:90%;margin:0 auto;padding:90px 0}
.formWrapper{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.infoSection{display:flex;flex-direction:column;gap:48px}
.infoBlock h2{font-size:2.1rem;font-weight:600;color:#590C97;margin:0 0 28px;line-height:1.3}
.infoBlock p{font-size:1.05rem;color:#2d2d2d;line-height:1.7;margin:0 0 18px}
.contactDetails{display:flex;flex-direction:column;gap:24px}
.contactItem{display:flex;align-items:start;gap:18px;padding:22px;background:linear-gradient(135deg,#4dc2ee14 0%,#f423bc14 100%);border-radius:8px;transition:all 220ms ease-in-out}
.contactItem:hover{background:linear-gradient(135deg,#4dc2ee24 0%,#f423bc24 100%);transform:translateX(6px)}
.contactItem .iconWrap{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,#590C97 0%,#F423BC 100%);border-radius:6px;flex-shrink:0}
.contactItem .iconWrap .lnr{font-size:1.4rem;color:#fff}
.contactItem .detailContent{display:flex;flex-direction:column;gap:4px}
.contactItem .detailLabel{font-size:.9rem;font-weight:600;color:#590C97;text-transform:uppercase;letter-spacing:.5px;margin:0}
.contactItem .detailValue{font-size:1.05rem;color:#2d2d2d;margin:0}
.contactItem .detailValue a{color:#2d2d2d;text-decoration:none;transition:color 180ms ease-in-out}
.contactItem .detailValue a:hover{color:#F423BC}
.formSection{background:#fff;border-radius:12px;padding:48px;box-shadow:0 4px 20px #590c9714}
.formSection h3{font-size:1.75rem;font-weight:600;color:#590C97;margin:0 0 32px;line-height:1.3}
.formSection form{display:flex;flex-direction:column;gap:28px}
.formGroup{display:flex;flex-direction:column;gap:8px}
.formGroup label{font-size:.95rem;font-weight:600;color:#2d2d2d;margin:0}
.formGroup input[type="email"],.formGroup textarea{padding:14px 18px;font-size:1rem;color:#2d2d2d;border:2px solid #590c9733;border-radius:6px;transition:all 200ms ease-in-out;background:#fff}
.formGroup input[type="email"]:focus,.formGroup textarea:focus{outline:none;border-color:#F423BC;box-shadow:0 0 0 3px #f423bc1a}
.formGroup textarea{min-height:140px;resize:vertical;font-family:inherit}
.radioGroup{display:flex;flex-direction:column;gap:8px}
.radioGroup label{font-size:.95rem;font-weight:600;color:#2d2d2d;margin:0 0 12px}
.radioOptions{display:flex;flex-direction:column;gap:12px}
.radioItem{display:flex;align-items:center;gap:12px;position:relative}
.radioItem input[type="radio"]{appearance:none;width:20px;height:20px;border:2px solid #590c974d;border-radius:50%;cursor:pointer;position:relative;transition:all 180ms ease-in-out}
.radioItem input[type="radio"]:checked{border-color:#F423BC;background:#F423BC}
.radioItem input[type="radio"]:checked::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#fff;border-radius:50%}
.radioItem .radioLabel{font-size:1rem;color:#2d2d2d;cursor:pointer;margin:0}
.privacyBox{display:flex;align-items:start;gap:12px;padding:18px;background:#4dc2ee0d;border-radius:6px}
.privacyBox input[type="checkbox"]{appearance:none;width:20px;height:20px;border:2px solid #590c974d;border-radius:4px;cursor:pointer;position:relative;transition:all 180ms ease-in-out;flex-shrink:0;margin-top:2px}
.privacyBox input[type="checkbox"]:checked{border-color:#F423BC;background:#F423BC}
.privacyBox input[type="checkbox"]:checked::after{content:'✓';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.85rem;font-weight:700}
.privacyBox .privacyText{font-size:.9rem;color:#2d2d2d;line-height:1.5;margin:0}
.privacyBox .privacyText a{color:#F423BC;text-decoration:none;font-weight:600;transition:color 180ms ease-in-out}
.privacyBox .privacyText a:hover{color:#590C97}
.submitBtn{padding:16px 42px;font-size:1.05rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#590C97 0%,#F423BC 100%);border:none;border-radius:8px;cursor:pointer;transition:all 200ms ease-in-out;align-self:flex-start;position:relative;z-index:10}
.submitBtn:hover{background:linear-gradient(135deg,#6d0eb5 0%,#ff2dd1 100%);transform:translateY(-2px);box-shadow:0 6px 18px #f423bc4d}
.submitBtn:active{transform:translateY(0)}
@media (max-width: 1024px) {
.contactHero .heroTitle{font-size:2.6rem}
.formWrapper{gap:60px}
.formSection{padding:36px}
}
@media (max-width: 768px) {
.contactHero{min-height:420px}
.contactHero .heroContent{padding:60px 0}
.contactHero .heroTitle{font-size:2rem;margin-bottom:18px}
.contactHero .heroDesc{font-size:1.1rem}
.contactMain{padding:60px 0}
.formWrapper{grid-template-columns:1fr;gap:48px}
.infoSection{gap:36px}
.infoBlock h2{font-size:1.75rem;margin-bottom:20px}
.formSection{padding:32px 24px}
.formSection h3{font-size:1.5rem;margin-bottom:24px}
.submitBtn{width:100%;text-align:center}
}
@media (max-width: 480px) {
.contactHero .heroTitle{font-size:1.75rem}
.contactHero .heroDesc{font-size:1rem}
.contactMain{width:92%}
.infoBlock h2{font-size:1.5rem}
.contactItem{padding:16px}
.contactItem .iconWrap{width:42px;height:42px}
.formSection{padding:24px 18px}
}
.titleBox{position:relative;min-height:480px;display:flex;align-items:center;justify-content:center;background-image:url(./visual_storage/2024-10-09-plans11.jpg);background-size:cover;background-position:center;overflow:hidden}
.titleBox::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#590c97e0 0%,#f423bcd1 50%,#4dc2eec2 100%);z-index:1}
.titleBox::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,#ffffff0a 0%,transparent 50%),radial-gradient(circle at 80% 70%,#ffffff08 0%,transparent 50%);z-index:2}
.titleBox .contentWrap{position:relative;z-index:3;max-width:900px;margin:0 auto;padding:40px 20px;text-align:center}
.titleBox h1{font-size:3.2rem;color:#fff;font-weight:700;margin:0 0 24px;line-height:1.2}
.titleBox h1 .numAccent{display:inline-block;color:#4DC2EE;font-size:4rem;font-weight:800;margin-right:12px}
.titleBox .explanation{font-size:1.25rem;color:#fffffff0;line-height:1.6;max-width:720px;margin:0 auto}
@media (max-width: 768px) {
.titleBox{min-height:360px}
.titleBox h1{font-size:2.2rem}
.titleBox h1 .numAccent{font-size:2.8rem}
.titleBox .explanation{font-size:1.1rem}
}
.projectsGrid{max-width:1400px;margin:80px auto;padding:0 20px}
.projectsGrid h2{font-size:2.4rem;color:#590C97;margin:0 0 48px;text-align:center;font-weight:600}
.gridLayout{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px}
.projectCard{background:#fff;border:2px solid #f0f0f0;border-radius:8px;padding:32px;transition:all 220ms ease-in-out;position:relative}
.projectCard::before{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:linear-gradient(180deg,#590C97 0%,#F423BC 50%,#4DC2EE 100%);transition:height 220ms ease-in-out;border-radius:8px 0 0 8px}
.projectCard:hover{transform:translateY(-4px);box-shadow:0 12px 24px #590c9726;border-color:#590C97}
.projectCard:hover::before{height:100%}
.projectCard h3{font-size:1.5rem;color:#590C97;margin:0 0 16px;font-weight:600}
.projectCard .student{font-size:.95rem;color:#F423BC;margin:0 0 20px;font-weight:500}
.projectCard .desc{font-size:1rem;color:#444;line-height:1.7;margin:0 0 24px}
.projectCard .skills{display:flex;flex-wrap:wrap;gap:8px}
.projectCard .skills span{background:linear-gradient(135deg,#590C97 0%,#F423BC 100%);color:#fff;font-size:.85rem;padding:6px 14px;border-radius:20px;font-weight:500}
@media (max-width: 768px) {
.projectsGrid{margin:60px auto}
.projectsGrid h2{font-size:2rem}
.gridLayout{grid-template-columns:1fr;gap:24px}
}
.showcaseBlock{background:linear-gradient(160deg,#f8f4fb 0%,#fef8fd 50%,#f3fbfe 100%);padding:80px 0;position:relative;overflow:hidden}
.showcaseBlock::before{content:'';position:absolute;width:600px;height:600px;background:radial-gradient(circle,#f423bc14 0%,transparent 70%);top:-200px;right:-150px;z-index:0}
.showcaseBlock .innerWrap{max-width:1400px;margin:0 auto;padding:0 20px;position:relative;z-index:1}
.showcaseBlock h2{font-size:2.6rem;color:#590C97;margin:0 0 20px;font-weight:600}
.showcaseBlock .intro{font-size:1.15rem;color:#555;line-height:1.8;margin:0 0 48px;max-width:800px}
.splitContent{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.splitContent .imageBox{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 16px 40px #590c972e}
.splitContent .imageBox img{width:100%;height:480px;object-fit:cover;display:block}
.splitContent .textBox{padding:20px 0}
.splitContent .textBox h3{font-size:1.8rem;color:#590C97;margin:0 0 24px;font-weight:600;position:relative;padding-left:20px}
.splitContent .textBox h3::before{content:'';position:absolute;left:0;top:8px;width:6px;height:32px;background:linear-gradient(180deg,#F423BC 0%,#4DC2EE 100%);border-radius:3px}
.splitContent .textBox p{font-size:1.05rem;color:#555;line-height:1.8;margin:0 0 20px}
.splitContent .textBox .highlight{background:linear-gradient(120deg,#f423bc1f 0%,#4dc2ee1f 100%);border-left:4px solid #F423BC;padding:20px 24px;margin:32px 0 0;border-radius:6px}
.splitContent .textBox .highlight p{margin:0;font-size:1.05rem;color:#590C97;font-weight:500;line-height:1.7}
@media (max-width: 992px) {
.splitContent{grid-template-columns:1fr;gap:40px}
.splitContent .imageBox img{height:360px}
.showcaseBlock h2{font-size:2.2rem}
}
@media (max-width: 768px) {
.showcaseBlock{padding:60px 0}
.showcaseBlock h2{font-size:1.9rem}
.splitContent .textBox h3{font-size:1.5rem}
}
.successWrapper{min-height:85vh;display:flex;align-items:center;justify-content:center;padding:60px 20px;background:linear-gradient(135deg,#f8f3fc 0%,#fff 50%,#f0f9fd 100%);position:relative;overflow:hidden}
.successWrapper::before{content:'';position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,#4cc2ee14 0%,transparent 70%);border-radius:50%}
.successWrapper::after{content:'';position:absolute;bottom:-30%;left:-15%;width:500px;height:500px;background:radial-gradient(circle,#f423bc0f 0%,transparent 70%);border-radius:50%}
.successContent{max-width:680px;width:100%;text-align:center;position:relative;z-index:1;background:#ffffffd9;backdrop-filter:blur(10px);border-radius:16px;padding:70px 50px;box-shadow:0 8px 32px #590c9714;border:1px solid #590c970f}
.checkmarkZone{width:110px;height:110px;margin:0 auto 35px;position:relative}
.checkmarkCircle{width:110px;height:110px;border-radius:50%;background:linear-gradient(135deg,#590C97 0%,#F423BC 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px #590c9740;animation:scaleIn .5s ease-out}
@keyframes scaleIn {
0%{transform:scale(0);opacity:0}
50%{transform:scale(1.1)}
100%{transform:scale(1);opacity:1}
}
.checkmarkSvg{width:58px;height:58px}
.checkmarkPath{fill:none;stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:100;stroke-dashoffset:100;animation:drawCheck .6s ease-out .3s forwards}
@keyframes drawCheck {
to{stroke-dashoffset:0}
}
.successContent h1{font-size:42px;font-weight:700;color:#1a1a1a;margin:0 0 20px;line-height:1.2}
.successContent h1::after{content:'';display:block;width:80px;height:4px;background:linear-gradient(90deg,#590C97 0%,#F423BC 50%,#4DC2EE 100%);margin:25px auto 0;border-radius:2px}
.confirmText{font-size:18px;line-height:1.7;color:#4a4a4a;margin:0 0 16px}
.detailNote{font-size:16px;line-height:1.6;color:#6b6b6b;margin:0 0 40px}
.actionRow{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.primaryBtn{display:inline-block;padding:16px 42px;background:linear-gradient(135deg,#590C97 0%,#F423BC 100%);color:#fff;text-decoration:none;border-radius:8px;font-size:16px;font-weight:600;transition:all .2s ease;box-shadow:0 4px 16px #590c9740;border:none}
.primaryBtn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #590c9759}
.secondaryBtn{display:inline-block;padding:16px 42px;background:#fff;color:#590C97;text-decoration:none;border-radius:8px;font-size:16px;font-weight:600;transition:all .2s ease;border:2px solid #590C97}
.secondaryBtn:hover{background:#590C97;color:#fff;transform:translateY(-2px)}
.infoGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-top:45px;padding-top:35px;border-top:1px solid #590c971a}
.infoBox{text-align:center}
.infoIcon{width:44px;height:44px;margin:0 auto 12px;background:linear-gradient(135deg,#590c971a 0%,#f423bc1a 100%);border-radius:50%;display:flex;align-items:center;justify-content:center}
.infoIcon svg{width:22px;height:22px;fill:#590C97}
.infoLabel{font-size:14px;font-weight:600;color:#590C97;margin:0 0 6px}
.infoValue{font-size:13px;color:#6b6b6b;margin:0;line-height:1.5}
@media (max-width: 768px) {
.successWrapper{padding:40px 20px}
.successContent{padding:50px 30px}
.successContent h1{font-size:32px}
.confirmText{font-size:16px}
.detailNote{font-size:15px}
.actionRow{flex-direction:column;gap:14px}
.primaryBtn,.secondaryBtn{width:100%;padding:15px 30px}
.infoGrid{grid-template-columns:1fr;gap:25px}
.checkmarkZone{width:90px;height:90px}
.checkmarkCircle{width:90px;height:90px}
.checkmarkSvg{width:48px;height:48px}
}
@media (max-width: 480px) {
.successContent h1{font-size:28px}
.successContent{padding:40px 25px}
}