/* ===== RENDERING & PERFORMANCE ===== */
html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,video{content-visibility:auto}
.reveal,.reveal-left,.reveal-right,.reveal-scale{will-change:opacity,transform}
.reveal.visible,.reveal-left.visible,.reveal-right.visible,.reveal-scale.visible{will-change:auto}

/* ===== PAGE LOADER ===== */
.page-loader{position:fixed;inset:0;z-index:9999;background:#fff;display:flex;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}
.page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== SCROLL PROGRESS ===== */
.scroll-progress{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-light));z-index:1001;transition:width 0.1s linear}

/* ===== RESET & VARIABLES ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --accent:#475569;
  --accent-light:#64748b;
  --accent-dark:#334155;
  --bg:#ffffff;
  --text:#1e293b;
  --text-light:#64748b;
  --border:#e2e8f0;
  --section-bg:#f8fafc;
  --dark-bg:#1e293b;
  --radius:12px;
  --transition:0.3s cubic-bezier(.4,0,.2,1)
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Noto Sans JP','Poppins',sans-serif;color:var(--text);background:var(--bg);line-height:1.8;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:'Poppins','Noto Sans JP',sans-serif;line-height:1.3}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
@media(max-width:480px){.container{padding:0 16px}}
.section-label{font-size:.75rem;letter-spacing:3px;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:8px}
.section-title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;margin-bottom:16px;color:var(--text)}
.section-desc{font-size:1rem;color:var(--text-light);max-width:760px;line-height:1.8}
@media(max-width:480px){.section-title{font-size:1.5rem;margin-bottom:12px}.section-desc{font-size:.9rem}.section-label{font-size:.68rem;letter-spacing:2px}}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:var(--transition);font-family:inherit}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(71,85,105,.3)}
.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .7s ease,transform .7s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* ===== NAV ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:var(--transition)}
.nav.scrolled{background:rgba(255,255,255,.95);backdrop-filter:blur(12px);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-brand{display:flex;flex-direction:column;line-height:1.1}
.nav-logo{font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:-1px}
.brand-lockup{display:flex;align-items:center;gap:12px}
.brand-image{display:block;height:42px;width:auto;border-radius:8px}
.hero-brandline{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:1px solid rgba(31,41,55,.10);border-radius:999px;background:rgba(255,255,255,.36);backdrop-filter:blur(8px);font-size:1.15rem;font-weight:700;color:var(--accent);letter-spacing:-.02em;margin-bottom:24px}
.footer-brand-image{display:block;height:48px;width:auto;margin-bottom:14px;border-radius:8px}
.nav-sub{font-size:.72rem;color:var(--text-light);font-weight:500;letter-spacing:.08em}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:.85rem;font-weight:500;color:var(--text-light);transition:var(--transition);position:relative}
.nav-links a:hover{color:var(--accent)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:width .3s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--accent)}
.nav-cta{background:var(--accent);color:#fff!important;padding:10px 24px;border-radius:8px;font-weight:600}
.nav-cta:hover{background:var(--accent-dark)}
.nav-cta::after{display:none}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.nav-hamburger span{width:24px;height:2px;background:var(--text);transition:var(--transition)}
@media(max-width:900px){
  .nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#fff;flex-direction:column;padding:80px 32px 32px;gap:20px;transition:var(--transition);box-shadow:-4px 0 20px rgba(0,0,0,.1)}
  .nav-links.open{right:0}
  .nav-hamburger{display:flex}
}
@media(max-width:768px){
  .brand-image{height:34px}
  .hero-brandline{font-size:1rem;padding:10px 18px}
  .footer-brand-image{height:40px}
  .nav-inner{gap:12px}
}
@media(max-width:480px){
  .brand-image{height:28px}
  .nav-sub{font-size:.62rem}
}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)}
.hero canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero::before{content:'';position:absolute;inset:auto -10% -20% auto;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(71,85,105,.08),rgba(71,85,105,0));pointer-events:none;z-index:0}
.hero-content{position:relative;z-index:2;max-width:780px;padding:132px 0 80px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:var(--section-bg);border:1px solid var(--border);padding:6px 16px;border-radius:100px;font-size:.8rem;color:var(--accent);font-weight:500;margin-bottom:24px}
.hero h1{font-size:clamp(2.3rem,5vw,4rem);font-weight:800;line-height:1.12;margin-bottom:20px;color:var(--text)}
.hero h1 span{color:var(--accent)}
.hero p{font-size:1.08rem;color:var(--text-light);margin-bottom:36px;max-width:700px}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:36px}
.hero-points{display:flex;gap:14px;flex-wrap:wrap}
.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--border);font-size:.82rem;font-weight:600;color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.03);transition:var(--transition)}
.hero-pill:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.06)}
@media(max-width:768px){
  .hero-content{padding-top:110px;padding-bottom:48px}
  .hero-buttons{flex-direction:column;align-items:flex-start}
  .btn{width:100%;justify-content:center}
  .hero p{font-size:.98rem;margin-bottom:28px}
  .hero-points{gap:10px}
  .hero-pill{padding:8px 12px;font-size:.76rem}
}
@media(max-width:480px){
  .hero-content{padding-top:100px;padding-bottom:40px}
  .hero h1{font-size:1.8rem;margin-bottom:16px}
  .hero-brandline{font-size:.88rem;padding:8px 14px;margin-bottom:18px}
  .hero p{font-size:.9rem}
}

/* ===== PHILOSOPHY ===== */
.philosophy-section{padding:100px 0;background:var(--section-bg)}
.philosophy-brand-visual{position:relative;overflow:hidden;border-radius:24px;background:#0f172a;box-shadow:0 18px 50px rgba(15,23,42,.18);margin-bottom:18px;transition:transform .5s ease}
.philosophy-brand-visual:hover{transform:scale(1.02)}
.philosophy-brand-visual img{display:block;width:100%;height:auto}
.philosophy-brand-caption{font-size:.78rem;color:var(--text-light);margin:8px 2px 0}
.philosophy-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:start}
.philosophy-text p{color:var(--text-light);margin-bottom:18px}
.philosophy-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 6px 24px rgba(0,0,0,.04)}
.philosophy-card h3{font-size:1rem;font-weight:700;margin-bottom:10px}
.philosophy-list{display:grid;gap:16px;margin-top:12px}
.philosophy-item{padding:18px;border:1px solid var(--border);border-radius:12px;background:#fff;transition:var(--transition)}
.philosophy-item:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(0,0,0,.06);transform:translateY(-2px)}
.philosophy-item h4{font-size:.95rem;font-weight:700;margin-bottom:6px}
.philosophy-item p{font-size:.84rem;color:var(--text-light)}
@media(max-width:900px){.philosophy-grid{grid-template-columns:1fr;gap:32px}}
@media(max-width:480px){.philosophy-section{padding:60px 0}.philosophy-item{padding:14px}.philosophy-card{padding:20px}}

/* ===== PROCESS ===== */
.process-section{padding:100px 0;background:var(--bg)}
.process-header{text-align:center;margin-bottom:64px}
.process-header .section-desc{margin:0 auto}
.process-steps{display:flex;align-items:flex-start;justify-content:center;gap:0;position:relative;max-width:980px;margin:0 auto}
.process-line{position:absolute;top:40px;left:calc(16.66% + 20px);right:calc(16.66% + 20px);height:2px;background:var(--border)}
.process-line::after{content:'';position:absolute;top:0;left:0;height:100%;width:0;background:var(--accent);transition:width 1.5s ease}
.process-line.animate::after{width:100%}
.process-step{flex:1;text-align:center;position:relative;z-index:1;padding:0 16px}
.process-circle{width:80px;height:80px;border-radius:50%;background:#fff;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:var(--transition)}
.process-step.active .process-circle{border-color:var(--accent);background:var(--accent)}
.process-step.active .process-circle svg{stroke:#fff}
.process-circle svg{stroke:var(--accent);transition:var(--transition)}
.process-step h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.process-step p{font-size:.85rem;color:var(--text-light);line-height:1.7}
@media(max-width:900px){.process-steps{flex-direction:column;gap:28px;max-width:680px}.process-line{display:none}.process-step{padding:0}.process-section{padding:80px 0}.process-header{margin-bottom:48px}}
@media(max-width:480px){.process-section{padding:60px 0}.process-circle{width:64px;height:64px}}

/* ===== SERVICE ===== */
.service-section{padding:100px 0;background:var(--bg)}
.service-header{text-align:center;margin-bottom:64px}
.service-header .section-desc{margin:0 auto}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.service-card{padding:34px 28px;border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);background:#fff;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.08);border-color:var(--accent)}
.service-num{font-family:'Poppins',sans-serif;font-size:3.4rem;font-weight:800;-webkit-text-stroke:2px var(--border);color:transparent;line-height:1;margin-bottom:16px;transition:var(--transition)}
.service-card:hover .service-num{-webkit-text-stroke-color:var(--accent)}
.service-card h3{font-size:1.08rem;font-weight:700;margin-bottom:10px}
.service-card p{font-size:.88rem;color:var(--text-light);line-height:1.7}
@media(max-width:900px){.service-grid{grid-template-columns:repeat(2,1fr);gap:20px}.service-section{padding:80px 0}.service-header{margin-bottom:48px}}
@media(max-width:600px){.service-grid{grid-template-columns:1fr}.service-card{padding:24px 20px}}
@media(max-width:480px){.service-section{padding:60px 0}.service-num{font-size:2.6rem}}

/* ===== CASE ===== */
.case-section{padding:100px 0;background:var(--section-bg)}
.case-header{text-align:center;margin-bottom:64px}
.case-header .section-desc{margin:0 auto}
.case-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.case-card{background:#fff;border-radius:16px;overflow:hidden;border:1px solid var(--border);transition:var(--transition)}
.case-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.08)}
.case-img{height:220px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2)}
.case-img::before{content:'';position:absolute;inset:0;background:repeating-conic-gradient(rgba(255,255,255,.04) 0% 25%,transparent 0% 50%) 0 0/40px 40px}
.case-img.secondary{background:linear-gradient(135deg,#4f46e5,#64748b)}
.case-img-label{color:#fff;font-size:1.18rem;font-weight:700;z-index:1;text-align:center;padding:0 24px;line-height:1.5}
.case-body{padding:28px}
.case-tag{display:inline-block;font-size:.75rem;font-weight:600;color:var(--accent);background:rgba(71,85,105,.08);padding:4px 12px;border-radius:100px;margin-bottom:12px}
.case-body h3{font-size:1.12rem;font-weight:700;margin-bottom:10px}
.case-body p{font-size:.88rem;color:var(--text-light);margin-bottom:16px;line-height:1.7}
.case-tags{display:flex;flex-wrap:wrap;gap:10px}
.case-chip{padding:8px 12px;border-radius:999px;border:1px solid var(--border);font-size:.8rem;font-weight:600;color:var(--accent);background:#f8fafc;transition:var(--transition)}
.case-chip:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.activity-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px;display:flex;flex-direction:column;justify-content:space-between}
.activity-card h3{font-size:1.15rem;font-weight:700;margin-bottom:10px}
.activity-card p{font-size:.88rem;color:var(--text-light);margin-bottom:18px;line-height:1.8}
.video-box{display:grid;place-items:center;min-height:220px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;text-align:center;padding:24px;transition:var(--transition)}
.video-box:hover{transform:scale(1.01)}
.video-box .play{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.18);margin:0 auto 12px;transition:var(--transition)}
.video-box:hover .play{background:rgba(255,255,255,.3);transform:scale(1.1)}
.video-box small{opacity:.84}
.video-box--player{background:#0f172a;min-height:auto;padding:0;border-radius:16px;overflow:hidden;max-width:360px;margin:0 auto;position:relative}
.video-box--player video{width:100%;border-radius:16px;display:block;background:#0f172a}

/* ===== SECURITY: Anti-copy ===== */
body{-webkit-user-select:none;-moz-user-select:none;user-select:none}
.faq-a-inner,.philosophy-text p,.case-body p,.service-card p,.news-content p,.contact-note,.section-desc,.hero p,.company-table-wrap,.company-table-wrap *{-webkit-user-select:text;-moz-user-select:text;user-select:text}
img{-webkit-user-drag:none;user-drag:none;pointer-events:none}
.brand-image,.footer-brand-image,.philosophy-brand-visual img{pointer-events:none}
@media(max-width:900px){.case-grid{grid-template-columns:1fr}.case-section{padding:80px 0}.case-header{margin-bottom:48px}}
@media(max-width:480px){.case-section{padding:60px 0}.case-img{height:160px}.case-img-label{font-size:.98rem;padding:0 16px}.case-body{padding:20px}.case-body h3{font-size:1rem}.activity-card{padding:20px}}

/* ===== TEAM ===== */
.team-section{padding:100px 0;background:var(--bg)}
.team-header{text-align:center;margin-bottom:64px}
.team-header .section-desc{margin:0 auto}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;max-width:820px;margin:0 auto}
.team-card{text-align:center;padding:32px 24px;border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);background:#fff}
.team-card:hover{border-color:var(--accent);box-shadow:0 8px 30px rgba(0,0,0,.06);transform:translateY(-4px)}
.team-avatar{width:84px;height:84px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;font-family:'Poppins',sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);transition:var(--transition)}
.team-card:hover .team-avatar{transform:scale(1.1)}
.team-card:nth-child(2) .team-avatar{background:linear-gradient(135deg,#4facfe,#00f2fe)}
.team-card h3{font-size:1rem;font-weight:700;margin-bottom:2px}
.team-card .role{font-size:.8rem;color:var(--accent);font-weight:600;margin-bottom:10px}
.team-card p{font-size:.82rem;color:var(--text-light);line-height:1.7}
@media(max-width:768px){.team-grid{grid-template-columns:1fr}.team-section{padding:80px 0}.team-header{margin-bottom:48px}}
@media(max-width:480px){.team-section{padding:60px 0}.team-card{padding:24px 16px}}

/* ===== COMPANY ===== */
.company-section{padding:100px 0;background:var(--section-bg)}
.company-header{text-align:center;margin-bottom:64px}
.company-table-wrap{max-width:820px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 6px 24px rgba(0,0,0,.04);transition:var(--transition)}
.company-table-wrap:hover{box-shadow:0 12px 40px rgba(0,0,0,.08);border-color:var(--accent-light)}
.company-table{width:100%;border-collapse:collapse}
.company-table th,.company-table td{padding:22px 28px;font-size:.92rem;line-height:1.8;text-align:left;border-bottom:1px solid var(--border);transition:background .3s ease}
.company-table tr:last-child th,.company-table tr:last-child td{border-bottom:none}
.company-table tr:hover th{background:rgba(71,85,105,.06)}
.company-table tr:hover td{background:rgba(71,85,105,.02)}
.company-table th{width:140px;font-weight:600;color:var(--accent);background:var(--section-bg);white-space:nowrap;vertical-align:top}
.company-table td{color:var(--text)}
.company-map-link{display:inline-flex;align-items:center;gap:4px;margin-left:12px;font-size:.8rem;font-weight:600;color:var(--accent);transition:var(--transition)}
.company-map-link:hover{color:var(--accent-dark);text-decoration:underline}
.company-service-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}
.company-service-list li{position:relative;padding-left:16px;font-size:.88rem;color:var(--text-light);line-height:1.7}
.company-service-list li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
@media(max-width:768px){.company-section{padding:80px 0}.company-header{margin-bottom:48px}.company-table th,.company-table td{padding:16px 20px;font-size:.88rem}.company-table th{width:110px}.company-map-link{display:flex;margin-left:0;margin-top:8px}}
@media(max-width:480px){.company-section{padding:60px 0}.company-table th,.company-table td{display:block;width:100%;padding:12px 16px}.company-table th{padding-bottom:4px;border-bottom:none}.company-table td{padding-top:0}}

/* ===== FAQ ===== */
.faq-section{padding:100px 0;background:var(--section-bg)}
.faq-header{text-align:center;margin-bottom:64px}
.faq-header .section-desc{margin:0 auto}
.faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);background:#fff;overflow:hidden;transition:var(--transition)}
.faq-item:hover{border-color:var(--accent-light)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;cursor:pointer;font-weight:600;font-size:.95rem;transition:var(--transition);gap:16px}
.faq-q:hover{color:var(--accent)}
.faq-q svg{flex-shrink:0;stroke:var(--text-light);transition:var(--transition);min-width:20px}
.faq-item.open .faq-q svg{transform:rotate(45deg);stroke:var(--accent)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 24px 20px;font-size:.9rem;color:var(--text-light);line-height:1.8}
@media(max-width:768px){.faq-section{padding:80px 0}.faq-header{margin-bottom:48px}.faq-q{padding:16px 18px;font-size:.88rem;gap:12px}.faq-a-inner{padding:0 18px 16px;font-size:.85rem}}
@media(max-width:480px){.faq-section{padding:60px 0}}

/* ===== CONTACT ===== */
.contact-section{padding:100px 0;background:var(--bg)}
.contact-header{text-align:center;margin-bottom:32px}
.contact-header .section-desc{margin:0 auto}
.contact-note{max-width:760px;margin:0 auto 28px;padding:16px 20px;border:1px solid var(--border);border-radius:12px;background:var(--section-bg);font-size:.92rem;color:var(--text-light)}
@media(max-width:768px){.contact-section{padding:80px 0}.contact-note{font-size:.85rem;padding:14px 16px}}
@media(max-width:480px){.contact-section{padding:60px 0}}
.contact-form{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.85rem;font-weight:600}
.form-group label .req{color:#ef4444;margin-left:4px}
.form-group input,.form-group textarea,.form-group select{padding:14px 16px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;transition:var(--transition);background:var(--bg);color:var(--text)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(71,85,105,.1)}
.form-group textarea{min-height:140px;resize:vertical}
.form-group .error-msg{font-size:.78rem;color:#ef4444;display:none;margin-top:2px}
.form-group.error input,.form-group.error textarea,.form-group.error select{border-color:#ef4444}
.form-group.error .error-msg{display:block}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:768px){.form-row{grid-template-columns:1fr}}
.form-submit{text-align:center;margin-top:8px}

/* ===== NEWS ===== */
.news-section{padding:100px 0;background:var(--bg)}
.news-header{text-align:center;margin-bottom:64px}
.news-header .section-desc{margin:0 auto}
.news-grid{display:flex;flex-direction:column;gap:20px;max-width:880px;margin:0 auto}
.news-card{display:flex;gap:24px;padding:28px;border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);background:#fff;align-items:flex-start;text-decoration:none;color:inherit;cursor:pointer}
.news-card:hover{border-color:var(--accent);box-shadow:0 6px 24px rgba(0,0,0,.06)}
.news-date{flex-shrink:0;background:var(--accent);color:#fff;padding:12px 16px;border-radius:10px;text-align:center;font-family:'Poppins',sans-serif;min-width:68px}
.news-month{font-size:.65rem;font-weight:500;opacity:.75;line-height:1.3}
.news-day{font-size:1rem;font-weight:700;line-height:1.3;letter-spacing:-.02em}
.news-content{flex:1;min-width:0}
.news-badge{display:inline-block;font-size:.72rem;font-weight:600;color:var(--accent);background:rgba(71,85,105,.08);padding:3px 10px;border-radius:100px;margin-bottom:8px}
.news-content h3{font-size:1.02rem;font-weight:700;margin-bottom:8px;line-height:1.5}
.news-content p{font-size:.88rem;color:var(--text-light);line-height:1.8}
.news-read-more{display:inline-block;margin-top:10px;font-size:.82rem;font-weight:600;color:var(--accent);transition:var(--transition)}
.news-card:hover .news-read-more{text-decoration:underline}
@media(max-width:768px){.news-card{flex-direction:column;gap:16px;padding:20px}.news-date{align-self:flex-start}.news-section{padding:80px 0}.news-header{margin-bottom:48px}.news-content h3{font-size:.95rem}}
@media(max-width:480px){.news-section{padding:60px 0}.news-card{padding:16px}.news-content p{font-size:.82rem}}

/* ===== NEWS DETAIL PAGE ===== */
.news-detail-section{padding:120px 0 80px;background:var(--bg)}
.news-detail{max-width:780px;margin:0 auto}
.news-back-link{display:inline-flex;align-items:center;gap:4px;margin-bottom:32px;font-size:.88rem;color:var(--accent);text-decoration:none;font-weight:500;transition:var(--transition)}
.news-back-link:hover{text-decoration:underline;color:var(--accent-dark)}
.news-detail-meta{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.news-detail-date{font-size:.88rem;color:var(--text-light);font-family:'Poppins',sans-serif}
.news-detail-title{font-size:clamp(1.3rem,3.5vw,1.8rem);font-weight:700;line-height:1.6;margin-bottom:32px;color:var(--text)}
.news-detail-body{font-size:.95rem;line-height:2;color:var(--text)}
.news-detail-body p{margin-bottom:1.5em}
.news-detail-body img{max-width:100%;height:auto;border-radius:var(--radius);margin:24px 0}
@media(max-width:768px){.news-detail-section{padding:100px 0 60px}.news-detail-title{margin-bottom:24px}.news-detail-body{font-size:.9rem}}
@media(max-width:480px){.news-detail-section{padding:90px 0 48px}.news-back-link{margin-bottom:24px}}

/* ===== BACK TO TOP ===== */
.back-to-top{position:fixed;bottom:32px;right:32px;z-index:900;width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(71,85,105,.3);opacity:0;visibility:hidden;transform:translateY(12px);transition:var(--transition)}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 6px 24px rgba(71,85,105,.4)}
@media(max-width:768px){.back-to-top{bottom:24px;right:20px;width:42px;height:42px}}
@media(max-width:480px){.back-to-top{bottom:20px;right:16px;width:40px;height:40px}}

/* ===== COOKIE BANNER ===== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:950;background:var(--dark-bg);color:rgba(255,255,255,.85);padding:16px 24px;display:flex;align-items:center;justify-content:center;gap:20px;font-size:.85rem;transform:translateY(100%);transition:transform .4s ease;box-shadow:0 -2px 12px rgba(0,0,0,.15)}
.cookie-banner.visible{transform:translateY(0)}
.cookie-banner p{max-width:640px;line-height:1.6}
.cookie-accept{padding:10px 24px;font-size:.82rem;flex-shrink:0}
@media(max-width:768px){.cookie-banner{flex-direction:column;gap:12px;text-align:center;padding:20px 24px}}

/* ===== FOOTER ===== */
.footer{background:var(--dark-bg);color:#fff;padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .nav-logo{color:#fff;margin-bottom:12px;display:block}
.footer-brand .nav-sub{color:rgba(255,255,255,.55)}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.7;margin-top:12px}
.footer-col h4{font-size:.85rem;font-weight:700;margin-bottom:16px;color:rgba(255,255,255,.88)}
.footer-col a{display:block;font-size:.85rem;color:rgba(255,255,255,.55);margin-bottom:10px;transition:var(--transition)}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:32px;border-top:1px solid rgba(255,255,255,.1);gap:16px}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.42)}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:28px}.footer-bottom{flex-direction:column;text-align:center}.footer{padding:48px 0 24px}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr;gap:24px}.footer-brand p{font-size:.82rem}}

/* ===== ACCESSIBILITY: Reduced Motion ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none}
  .hero canvas{display:none}
  .page-loader{display:none}
}

/* ===== PRINT ===== */
@media print{
  .nav,.hero canvas,.video-box--player,.contact-form,.nav-hamburger,.back-to-top,.cookie-banner,.scroll-progress,.page-loader{display:none}
  .hero{min-height:auto;padding:40px 0}
  section{padding:40px 0!important;break-inside:avoid}
  body{font-size:12pt;color:#000}
  .footer{background:#fff;color:#000}
  .footer-brand p,.footer-col a,.footer-bottom p{color:#333}
}
