:root{--primary-color:#858DAB;--secondary-color:#B1B8C0;--tertiary-color:#D7D7DF;--text-dark:#212529;--text-medium:#495057;--bg-light:#fafbfc;--bg-white:#fff;--bg-cream:#f8f9fa;--shadow-sm:0 1px 3px #858dab1f;--shadow-md:0 4px 12px #858dab26;--shadow-lg:0 8px 24px #858dab2e}
*{margin:0;padding:0;box-sizing:border-box}
body{color:var(--text-dark);background:var(--bg-light);overflow-x:hidden;font:17px/1.7 'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}
.brand_showcase_82{background:linear-gradient(135deg,var(--bg-white) 0%,#f5f6fa 100%);border-bottom:1px solid #858dab1a;padding:0}
.company_header_main{max-width:1340px;margin:0 auto;padding:0 24px}
.top_brand_row_47{display:flex;justify-content:center;align-items:center;padding:32px 0 28px;border-bottom:1px solid #b1b8c026;position:relative}
.brand_text_container_93{text-align:center}
.company_name_display_61{font-size:clamp(2.2rem,4vw,3.1rem);font-weight:700;color:var(--text-dark);letter-spacing:-.02em;margin-bottom:8px;line-height:1.1}
.tagline_descriptor_28{font-size:clamp(1rem,1.8vw,1.25rem);color:var(--text-medium);font-weight:400;letter-spacing:.01em}
.navigation_foundation_56{display:flex;justify-content:space-between;align-items:center;padding:24px 0;gap:40px}
.logo_container_left_19{flex-shrink:0;display:flex;align-items:center;z-index:10}
.site_logo_img_74{height:62px;width:62px;object-fit:contain;object-position:center;display:block;transition:opacity .25s ease}
.site_logo_img_74:hover{opacity:.82}
.primary_nav_right_35{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.nav_link_item_42{color:var(--text-dark);text-decoration:none;padding:11px 20px;border-radius:6px;font-weight:500;font-size:16px;transition:background-color .2s ease,color .2s ease;white-space:nowrap;position:relative}
.nav_link_item_42:hover{color:var(--primary-color);background:#858dab14}
.nav_link_item_42:focus{outline:2px solid var(--primary-color);outline-offset:2px}
.nav_link_item_42:active{background:#858dab24}
@media (max-width: 968px) {
.navigation_foundation_56{flex-direction:column;align-items:center;gap:24px;padding:28px 0}
.logo_container_left_19{margin-bottom:4px}
.primary_nav_right_35{justify-content:center;gap:6px}
.nav_link_item_42{padding:10px 16px;font-size:15px}
.top_brand_row_47{padding:26px 0 22px}
}
@media (max-width: 640px) {
.company_header_main{padding:0 18px}
.primary_nav_right_35{flex-direction:column;width:100%;gap:8px}
.nav_link_item_42{width:100%;text-align:center;padding:13px 20px}
.site_logo_img_74{height:56px;width:56px}
}
main{min-height:60vh}
.footer_master_container{background:linear-gradient(160deg,#2a2e3f 0%,#3d4256 100%);color:#e8e9ed;padding:64px 0 0;margin-top:80px;position:relative}
.footer_master_container::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,#858dab66 50%,transparent 100%)}
.footer_content_wrap_84{max-width:1340px;margin:0 auto;padding:0 24px}
.footer_grid_layout_73{display:grid;grid-template-columns:1.8fr 1fr 1fr;gap:56px;padding-bottom:48px;border-bottom:1px solid #d7d7df1f}
.footer_about_section_29{display:flex;flex-direction:column;gap:24px}
.footer_logo_block_51{display:flex;align-items:center;gap:16px}
.footer_logo_image_62{height:58px;width:58px;object-fit:contain;object-position:center}
.footer_company_title_18{font-size:1.6rem;font-weight:700;color:var(--bg-white);letter-spacing:-.01em}
.footer_description_text_94{color:#c5c8d1;line-height:1.7;font-size:15px;max-width:420px}
.contact_info_block_37{display:flex;flex-direction:column;gap:14px}
.contact_item_display_66{display:flex;align-items:flex-start;gap:12px;color:#d1d3db;font-size:15px;line-height:1.6}
.contact_icon_holder_45{color:var(--tertiary-color);margin-top:2px;flex-shrink:0}
.footer_links_column_82{display:flex;flex-direction:column;gap:12px}
.footer_column_heading_39{font-size:1.1rem;font-weight:600;color:var(--bg-white);margin-bottom:8px;letter-spacing:.01em}
.footer_nav_link_57{color:#c5c8d1;text-decoration:none;font-size:15px;transition:color .2s ease;display:inline-block;padding:4px 0}
.footer_nav_link_57:hover{color:var(--tertiary-color)}
.footer_nav_link_57:focus{outline:2px solid var(--tertiary-color);outline-offset:2px;border-radius:3px}
.footer_bottom_bar_26{padding:28px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.copyright_text_91{color:#b4b7c2;font-size:14px}
.footer_utility_links_48{display:flex;gap:24px;flex-wrap:wrap}
.utility_link_item_77{color:#c5c8d1;text-decoration:none;font-size:14px;transition:color .2s ease}
.utility_link_item_77:hover{color:var(--tertiary-color)}
@media (max-width: 968px) {
.footer_grid_layout_73{grid-template-columns:1fr 1fr;gap:40px}
.footer_about_section_29{grid-column:1 / -1}
}
@media (max-width: 640px) {
.footer_master_container{padding:48px 0 0;margin-top:60px}
.footer_content_wrap_84{padding:0 18px}
.footer_grid_layout_73{grid-template-columns:1fr;gap:36px}
.footer_bottom_bar_26{flex-direction:column;text-align:center;padding:24px 0}
.footer_utility_links_48{justify-content:center}
}
.consent_modal_wrapper_53{position:fixed;bottom:24px;right:24px;max-width:440px;background:var(--bg-white);border-radius:12px;box-shadow:0 12px 40px #21252938;padding:28px;z-index:9999;border:1px solid #858dab26;animation:slideInUp_79 .4s ease-out}
@keyframes slideInUp_79 {
from{transform:translateY(30px);opacity:0}
to{transform:translateY(0);opacity:1}
}
.consent_header_block_68{display:flex;gap:14px;margin-bottom:16px;align-items:flex-start}
.consent_icon_graphic_41{width:36px;height:36px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--bg-white);font-size:20px}
.consent_title_text_92{font-size:1.25rem;font-weight:600;color:var(--text-dark);line-height:1.3}
.consent_message_body_34{color:var(--text-medium);font-size:15px;line-height:1.65;margin-bottom:20px}
.consent_policy_link_85{color:var(--primary-color);text-decoration:underline;font-weight:500;transition:color .2s ease}
.consent_policy_link_85:hover{color:var(--secondary-color)}
.consent_actions_row_27{display:flex;gap:10px;flex-wrap:wrap}
.consent_btn_base_74{flex:1;min-width:120px;padding:12px 20px;border-radius:7px;font-size:15px;font-weight:600;cursor:pointer;transition:background-color .2s ease,transform .1s ease;border:none;font-family:inherit}
.consent_btn_base_74:focus{outline:2px solid var(--primary-color);outline-offset:2px}
.consent_btn_base_74:active{transform:scale(0.98)}
.consent_accept_btn_16{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:var(--bg-white)}
.consent_accept_btn_16:hover{background:linear-gradient(135deg,#7580a0,#a0a7b5)}
.consent_reject_btn_59{background:var(--bg-cream);color:var(--text-dark);border:1px solid #858dab33}
.consent_reject_btn_59:hover{background:#858dab1f}
.consent_hidden_state_38{display:none}
@media (max-width: 640px) {
.consent_modal_wrapper_53{bottom:16px;right:16px;left:16px;max-width:none;padding:24px}
.consent_actions_row_27{flex-direction:column}
.consent_btn_base_74{width:100%}
}
.index-hero-section{position:relative;min-height:85vh;display:flex;align-items:center;background:linear-gradient(135deg,#f8f9fa 0%,#fafbfc 50%,#D7D7DF 100%);overflow:hidden;padding:4rem 0}
.index-hero-content-wrapper{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.index-hero-text-block h1{font-size:3.2rem;line-height:1.1;color:#212529;margin-bottom:1.5rem;font-weight:700}
.index-hero-text-block p{font-size:1.15rem;line-height:1.7;color:#495057;margin-bottom:2rem}
.index-hero-cta-button{display:inline-block;padding:1rem 2.5rem;background:#858DAB;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.05rem;transition:all .3s ease;box-shadow:0 4px 15px #858dab33}
.index-hero-cta-button:hover{background:#6b7492;transform:translateY(-2px);box-shadow:0 6px 20px #858dab4d}
.index-hero-image-container{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 15px 50px #0000001f}
.index-hero-image-container img{width:100%;height:450px;object-fit:cover;display:block}
.index-approach-section{background:#fff;padding:5rem 0}
.index-approach-container{max-width:1100px;margin:0 auto;padding:0 1.5rem}
.index-approach-header{text-align:center;margin-bottom:4rem}
.index-approach-header h2{font-size:2.5rem;color:#212529;margin-bottom:1rem;font-weight:700}
.index-approach-header p{font-size:1.1rem;color:#495057;max-width:700px;margin:0 auto;line-height:1.6}
.index-approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.index-approach-card{background:#fafbfc;padding:2rem;border-radius:12px;border-left:4px solid #858DAB;transition:all .3s ease}
.index-approach-card:hover{transform:translateX(8px);box-shadow:0 8px 25px #858dab26}
.index-approach-card h3{font-size:1.4rem;color:#212529;margin-bottom:1rem;font-weight:600}
.index-approach-card p{font-size:1rem;color:#495057;line-height:1.6}
.index-levels-showcase{background:linear-gradient(180deg,#f8f9fa 0%,#fff 100%);padding:5rem 0;position:relative}
.index-levels-wrapper{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:45% 55%;gap:3rem;align-items:center}
.index-levels-image-box{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 12px 40px #0000001a}
.index-levels-image-box img{width:100%;height:480px;object-fit:cover;display:block}
.index-levels-content h2{font-size:2.3rem;color:#212529;margin-bottom:1.5rem;font-weight:700}
.index-levels-list{list-style:none;padding:0;margin:0}
.index-levels-list li{padding:1.2rem 0;border-bottom:1px solid #D7D7DF;font-size:1.05rem;color:#495057;line-height:1.6;position:relative;padding-left:2rem}
.index-levels-list li:before{content:"→";position:absolute;left:0;color:#858DAB;font-weight:700;font-size:1.2rem}
.index-levels-list li:last-child{border-bottom:none}
.index-transformation-section{background:#fff;padding:5rem 0}
.index-transformation-inner{max-width:1150px;margin:0 auto;padding:0 1.5rem}
.index-transformation-title{text-align:center;margin-bottom:3.5rem}
.index-transformation-title h2{font-size:2.4rem;color:#212529;margin-bottom:1rem;font-weight:700}
.index-transformation-layout{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.index-transformation-block{background:linear-gradient(135deg,#fafbfc 0%,#f8f9fa 100%);padding:2.5rem;border-radius:14px;box-shadow:0 6px 20px #0000000f;position:relative}
.index-transformation-block:before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;background:#858DAB;border-radius:14px 0 0 14px}
.index-transformation-block h3{font-size:1.5rem;color:#212529;margin-bottom:1.2rem;font-weight:600}
.index-transformation-block p{font-size:1rem;color:#495057;line-height:1.7;margin-bottom:1rem}
.index-immersion-section{background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);padding:5.5rem 0;position:relative}
.index-immersion-container{max-width:1100px;margin:0 auto;padding:0 1.5rem}
.index-immersion-header{text-align:center;margin-bottom:3rem}
.index-immersion-header h2{font-size:2.6rem;color:#fff;margin-bottom:1rem;font-weight:700}
.index-immersion-header p{font-size:1.15rem;color:#fafbfc;max-width:750px;margin:0 auto;line-height:1.6}
.index-immersion-flex{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}
.index-immersion-card{background:#fffffff2;padding:2rem;border-radius:12px;box-shadow:0 8px 30px #00000026;position:relative;overflow:hidden}
.index-immersion-card:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#858DAB 0%,#B1B8C0 100%)}
.index-immersion-card h3{font-size:1.4rem;color:#212529;margin-bottom:1rem;font-weight:600}
.index-immersion-card p{font-size:1rem;color:#495057;line-height:1.7}
.index-metrics-showcase{background:#fff;padding:5rem 0}
.index-metrics-wrapper{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:50% 50%;gap:3rem;align-items:center}
.index-metrics-visual{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 14px 45px #0000001f}
.index-metrics-visual img{width:100%;height:500px;object-fit:cover;display:block}
.index-metrics-content h2{font-size:2.4rem;color:#212529;margin-bottom:1.5rem;font-weight:700}
.index-metrics-content p{font-size:1.05rem;color:#495057;line-height:1.7;margin-bottom:2rem}
.index-metrics-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:2rem}
.index-metrics-stat-box{background:#f8f9fa;padding:1.5rem;border-radius:10px;text-align:center;border:2px solid #D7D7DF;transition:all .3s ease}
.index-metrics-stat-box:hover{border-color:#858DAB;transform:scale(1.05)}
.index-metrics-stat-box .stat-number{font-size:2rem;color:#858DAB;font-weight:700;display:block;margin-bottom:.5rem}
.index-metrics-stat-box .stat-label{font-size:.95rem;color:#495057;font-weight:500}
.index-final-cta-section{background:linear-gradient(180deg,#f8f9fa 0%,#fafbfc 100%);padding:6rem 0;text-align:center}
.index-final-cta-container{max-width:900px;margin:0 auto;padding:0 1.5rem}
.index-final-cta-container h2{font-size:2.8rem;color:#212529;margin-bottom:1.5rem;font-weight:700}
.index-final-cta-container p{font-size:1.2rem;color:#495057;line-height:1.7;margin-bottom:2.5rem}
.index-final-cta-buttons{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.index-final-primary-btn{display:inline-block;padding:1.1rem 3rem;background:#858DAB;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.1rem;transition:all .3s ease;box-shadow:0 5px 18px #858dab40}
.index-final-primary-btn:hover{background:#6b7492;transform:translateY(-3px);box-shadow:0 8px 25px #858dab59}
.index-final-secondary-btn{display:inline-block;padding:1.1rem 3rem;background:#fff;color:#858DAB;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.1rem;border:2px solid #858DAB;transition:all .3s ease}
.index-final-secondary-btn:hover{background:#858DAB;color:#fff;transform:translateY(-3px)}
@media (max-width: 968px) {
.index-hero-content-wrapper{grid-template-columns:1fr;gap:2rem}
.index-hero-text-block h1{font-size:2.4rem}
.index-hero-image-container img{height:350px}
.index-approach-grid{grid-template-columns:1fr}
.index-levels-wrapper{grid-template-columns:1fr}
.index-levels-image-box img{height:380px}
.index-transformation-layout{grid-template-columns:1fr}
.index-immersion-flex{grid-template-columns:1fr}
.index-metrics-wrapper{grid-template-columns:1fr}
.index-metrics-visual img{height:380px}
.index-metrics-stats-grid{grid-template-columns:1fr}
.index-final-cta-buttons{flex-direction:column;align-items:center}
.index-final-primary-btn,.index-final-secondary-btn{width:100%;max-width:320px}
}
@media (max-width: 640px) {
.index-hero-text-block h1{font-size:2rem}
.index-approach-header h2,.index-transformation-title h2,.index-immersion-header h2,.index-metrics-content h2,.index-final-cta-container h2{font-size:1.9rem}
.index-hero-section{min-height:auto;padding:3rem 0}
.index-approach-section,.index-levels-showcase,.index-transformation-section,.index-immersion-section,.index-metrics-showcase,.index-final-cta-section{padding:3rem 0}
}
.contact-wrapper-2025{background:linear-gradient(135deg,#fafbfc 0%,#f8f9fa 100%);min-height:100vh;padding:0;margin:0}
.contact-hero-japanese{background:linear-gradient(to right,#fff 0%,#f5f6fa 100%);padding:80px 20px 60px;position:relative;overflow:hidden}
.contact-hero-japanese::before{content:'';position:absolute;top:-50%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,#858dab14 0%,transparent 70%);border-radius:50%;z-index:1}
.hero-content-contact{max-width:680px;margin:0 auto;position:relative;z-index:2;text-align:center}
.hero-content-contact h1{font-size:2.8rem;color:#212529;margin:0 0 20px;font-weight:700;line-height:1.2}
.hero-content-contact .subtitle-text{font-size:1.15rem;color:#495057;line-height:1.7;margin:0}
.info-map-section{padding:70px 20px;background:#fff}
.info-map-container{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-details-block{background:#fafbfc;padding:45px;border-radius:12px;border:1px solid #D7D7DF}
.contact-details-block h2{font-size:1.9rem;color:#212529;margin:0 0 30px;font-weight:600}
.detail-item-contact{margin-bottom:28px;display:flex;align-items:start;gap:15px}
.detail-item-contact:last-child{margin-bottom:0}
.icon-circle-contact{width:48px;height:48px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:1.3rem}
.detail-text-contact{flex:1}
.detail-text-contact .label-contact{font-size:.85rem;color:#858DAB;text-transform:uppercase;letter-spacing:.5px;margin:0 0 5px;font-weight:600}
.detail-text-contact .value-contact{font-size:1.05rem;color:#212529;margin:0;line-height:1.6}
.detail-text-contact a{color:#495057;text-decoration:none;transition:color .3s ease}
.detail-text-contact a:hover{color:#858DAB}
.image-location-block{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #858dab26}
.image-location-block img{width:100%;height:420px;object-fit:cover;display:block}
.form-section-japanese{padding:80px 20px;background:linear-gradient(180deg,#f5f6fa 0%,#fff 100%)}
.form-container-wrap{max-width:750px;margin:0 auto}
.form-container-wrap h2{font-size:2.2rem;color:#212529;margin:0 0 15px;font-weight:600;text-align:center}
.form-intro-text{font-size:1.05rem;color:#495057;line-height:1.7;text-align:center;margin:0 0 45px;max-width:580px;margin-left:auto;margin-right:auto}
.contact-form-japanese{background:#fff;padding:50px;border-radius:12px;box-shadow:0 2px 15px #858dab1f;border:1px solid #D7D7DF}
.form-row-double{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.form-group-contact{margin-bottom:20px}
.form-group-contact label{display:block;font-size:.95rem;color:#343a40;margin-bottom:8px;font-weight:500}
.form-group-contact input,.form-group-contact textarea,.form-group-contact select{width:100%;padding:14px 16px;border:2px solid #D7D7DF;border-radius:8px;font-size:1rem;color:#212529;background:#fafbfc;transition:all .3s ease;font-family:inherit}
.form-group-contact input:focus,.form-group-contact textarea:focus,.form-group-contact select:focus{outline:none;border-color:#858DAB;background:#fff;box-shadow:0 0 0 3px #858dab1a}
.form-group-contact textarea{resize:vertical;min-height:140px}
.checkbox-group-privacy{margin:30px 0;display:flex;align-items:start;gap:12px}
.checkbox-group-privacy input[type="checkbox"]{width:20px;height:20px;margin-top:2px;cursor:pointer;flex-shrink:0}
.checkbox-group-privacy label{font-size:.95rem;color:#495057;line-height:1.6;cursor:pointer}
.checkbox-group-privacy a{color:#858DAB;text-decoration:underline;transition:color .3s ease}
.checkbox-group-privacy a:hover{color:#495057}
.submit-btn-contact{width:100%;padding:16px 32px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}
.submit-btn-contact:hover{transform:translateY(-2px);box-shadow:0 6px 20px #858dab4d}
.hours-info-section{padding:70px 20px;background:#fff}
.hours-content-wrapper{max-width:900px;margin:0 auto;text-align:center}
.hours-content-wrapper h2{font-size:2rem;color:#212529;margin:0 0 40px;font-weight:600}
.hours-grid-display{display:grid;grid-template-columns:repeat(3,1fr);gap:25px;margin-bottom:35px}
.hour-card-item{background:#fafbfc;padding:30px 20px;border-radius:10px;border:2px solid #D7D7DF;transition:all .3s ease}
.hour-card-item:hover{border-color:#858DAB;transform:translateY(-3px);box-shadow:0 4px 15px #858dab26}
.hour-card-item .day-name{font-size:1.1rem;color:#858DAB;font-weight:600;margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}
.hour-card-item .time-range{font-size:1.05rem;color:#343a40;margin:0}
.additional-note-hours{font-size:1rem;color:#495057;line-height:1.7;max-width:600px;margin:0 auto}
.cta-final-section{padding:80px 20px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);text-align:center;position:relative;overflow:hidden}
.cta-final-section::before{content:'';position:absolute;top:-30%;left:-15%;width:500px;height:500px;background:radial-gradient(circle,#ffffff1a 0%,transparent 70%);border-radius:50%}
.cta-content-final{max-width:700px;margin:0 auto;position:relative;z-index:2}
.cta-content-final h2{font-size:2.3rem;color:#fff;margin:0 0 20px;font-weight:700}
.cta-content-final p{font-size:1.15rem;color:#fff;line-height:1.7;margin:0 0 35px;opacity:.95}
.cta-btn-home{display:inline-block;padding:16px 45px;background:#fff;color:#858DAB;text-decoration:none;border-radius:8px;font-size:1.05rem;font-weight:600;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}
.cta-btn-home:hover{transform:translateY(-3px);box-shadow:0 6px 25px #0003;background:#f8f9fa}
@media (max-width: 968px) {
.info-map-container{grid-template-columns:1fr;gap:40px}
.hours-grid-display{grid-template-columns:repeat(2,1fr);gap:20px}
.form-row-double{grid-template-columns:1fr;gap:20px}
}
@media (max-width: 768px) {
.contact-hero-japanese{padding:60px 20px 40px}
.hero-content-contact h1{font-size:2.2rem}
.hero-content-contact .subtitle-text{font-size:1.05rem}
.contact-details-block{padding:35px 25px}
.contact-form-japanese{padding:35px 25px}
.hours-grid-display{grid-template-columns:1fr}
.cta-content-final h2{font-size:1.9rem}
.image-location-block img{height:300px}
}
@media (max-width: 480px) {
.hero-content-contact h1{font-size:1.8rem}
.form-container-wrap h2{font-size:1.8rem}
.contact-details-block{padding:25px 20px}
.contact-form-japanese{padding:25px 20px}
.detail-item-contact{flex-direction:column;align-items:center;text-align:center}
}
.about-page-wrapper{background:#fff;color:#212529;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;line-height:1.7}
.about-hero-section{background:linear-gradient(135deg,#f8f9fa 0%,#fff 100%);padding:80px 20px 60px;position:relative;overflow:hidden}
.about-hero-section::before{content:'';position:absolute;top:-50%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,#858dab14 0%,transparent 70%);border-radius:50%;z-index:1}
.about-hero-content{max-width:800px;margin:0 auto;position:relative;z-index:2;text-align:center}
.about-hero-content h1{font-size:2.8rem;font-weight:700;color:#212529;margin-bottom:24px;letter-spacing:-.5px}
.about-hero-content .hero-subtitle{font-size:1.25rem;color:#495057;margin-bottom:0;font-weight:400}
.journey-timeline-section{padding:90px 20px;background:#fafbfc;position:relative}
.journey-timeline-section::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,#D7D7DF 50%,transparent 100%)}
.timeline-header{text-align:center;margin-bottom:70px}
.timeline-header h2{font-size:2.4rem;color:#212529;margin-bottom:20px;font-weight:700}
.timeline-header p{font-size:1.1rem;color:#495057;max-width:680px;margin:0 auto}
.timeline-container{max-width:1100px;margin:0 auto;position:relative}
.timeline-items-wrapper{display:flex;flex-direction:column;gap:0}
.timeline-item{display:grid;grid-template-columns:1fr 80px 1fr;gap:40px;align-items:center;margin-bottom:60px;position:relative}
.timeline-item:last-child{margin-bottom:0}
.timeline-content-left,.timeline-content-right{background:#fff;padding:32px;border-radius:12px;box-shadow:0 2px 12px #0000000f;border:1px solid #D7D7DF;position:relative}
.timeline-content-left{text-align:right;grid-column:1}
.timeline-content-right{text-align:left;grid-column:3}
.timeline-item:nth-child(even) .timeline-content-left{grid-column:3;text-align:left}
.timeline-item:nth-child(even) .timeline-content-right{grid-column:1;text-align:right}
.timeline-year{font-size:1.8rem;font-weight:700;color:#858DAB;margin-bottom:12px;display:block}
.timeline-content-left h3,.timeline-content-right h3{font-size:1.4rem;color:#212529;margin-bottom:14px;font-weight:600}
.timeline-content-left p,.timeline-content-right p{font-size:1rem;color:#495057;margin:0;line-height:1.6}
.timeline-marker-wrapper{grid-column:2;display:flex;flex-direction:column;align-items:center;position:relative;z-index:3}
.timeline-marker{width:24px;height:24px;background:#858DAB;border-radius:50%;border:4px solid #fff;box-shadow:0 0 0 3px #D7D7DF;position:relative;z-index:4}
.timeline-line{position:absolute;width:3px;background:linear-gradient(180deg,#D7D7DF 0%,#B1B8C0 100%);left:50%;transform:translateX(-50%);top:24px;bottom:-60px;z-index:1}
.timeline-item:last-child .timeline-line{display:none}
.timeline-image-container{margin-top:16px;border-radius:8px;overflow:hidden;border:1px solid #D7D7DF}
.timeline-image-container img{width:100%;height:200px;object-fit:cover;display:block}
.values-section{padding:90px 20px;background:#fff;position:relative}
.values-section::before{content:'';position:absolute;top:-2px;left:50%;transform:translateX(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent 0%,#858DAB 50%,transparent 100%)}
.values-header{text-align:center;margin-bottom:70px}
.values-header h2{font-size:2.4rem;color:#212529;margin-bottom:20px;font-weight:700}
.values-header p{font-size:1.1rem;color:#495057;max-width:700px;margin:0 auto}
.values-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:40px}
.value-card{background:linear-gradient(135deg,#f8f9fa 0%,#fff 100%);padding:40px;border-radius:16px;border:2px solid #D7D7DF;position:relative;transition:all .3s ease}
.value-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #858dab26;border-color:#858DAB}
.value-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#858DAB 0%,#B1B8C0 100%);border-radius:16px 0 0 16px}
.value-icon{width:56px;height:56px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;font-size:1.8rem;color:#fff}
.value-card h3{font-size:1.5rem;color:#212529;margin-bottom:16px;font-weight:600}
.value-card p{font-size:1rem;color:#495057;line-height:1.7;margin-bottom:16px}
.value-example{background:#fff;padding:20px;border-radius:8px;border-left:3px solid #858DAB;margin-top:20px}
.value-example-label{font-size:.85rem;text-transform:uppercase;letter-spacing:1px;color:#858DAB;font-weight:600;margin-bottom:8px}
.value-example p{font-size:.95rem;color:#343a40;margin:0;font-style:italic}
.commitment-section{padding:90px 20px;background:linear-gradient(180deg,#fafbfc 0%,#fff 100%);position:relative}
.commitment-content-wrapper{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.commitment-text-block h2{font-size:2.4rem;color:#212529;margin-bottom:24px;font-weight:700;line-height:1.3}
.commitment-text-block p{font-size:1.05rem;color:#495057;line-height:1.8;margin-bottom:20px}
.commitment-highlights{margin-top:32px}
.highlight-item{display:flex;align-items:flex-start;margin-bottom:24px;gap:16px}
.highlight-icon{width:40px;height:40px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-weight:700;font-size:1.2rem}
.highlight-text h4{font-size:1.1rem;color:#212529;margin-bottom:6px;font-weight:600}
.highlight-text p{font-size:.95rem;color:#495057;margin:0}
.commitment-visual-block{position:relative}
.commitment-image-main{border-radius:16px;overflow:hidden;box-shadow:0 12px 32px #0000001f;border:3px solid #D7D7DF}
.commitment-image-main img{width:100%;height:450px;object-fit:cover;display:block}
.commitment-decorative{position:absolute;bottom:-20px;right:-20px;width:180px;height:180px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:50%;opacity:.15;z-index:-1}
@media (max-width: 968px) {
.about-hero-content h1{font-size:2.2rem}
.timeline-item{grid-template-columns:1fr;gap:20px;margin-bottom:50px;padding-left:60px;position:relative}
.timeline-content-left,.timeline-content-right{grid-column:1!important;text-align:left!important}
.timeline-marker-wrapper{position:absolute;left:0;top:8px;grid-column:auto}
.timeline-line{left:11px;transform:none}
.values-grid{grid-template-columns:1fr;gap:30px}
.commitment-content-wrapper{grid-template-columns:1fr;gap:40px}
.commitment-decorative{display:none}
}
@media (max-width: 640px) {
.about-hero-section{padding:60px 16px 40px}
.about-hero-content h1{font-size:1.8rem}
.about-hero-content .hero-subtitle{font-size:1.05rem}
.journey-timeline-section,.values-section,.commitment-section{padding:60px 16px}
.timeline-header h2,.values-header h2,.commitment-text-block h2{font-size:1.9rem}
.timeline-item{padding-left:50px}
.timeline-content-left,.timeline-content-right{padding:24px}
.value-card{padding:28px}
.commitment-image-main img{height:320px}
}
.tech-req-wrapper{background:#fff;min-height:100vh}
.tech-req-header-section{background:linear-gradient(135deg,#f8f9fa 0%,#fafbfc 100%);padding:5rem 0 4rem;position:relative;overflow:hidden}
.tech-req-header-section::before{content:'';position:absolute;top:-50%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,#858dab14 0%,transparent 70%);border-radius:50%}
.tech-req-header-section::after{content:'';position:absolute;bottom:-30%;left:-5%;width:400px;height:400px;background:radial-gradient(circle,#b1b8c00f 0%,transparent 70%);border-radius:50%}
.tech-req-header-content{max-width:900px;margin:0 auto;text-align:center;position:relative;z-index:2;padding:0 1.5rem}
.tech-req-main-title{font-size:2.8rem;font-weight:700;color:#212529;margin-bottom:1.5rem;line-height:1.2;letter-spacing:-.02em}
.tech-req-subtitle{font-size:1.25rem;color:#495057;line-height:1.6;margin-bottom:2rem}
.tech-req-intro-text{font-size:1.05rem;color:#6c757d;line-height:1.7;max-width:750px;margin:0 auto 2.5rem}
.tech-req-content-wrapper{max-width:1400px;margin:0 auto;padding:4rem 1.5rem}
.tech-req-main-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2.5rem;margin-bottom:4rem}
.tech-req-card{background:#fff;border:2px solid #f0f1f3;border-radius:12px;padding:2.5rem 2rem;position:relative;transition:all .3s ease}
.tech-req-card:hover{border-color:#858DAB;box-shadow:0 8px 24px #858dab1f;transform:translateY(-4px)}
.tech-req-card-icon{width:64px;height:64px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;font-size:1.8rem;color:#fff}
.tech-req-card-title{font-size:1.4rem;font-weight:700;color:#212529;margin-bottom:1rem}
.tech-req-card-desc{font-size:1rem;color:#6c757d;line-height:1.6;margin-bottom:1.5rem}
.tech-req-spec-list{list-style:none;padding:0;margin:0}
.tech-req-spec-list li{padding:.5rem 0;color:#495057;font-size:.95rem;position:relative;padding-left:1.5rem}
.tech-req-spec-list li::before{content:'';position:absolute;left:0;color:#858DAB;font-weight:700}
.tech-req-visual-section{background:linear-gradient(135deg,#f5f6fa 0%,#fafbfc 100%);padding:4rem 0;margin:4rem 0;border-radius:24px}
.tech-req-visual-container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.tech-req-image-showcase{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:stretch}
.tech-req-main-image{border-radius:16px;overflow:hidden;box-shadow:0 12px 32px #0000001a;height:100%}
.tech-req-main-image img{width:100%;height:100%;object-fit:cover;display:block}
.tech-req-side-images{display:flex;flex-direction:column;gap:2rem}
.tech-req-side-image{border-radius:16px;overflow:hidden;box-shadow:0 8px 24px #00000014;flex:1}
.tech-req-side-image img{width:100%;height:100%;object-fit:cover;display:block}
.tech-req-detailed-section{max-width:1200px;margin:5rem auto 0;padding:0 1.5rem}
.tech-req-detailed-title{font-size:2.2rem;font-weight:700;color:#212529;margin-bottom:3rem;text-align:center}
.tech-req-comparison-table{width:100%;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 16px #0000000f;margin-bottom:3rem}
.tech-req-table-header{background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);color:#fff;padding:1.5rem 2rem;font-size:1.3rem;font-weight:700}
.tech-req-table-content{padding:2.5rem 2rem}
.tech-req-table-row{display:grid;grid-template-columns:250px 1fr 1fr;gap:2rem;padding:1.5rem 0;border-bottom:1px solid #e9ecef;align-items:start}
.tech-req-table-row:last-child{border-bottom:none}
.tech-req-table-label{font-weight:700;color:#343a40;font-size:1.05rem}
.tech-req-table-item{color:#495057;font-size:.98rem;line-height:1.6}
.tech-req-table-item strong{color:#212529;display:block;margin-bottom:.3rem}
.tech-req-status-badge{display:inline-block;padding:.4rem .9rem;border-radius:6px;font-size:.9rem;font-weight:600;margin-top:.5rem}
.tech-req-status-required{background:#d7f0dd;color:#1e7e34}
.tech-req-status-recommended{background:#d4edfc;color:#0c5a8a}
.tech-req-status-optional{background:#f0f1f3;color:#495057}
.tech-req-important-note{background:linear-gradient(135deg,#fff9e6 0%,#fffbf0 100%);border-left:4px solid #858DAB;padding:2rem 2.5rem;border-radius:12px;margin:3rem 0}
.tech-req-note-title{font-size:1.2rem;font-weight:700;color:#212529;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.tech-req-note-text{color:#495057;line-height:1.7;font-size:1rem}
.tech-req-cta-section{text-align:center;padding:4rem 1.5rem 2rem;max-width:800px;margin:0 auto}
.tech-req-cta-title{font-size:1.8rem;font-weight:700;color:#212529;margin-bottom:1.5rem}
.tech-req-cta-text{font-size:1.1rem;color:#6c757d;line-height:1.6;margin-bottom:2rem}
.tech-req-cta-button{display:inline-block;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);color:#fff;padding:1rem 3rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .3s ease;box-shadow:0 4px 12px #858dab4d}
.tech-req-cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #858dab66;color:#fff}
@media (max-width: 992px) {
.tech-req-main-grid{grid-template-columns:1fr 1fr}
.tech-req-image-showcase{grid-template-columns:1fr}
.tech-req-side-images{flex-direction:row}
.tech-req-table-row{grid-template-columns:1fr;gap:1rem}
}
@media (max-width: 768px) {
.tech-req-header-section{padding:3rem 0 2rem}
.tech-req-main-title{font-size:2rem}
.tech-req-subtitle{font-size:1.1rem}
.tech-req-main-grid{grid-template-columns:1fr;gap:1.5rem}
.tech-req-card{padding:2rem 1.5rem}
.tech-req-content-wrapper{padding:2rem 1rem}
.tech-req-visual-section{margin:2rem 0;padding:2rem 0}
.tech-req-side-images{flex-direction:column}
.tech-req-detailed-title{font-size:1.8rem}
.tech-req-table-content{padding:1.5rem 1rem}
.tech-req-important-note{padding:1.5rem}
}
.faq-page-wrapper{background:linear-gradient(135deg,#fafbfc 0%,#fff 100%);min-height:100vh}
.faq-hero-section{background:linear-gradient(165deg,#858DAB 0%,#B1B8C0 100%);padding:4rem 2rem 3rem;position:relative;overflow:hidden}
.faq-hero-section::before{content:'';position:absolute;top:-50%;right:-10%;width:600px;height:600px;background:#ffffff14;border-radius:50%;z-index:1}
.faq-hero-section::after{content:'';position:absolute;bottom:-30%;left:-5%;width:400px;height:400px;background:#ffffff0d;border-radius:50%;z-index:1}
.faq-hero-content{max-width:1200px;margin:0 auto;position:relative;z-index:2}
.faq-hero-content h1{color:#fff;font-size:2.8rem;font-weight:700;margin-bottom:1.2rem;line-height:1.2}
.faq-hero-subtitle{color:#fff;font-size:1.2rem;line-height:1.7;opacity:.95;max-width:700px}
.faq-questions-block{max-width:1200px;margin:0 auto;padding:5rem 2rem}
.faq-intro-text{text-align:center;margin-bottom:3.5rem}
.faq-intro-text h2{color:#212529;font-size:2.2rem;font-weight:600;margin-bottom:1rem}
.faq-intro-text p{color:#495057;font-size:1.1rem;line-height:1.7;max-width:750px;margin:0 auto}
.faq-grid-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:4rem}
.faq-question-card{background:#fff;border:2px solid #D7D7DF;border-radius:12px;padding:2rem;transition:all .3s ease;box-shadow:0 2px 8px #858dab14}
.faq-question-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #858dab26;border-color:#858DAB}
.faq-question-card h3{color:#858DAB;font-size:1.3rem;font-weight:600;margin-bottom:1rem;line-height:1.4}
.faq-question-card p{color:#495057;font-size:1rem;line-height:1.7;margin-bottom:0}
.faq-practical-section{background:#f8f9fa;padding:5rem 2rem;position:relative}
.faq-practical-container{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.faq-practical-content h2{color:#212529;font-size:2.4rem;font-weight:700;margin-bottom:1.5rem;line-height:1.3}
.faq-practical-list{list-style:none;padding:0;margin:2rem 0 0}
.faq-practical-list li{background:#fff;border-left:4px solid #858DAB;padding:1.5rem 1.8rem;margin-bottom:1.2rem;border-radius:8px;box-shadow:0 2px 6px #858dab14;transition:all .3s ease}
.faq-practical-list li:hover{border-left-color:#B1B8C0;box-shadow:0 4px 12px #858dab26}
.faq-practical-list strong{color:#212529;font-size:1.1rem;display:block;margin-bottom:.5rem;font-weight:600}
.faq-practical-list span{color:#495057;font-size:1rem;line-height:1.6}
.faq-practical-image{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 12px 30px #858dab33}
.faq-practical-image img{width:100%;height:550px;object-fit:cover;display:block}
.faq-learning-block{max-width:1200px;margin:0 auto;padding:5rem 2rem}
.faq-learning-header{text-align:center;margin-bottom:3rem}
.faq-learning-header h2{color:#212529;font-size:2.3rem;font-weight:700;margin-bottom:1.2rem}
.faq-learning-header p{color:#495057;font-size:1.1rem;line-height:1.7;max-width:800px;margin:0 auto}
.faq-dual-layout{display:flex;gap:3rem;margin-top:3rem;align-items:stretch}
.faq-dual-column{flex:1;background:#fff;border-radius:12px;padding:2.5rem;border:1px solid #D7D7DF;box-shadow:0 4px 12px #858dab14}
.faq-dual-column h3{color:#858DAB;font-size:1.6rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:3px solid #D7D7DF}
.faq-dual-column ul{list-style:none;padding:0;margin:0}
.faq-dual-column li{color:#495057;font-size:1rem;line-height:1.7;padding:.9rem 0;padding-left:1.8rem;position:relative;border-bottom:1px solid #f8f9fa}
.faq-dual-column li:last-child{border-bottom:none}
.faq-dual-column li::before{content:'→';position:absolute;left:0;color:#858DAB;font-weight:700;font-size:1.2rem}
.faq-image-showcase{margin-top:3rem;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px #858dab26}
.faq-image-showcase img{width:100%;height:450px;object-fit:cover;display:block}
.faq-contact-cta{background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);padding:4rem 2rem;text-align:center;margin-top:4rem;border-radius:16px;max-width:1000px;margin-left:auto;margin-right:auto}
.faq-contact-cta h3{color:#fff;font-size:2rem;font-weight:700;margin-bottom:1rem}
.faq-contact-cta p{color:#fff;font-size:1.1rem;line-height:1.6;margin-bottom:2rem;opacity:.95}
.faq-cta-button{display:inline-block;background:#fff;color:#858DAB;padding:1rem 2.5rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}
.faq-cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000026;background:#f8f9fa}
@media (max-width: 968px) {
.faq-hero-content h1{font-size:2.2rem}
.faq-practical-container{grid-template-columns:1fr;gap:2.5rem}
.faq-practical-image{order:-1}
.faq-practical-image img{height:400px}
.faq-dual-layout{flex-direction:column;gap:2rem}
.faq-grid-layout{grid-template-columns:1fr}
}
@media (max-width: 640px) {
.faq-hero-section{padding:3rem 1.5rem 2rem}
.faq-hero-content h1{font-size:1.8rem}
.faq-hero-subtitle{font-size:1rem}
.faq-questions-block{padding:3rem 1.5rem}
.faq-intro-text h2{font-size:1.8rem}
.faq-question-card{padding:1.5rem}
.faq-practical-section{padding:3rem 1.5rem}
.faq-practical-content h2{font-size:1.9rem}
.faq-practical-image img{height:300px}
.faq-learning-block{padding:3rem 1.5rem}
.faq-learning-header h2{font-size:1.8rem}
.faq-image-showcase img{height:300px}
.faq-contact-cta{padding:3rem 1.5rem;margin-top:3rem}
.faq-contact-cta h3{font-size:1.6rem}
}
.politique-cookies-page{background:linear-gradient(135deg,#fafbfc 0%,#f8f9fa 100%);min-height:100vh;padding:0;margin:0}
.cookies-hero-wrapper{background:linear-gradient(to bottom right,#858DAB,#B1B8C0);padding:80px 20px 60px;text-align:center;position:relative;overflow:hidden}
.cookies-hero-wrapper::before{content:'';position:absolute;top:-50%;right:-10%;width:500px;height:500px;background:#ffffff1a;border-radius:50%;z-index:1}
.cookies-hero-wrapper::after{content:'';position:absolute;bottom:-30%;left:-5%;width:400px;height:400px;background:#ffffff14;border-radius:50%;z-index:1}
.cookies-hero-content{max-width:800px;margin:0 auto;position:relative;z-index:2}
.cookies-hero-content h1{color:#fff;font-size:2.8em;font-weight:700;margin:0 0 20px;line-height:1.2}
.cookies-hero-subtitle{color:#f8f9fa;font-size:1.15em;line-height:1.6;margin:0}
.cookies-content-container{max-width:900px;margin:-40px auto 0;padding:0 20px 80px;position:relative;z-index:3}
.cookies-intro-card{background:#fff;border-radius:12px;padding:45px;margin-bottom:40px;box-shadow:0 4px 20px #858dab26}
.cookies-intro-card p{color:#495057;font-size:1.05em;line-height:1.8;margin:0 0 20px}
.cookies-intro-card p:last-child{margin-bottom:0}
.cookies-date-info{color:#858DAB;font-size:.95em;font-weight:600;margin-top:25px;padding-top:20px;border-top:2px solid #f5f6fa}
.cookies-section-block{background:#fff;border-radius:10px;padding:40px;margin-bottom:30px;box-shadow:0 2px 15px #b1b8c01f;border-left:4px solid #858DAB}
.cookies-section-block h2{color:#343a40;font-size:1.9em;font-weight:700;margin:0 0 25px;line-height:1.3}
.cookies-section-block h3{color:#495057;font-size:1.4em;font-weight:600;margin:30px 0 18px;line-height:1.4}
.cookies-section-block p{color:#495057;font-size:1.02em;line-height:1.8;margin:0 0 18px}
.cookies-section-block ul{margin:20px 0;padding-left:0;list-style:none}
.cookies-section-block ul li{color:#495057;font-size:1.02em;line-height:1.8;margin-bottom:15px;padding-left:35px;position:relative}
.cookies-section-block ul li::before{content:'●';color:#B1B8C0;font-size:1.3em;position:absolute;left:10px;top:-2px}
.cookies-types-grid{display:grid;grid-template-columns:1fr;gap:25px;margin:30px 0}
.cookie-type-card{background:linear-gradient(135deg,#f8f9fa 0%,#fff 100%);border:2px solid #D7D7DF;border-radius:8px;padding:30px;transition:all .3s ease}
.cookie-type-card:hover{border-color:#858DAB;box-shadow:0 6px 20px #858dab26;transform:translateY(-3px)}
.cookie-type-card h4{color:#343a40;font-size:1.3em;font-weight:700;margin:0 0 15px;display:flex;align-items:center}
.cookie-type-icon{width:40px;height:40px;background:#858DAB;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-right:15px;color:#fff;font-size:1.2em;font-weight:700}
.cookie-type-card p{color:#495057;font-size:1em;line-height:1.7;margin:0}
.cookies-management-box{background:linear-gradient(to right,#f5f6fa,#fafbfc);border:2px solid #B1B8C0;border-radius:10px;padding:35px;margin:30px 0}
.cookies-management-box h3{color:#343a40;font-size:1.5em;font-weight:700;margin:0 0 20px}
.cookies-management-box p{color:#495057;font-size:1.02em;line-height:1.8;margin-bottom:15px}
.browser-instructions{background:#fff;border-radius:8px;padding:25px;margin-top:25px}
.browser-instructions h4{color:#495057;font-size:1.2em;font-weight:600;margin:0 0 15px}
.browser-list{display:grid;grid-template-columns:1fr;gap:12px;margin:0;padding:0;list-style:none}
.browser-list li{color:#495057;font-size:1em;line-height:1.6;padding:12px 15px;background:#f8f9fa;border-radius:6px;border-left:3px solid #858DAB;position:relative;padding-left:15px}
.browser-list li::before{display:none}
.cookies-contact-final{background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:12px;padding:45px;text-align:center;margin-top:50px;color:#fff}
.cookies-contact-final h3{color:#fff;font-size:1.8em;font-weight:700;margin:0 0 20px}
.cookies-contact-final p{color:#f8f9fa;font-size:1.1em;line-height:1.7;margin:0 0 25px}
.cookies-contact-details{display:flex;flex-direction:column;gap:12px;align-items:center}
.cookies-contact-item{color:#fff;font-size:1.05em;font-weight:600;text-decoration:none;transition:all .3s ease}
.cookies-contact-item:hover{color:#D7D7DF;transform:scale(1.05)}
.emphasis-text{color:#858DAB;font-weight:600}
@media (max-width: 768px) {
.cookies-hero-wrapper{padding:60px 20px 50px}
.cookies-hero-content h1{font-size:2em}
.cookies-hero-subtitle{font-size:1.05em}
.cookies-intro-card{padding:30px 25px}
.cookies-section-block{padding:30px 25px}
.cookies-section-block h2{font-size:1.6em}
.cookies-section-block h3{font-size:1.25em}
.cookie-type-card{padding:25px 20px}
.cookies-management-box{padding:25px 20px}
.cookies-contact-final{padding:35px 25px}
.cookies-contact-final h3{font-size:1.5em}
}
@media (min-width: 769px) {
.cookies-types-grid{grid-template-columns:repeat(2,1fr)}
.browser-list{grid-template-columns:repeat(2,1fr)}
}
.politique-confidentialite-wrapper{background:linear-gradient(135deg,#fafbfc 0%,#f8f9fa 100%);min-height:100vh;padding:60px 20px}
.politique-confidentialite-wrapper .contenu-principal-politique{max-width:900px;margin:0 auto;background:#fff;padding:50px 40px;border-radius:8px;box-shadow:0 4px 20px #858dab26}
.politique-confidentialite-wrapper .en-tete-politique{text-align:center;margin-bottom:50px;padding-bottom:30px;border-bottom:3px solid #858DAB}
.politique-confidentialite-wrapper .titre-principal-politique{font-size:2.8rem;color:#212529;font-weight:700;margin-bottom:15px;letter-spacing:-.5px}
.politique-confidentialite-wrapper .date-mise-a-jour{font-size:1rem;color:#858DAB;font-weight:500}
.politique-confidentialite-wrapper .section-politique{margin-bottom:45px}
.politique-confidentialite-wrapper .titre-section-politique{font-size:1.9rem;color:#343a40;font-weight:600;margin-bottom:20px;padding-left:15px;border-left:4px solid #B1B8C0}
.politique-confidentialite-wrapper .sous-titre-politique{font-size:1.4rem;color:#495057;font-weight:600;margin-top:30px;margin-bottom:15px}
.politique-confidentialite-wrapper .paragraphe-politique{font-size:1.05rem;line-height:1.8;color:#343a40;margin-bottom:18px}
.politique-confidentialite-wrapper .liste-politique{margin:20px 0;padding-left:25px}
.politique-confidentialite-wrapper .liste-politique li{font-size:1.05rem;line-height:1.7;color:#343a40;margin-bottom:12px;position:relative}
.politique-confidentialite-wrapper .liste-politique li::marker{color:#858DAB;font-weight:700}
.politique-confidentialite-wrapper .encadre-important{background:linear-gradient(120deg,#f8f9fa 0%,#D7D7DF 100%);padding:25px 30px;border-radius:6px;border-left:5px solid #858DAB;margin:30px 0}
.politique-confidentialite-wrapper .encadre-important .paragraphe-politique{margin-bottom:10px}
.politique-confidentialite-wrapper .encadre-important:last-child .paragraphe-politique{margin-bottom:0}
.politique-confidentialite-wrapper .tableau-donnees{width:100%;border-collapse:collapse;margin:25px 0;background:#fff;border:1px solid #D7D7DF;border-radius:6px;overflow:hidden}
.politique-confidentialite-wrapper .tableau-donnees th{background:#858DAB;color:#fff;padding:15px;text-align:left;font-weight:600;font-size:1.05rem}
.politique-confidentialite-wrapper .tableau-donnees td{padding:15px;border-bottom:1px solid #D7D7DF;color:#343a40;font-size:1rem;line-height:1.6}
.politique-confidentialite-wrapper .tableau-donnees tr:last-child td{border-bottom:none}
.politique-confidentialite-wrapper .tableau-donnees tr:nth-child(even){background:#fafbfc}
.politique-confidentialite-wrapper .bloc-contact-rgpd{background:#fff;padding:35px;border:2px solid #B1B8C0;border-radius:8px;margin-top:40px}
.politique-confidentialite-wrapper .bloc-contact-rgpd .titre-contact{font-size:1.6rem;color:#212529;font-weight:600;margin-bottom:20px}
.politique-confidentialite-wrapper .info-contact-item{display:flex;align-items:baseline;margin-bottom:12px;font-size:1.05rem;color:#343a40}
.politique-confidentialite-wrapper .info-contact-item strong{color:#858DAB;min-width:120px;font-weight:600}
.politique-confidentialite-wrapper .lien-email-politique{color:#858DAB;text-decoration:none;font-weight:500;transition:color .3s ease}
.politique-confidentialite-wrapper .lien-email-politique:hover{color:#212529;text-decoration:underline}
.politique-confidentialite-wrapper .grille-droits-utilisateur{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:25px;margin:30px 0}
.politique-confidentialite-wrapper .carte-droit{background:#fafbfc;padding:25px;border-radius:6px;border:1px solid #D7D7DF;transition:transform .3s ease,box-shadow .3s ease}
.politique-confidentialite-wrapper .carte-droit:hover{transform:translateY(-3px);box-shadow:0 6px 18px #858dab33}
.politique-confidentialite-wrapper .carte-droit .titre-droit{font-size:1.2rem;color:#858DAB;font-weight:700;margin-bottom:12px}
.politique-confidentialite-wrapper .carte-droit .description-droit{font-size:1rem;color:#343a40;line-height:1.6}
@media (max-width: 768px) {
.politique-confidentialite-wrapper{padding:30px 15px}
.politique-confidentialite-wrapper .contenu-principal-politique{padding:30px 20px}
.politique-confidentialite-wrapper .titre-principal-politique{font-size:2rem}
.politique-confidentialite-wrapper .titre-section-politique{font-size:1.5rem}
.politique-confidentialite-wrapper .sous-titre-politique{font-size:1.2rem}
.politique-confidentialite-wrapper .paragraphe-politique,.politique-confidentialite-wrapper .liste-politique li{font-size:1rem}
.politique-confidentialite-wrapper .tableau-donnees{font-size:.9rem}
.politique-confidentialite-wrapper .tableau-donnees th,.politique-confidentialite-wrapper .tableau-donnees td{padding:10px}
.politique-confidentialite-wrapper .grille-droits-utilisateur{grid-template-columns:1fr}
.politique-confidentialite-wrapper .encadre-important{padding:20px}
}
@media (max-width: 480px) {
.politique-confidentialite-wrapper .titre-principal-politique{font-size:1.7rem}
.politique-confidentialite-wrapper .info-contact-item{flex-direction:column;align-items:flex-start}
.politique-confidentialite-wrapper .info-contact-item strong{margin-bottom:5px}
}
.confirmation-success-page{background:linear-gradient(135deg,#fafbfc 0%,#f8f9fa 100%);min-height:100vh;padding:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}
.success-hero-container{background:linear-gradient(165deg,#fff 0%,#f5f6fa 100%);padding:80px 20px 60px;text-align:center;position:relative;overflow:hidden}
.success-hero-container::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,#858dab0d 0%,transparent 70%);animation:pulse-circle 4s ease-in-out infinite}
@keyframes pulse-circle {
0%,100%{transform:scale(1);opacity:.3}
50%{transform:scale(1.1);opacity:.5}
}
.success-icon-wrapper{width:120px;height:120px;margin:0 auto 30px;position:relative;z-index:2}
.success-checkmark{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);display:flex;align-items:center;justify-content:center;animation:pop-in .6s cubic-bezier(0.68,-0.55,0.265,1.55);box-shadow:0 10px 40px #858dab4d}
@keyframes pop-in {
0%{transform:scale(0);opacity:0}
100%{transform:scale(1);opacity:1}
}
.success-checkmark::after{content:'';font-size:60px;color:#fff;font-weight:700;animation:check-draw .4s .3s ease-out forwards;opacity:0}
@keyframes check-draw {
to{opacity:1}
}
.success-main-heading{font-size:48px;font-weight:700;color:#212529;margin:0 0 20px;position:relative;z-index:2;animation:fade-slide-up .8s .2s ease-out backwards}
@keyframes fade-slide-up {
from{opacity:0;transform:translateY(20px)}
to{opacity:1;transform:translateY(0)}
}
.success-subheading-text{font-size:22px;color:#495057;max-width:600px;margin:0 auto;line-height:1.6;position:relative;z-index:2;animation:fade-slide-up .8s .4s ease-out backwards}
.confirmation-details-section{max-width:800px;margin:0 auto;padding:60px 20px}
.confirmation-card-box{background:#fff;border-radius:12px;padding:45px;box-shadow:0 4px 20px #858dab1f;border:1px solid #D7D7DF;margin-bottom:40px}
.confirmation-card-heading{font-size:28px;font-weight:600;color:#212529;margin:0 0 25px;padding-bottom:20px;border-bottom:2px solid #f5f6fa}
.confirmation-message-text{font-size:17px;line-height:1.8;color:#343a40;margin-bottom:20px}
.confirmation-message-text strong{color:#858DAB;font-weight:600}
.next-steps-list{list-style:none;padding:0;margin:30px 0 0}
.next-steps-list li{padding:18px 0 18px 50px;position:relative;font-size:16px;line-height:1.7;color:#495057;border-bottom:1px solid #f5f6fa}
.next-steps-list li:last-child{border-bottom:none}
.next-steps-list li::before{content:'';position:absolute;left:0;top:18px;width:32px;height:32px;background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:50%;display:flex;align-items:center;justify-content:center}
.next-steps-list li:nth-child(1)::after{content:'1';position:absolute;left:11px;top:24px;color:#fff;font-weight:700;font-size:14px}
.next-steps-list li:nth-child(2)::after{content:'2';position:absolute;left:11px;top:24px;color:#fff;font-weight:700;font-size:14px}
.next-steps-list li:nth-child(3)::after{content:'3';position:absolute;left:11px;top:24px;color:#fff;font-weight:700;font-size:14px}
.timing-info-box{background:linear-gradient(135deg,#f8f9fa 0%,#fafbfc 100%);border-left:4px solid #858DAB;padding:25px 30px;border-radius:8px;margin:35px 0}
.timing-info-box p{margin:0;font-size:16px;line-height:1.7;color:#343a40}
.action-buttons-container{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin:45px 0 0}
.primary-action-btn{background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);color:#fff;padding:16px 40px;border-radius:8px;text-decoration:none;font-size:17px;font-weight:600;transition:all .3s ease;border:none;box-shadow:0 4px 15px #858dab40;display:inline-block}
.primary-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #858dab59;background:linear-gradient(135deg,#B1B8C0 0%,#858DAB 100%)}
.secondary-action-btn{background:#fff;color:#858DAB;padding:16px 40px;border-radius:8px;text-decoration:none;font-size:17px;font-weight:600;transition:all .3s ease;border:2px solid #858DAB;display:inline-block}
.secondary-action-btn:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 15px #858dab26}
.resources-section-wrapper{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 20px #858dab1f;border:1px solid #D7D7DF}
.resources-heading-title{font-size:24px;font-weight:600;color:#212529;margin:0 0 30px;text-align:center}
.resources-grid-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:25px}
.resource-item-card{background:#fafbfc;padding:25px;border-radius:8px;border:1px solid #D7D7DF;transition:all .3s ease}
.resource-item-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #858dab26;border-color:#B1B8C0}
.resource-card-title{font-size:18px;font-weight:600;color:#858DAB;margin:0 0 12px}
.resource-card-description{font-size:15px;line-height:1.6;color:#495057;margin:0 0 15px}
.resource-card-link{color:#858DAB;text-decoration:none;font-weight:600;font-size:15px;transition:color .3s ease}
.resource-card-link:hover{color:#B1B8C0}
.contact-support-section{background:linear-gradient(135deg,#858DAB 0%,#B1B8C0 100%);border-radius:12px;padding:45px;text-align:center;margin-top:40px;color:#fff}
.support-section-heading{font-size:26px;font-weight:600;margin:0 0 20px;color:#fff}
.support-section-text{font-size:16px;line-height:1.7;margin:0 0 25px;opacity:.95}
.contact-info-links{display:flex;gap:30px;justify-content:center;flex-wrap:wrap;margin-top:20px}
.contact-link-item{color:#fff;text-decoration:none;font-size:16px;font-weight:500;transition:opacity .3s ease;display:flex;align-items:center;gap:8px}
.contact-link-item:hover{opacity:.8}
@media (max-width: 768px) {
.success-main-heading{font-size:36px}
.success-subheading-text{font-size:18px}
.confirmation-card-box{padding:30px 20px}
.confirmation-card-heading{font-size:24px}
.action-buttons-container{flex-direction:column;align-items:stretch}
.primary-action-btn,.secondary-action-btn{width:100%;text-align:center}
.resources-grid-layout{grid-template-columns:1fr}
.contact-support-section{padding:30px 20px}
.contact-info-links{flex-direction:column;gap:15px}
}
@media (max-width: 480px) {
.success-hero-container{padding:60px 15px 40px}
.success-icon-wrapper{width:90px;height:90px}
.success-checkmark{width:90px;height:90px}
.success-checkmark::after{font-size:45px}
.success-main-heading{font-size:28px}
.resources-section-wrapper{padding:25px 15px}
}
.error-page-wrapper{min-height:100vh;background:linear-gradient(135deg,#fafbfc 0%,#f8f9fa 50%,#fff 100%);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;position:relative;overflow:hidden}
.error-page-wrapper::before{content:'';position:absolute;top:-50%;right:-20%;width:70%;height:150%;background:radial-gradient(circle,#858dab14 0%,transparent 70%);pointer-events:none}
.error-page-wrapper::after{content:'';position:absolute;bottom:-30%;left:-15%;width:60%;height:120%;background:radial-gradient(circle,#b1b8c00f 0%,transparent 70%);pointer-events:none}
.error-content-container{max-width:800px;width:100%;position:relative;z-index:2}
.error-main-block{background:#fff;border-radius:16px;padding:3.5rem 2.5rem;box-shadow:0 8px 24px #858dab1f;text-align:center;position:relative;border:1px solid #d7d7df4d}
.error-visual-element{width:180px;height:180px;margin:0 auto 2rem;position:relative}
.error-visual-element svg{width:100%;height:100%}
.error-circle-outer{fill:none;stroke:#D7D7DF;stroke-width:3;opacity:.4}
.error-circle-middle{fill:none;stroke:#B1B8C0;stroke-width:2;stroke-dasharray:8 4;opacity:.6;animation:rotate-circle 20s linear infinite}
.error-circle-inner{fill:#858dab1a}
.error-text-404{fill:#858DAB;font-size:72px;font-weight:700;letter-spacing:-2px}
@keyframes rotate-circle {
from{transform:rotate(0deg)}
to{transform:rotate(360deg)}
}
.error-main-heading{font-size:2.2rem;color:#212529;margin:0 0 1rem;font-weight:700;line-height:1.3}
.error-description-text{font-size:1.1rem;color:#495057;line-height:1.7;margin:0 0 2rem;max-width:580px;margin-left:auto;margin-right:auto}
.error-actions-group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.error-btn-primary{display:inline-block;padding:1rem 2.5rem;background:#858DAB;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.05rem;transition:all .3s ease;border:2px solid #858DAB;box-shadow:0 4px 12px #858dab33}
.error-btn-primary:hover{background:#747c99;border-color:#747c99;transform:translateY(-2px);box-shadow:0 6px 16px #858dab4d}
.error-btn-secondary{display:inline-block;padding:1rem 2.5rem;background:none;color:#858DAB;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.05rem;transition:all .3s ease;border:2px solid #858DAB}
.error-btn-secondary:hover{background:#858dab14;transform:translateY(-2px)}
.error-suggestions-section{border-top:2px solid #f8f9fa;padding-top:2rem}
.error-suggestions-title{font-size:1.15rem;color:#343a40;margin:0 0 1.5rem;font-weight:600}
.error-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}
.error-link-card{background:#fafbfc;border:1px solid #D7D7DF;border-radius:8px;padding:1.2rem 1rem;text-decoration:none;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center}
.error-link-card:hover{background:#fff;border-color:#B1B8C0;transform:translateY(-3px);box-shadow:0 4px 12px #858dab26}
.error-link-icon{width:44px;height:44px;background:linear-gradient(135deg,#858DAB,#B1B8C0);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem;font-size:1.3rem;color:#fff}
.error-link-title{font-size:1rem;color:#495057;font-weight:600;margin:0}
.error-contact-info{background:linear-gradient(135deg,#858dab0d,#b1b8c00d);border-radius:8px;padding:1.5rem;margin-top:1.5rem}
.error-contact-title{font-size:1rem;color:#343a40;margin:0 0 1rem;font-weight:600}
.error-contact-details{display:flex;flex-direction:column;gap:.6rem}
.error-contact-item{color:#495057;font-size:.95rem;text-decoration:none;transition:color .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}
.error-contact-item:hover{color:#858DAB}
.error-contact-icon{font-size:1.1rem}
@media (max-width: 768px) {
.error-main-block{padding:2.5rem 1.5rem}
.error-main-heading{font-size:1.8rem}
.error-description-text{font-size:1rem}
.error-visual-element{width:140px;height:140px}
.error-text-404{font-size:56px}
.error-actions-group{flex-direction:column;gap:.75rem}
.error-btn-primary,.error-btn-secondary{width:100%;padding:.9rem 1.5rem}
.error-links-grid{grid-template-columns:1fr}
}
@media (max-width: 480px) {
.error-page-wrapper{padding:1rem .75rem}
.error-main-block{padding:2rem 1.25rem}
.error-visual-element{width:120px;height:120px}
.error-text-404{font-size:48px}
.error-main-heading{font-size:1.5rem}
}