.top-nav {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 85px; z-index: 1000;
display: flex;
justify-content: space-between;
align-items: center;
padding: 0 50px; background-color: #f2f2f2;   border-bottom: 1px solid rgba(0, 0, 0, 0.05);
transition: all 0.4s ease;
}
.header-logo {
position: relative;
z-index: 1100; } .header-logo a {
display: flex;
align-items: center;
}
.header-logo img {
height: 80px; width: auto;
display: block;
} .top-nav .nav-links {
display: flex;
gap: 3vw;
align-items: center;
}
.top-nav .nav-links a {
text-decoration: none;
color: #000;
font-weight: 600;
font-size: 15px;
letter-spacing: 0.1em;
padding: 5px 0;
position: relative;
transition: color 0.3s ease;
} .top-nav .nav-links a::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 0;
height: 2px;
background: #00c3ff; box-shadow: 0 0 10px rgba(0, 195, 255, 0.8);
transition: width 0.3s ease;
}
.top-nav .nav-links a:hover {
color: #00c3ff;
}
.top-nav .nav-links a:hover::after {
width: 100%;
} .menu-icon {
display: none;
width: 30px;
height: 16px;
flex-direction: column;
justify-content: space-between;
cursor: pointer;
z-index: 1100;
}
.menu-icon span {
display: block;
height: 2px;
width: 100%;
background-color: #000;
transition: all 0.4s ease;
} @media (max-width: 768px) {
.top-nav {
height: 70px; padding: 0 20px;
}
.header-logo img {
height: 55px; }
.menu-icon {
display: flex;
} .top-nav .nav-links {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100vh;
background-color: rgba(255, 255, 255, 0.98);
flex-direction: column;
justify-content: center;
z-index: 1050;
opacity: 0;
visibility: hidden;
transition: all 0.5s ease-in-out;
}
.top-nav .nav-links.active {
opacity: 1;
visibility: visible;
}
.top-nav .nav-links a {
font-size: 24px;
margin: 15px 0;
color: #000;
} .menu-icon.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-icon.active span:nth-child(2) { transform: translateY(-7px) rotate(-45deg); }
body.nav-open { overflow: hidden; }
}* {
margin: 0;
padding: 0;
box-sizing: border-box;
} html {
scroll-behavior: smooth;
}  #contact,
#work,
#service,
#faq,
#about {
scroll-margin-top: 80px; }
body {
font-family: "Inter", sans-serif;
background-color: #f2f2f2;
color: #000;
line-height: 1.2;
overflow-x: hidden;
} .container {
padding: 0 50px 60px 50px;
position: relative;
min-height: 72vh;
} .section-title {
text-align: center;
font-size: clamp(20px, 4vw, 32px);
font-weight: 700;
letter-spacing: 0.18em;
text-transform: uppercase;
color: #111;
margin: 120px 0 30px;
}  .hero-video {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: cover;
z-index: 0;
}
.container::before {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(rgba(0, 0, 0, 0.45), rgba(0, 0, 0, 0.35));
z-index: 1;
}
.main-title,
.bottom-actions {
position: relative;
z-index: 2;
color: #fff;
text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
}
.main-title {
font-size: clamp(20px, 15vw, 60px);
font-weight: 700;
letter-spacing: -1px;
padding-top: 290px;
margin-bottom: 30px;
text-transform: uppercase;
}
.main-title .small-lines {
display: block;
font-size: 0.6em;
line-height: 1.1;
margin-bottom: 15px;
}
.main-title .companyname {
display: block;
font-size: 1.2em;
margin-top: 20px;
}
.cta-button {
display: inline-block; background-color: #000;
color: #fff;
border: none;
padding: 15px 40px;
font-size: 17px;
cursor: pointer;
transition: all 0.3s ease;
text-decoration: none;
z-index: 2;
position: relative;
text-transform: uppercase;
letter-spacing: 0.1em;
}
.cta-button:hover {
opacity: 0.8;
} .work {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 32px;
max-width: 1200px;
margin: 0 auto 60px;
padding: 0 20px;
} .filter-group {
display: flex;
justify-content: center;
align-items: center;
gap: 30px; flex-wrap: wrap; margin-bottom: 40px;
padding: 0 20px;
}
.filter-btn {
background: none;
border: none;
font-size: 20px;
font-weight: 700;
color: #888;
cursor: pointer;
letter-spacing: 0.15em;
padding-bottom: 5px;
border-bottom: 2px solid transparent;
transition: all 0.3s ease;
white-space: nowrap; text-decoration: none !important;
display: inline-block;
}
.filter-btn.active,
.filter-btn:hover {
color: #000;
border-bottom: 2px solid #000;
} .work-img {
width: 100%;
aspect-ratio: 1 / 1; border-radius: 6px;
overflow: hidden;
background-color: #000; }
.work-img img {
width: 100%;
height: 100%;
object-fit: cover; } .work-item.fade-out {
opacity: 0;
transform: translateY(10px);
}
.work-item.fade-in {
opacity: 1;
transform: translateY(0);
}
.work-item {
transition:
opacity 0.4s ease,
transform 0.4s ease;
margin-bottom: 15px;
}
.work-lightbox {
text-decoration: none !important; color: inherit !important; display: block; } .work-lightbox:hover,
.work-lightbox:focus,
.work-lightbox:active {
text-decoration: none !important;
color: inherit !important;
} .work-item.is-hidden {
display: none;
}
.work-item img {
width: 100%;
height: auto;
object-fit: cover;
display: block; transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
} .work-item:hover .work-img img {
transform: scale(1.1);
} .work-item h3,
.work-item p {
margin-top: 15px;
font-size: 1.2rem;
color: #000;
text-decoration: none;
} .more-container { grid-column: 1 / -1;
display: flex;
justify-content: flex-start; align-items: center;
padding-top: 20px;
}
.more-btn {
text-decoration: none;
color: #333;
font-weight: bold;
border: 1px solid #333; padding: 10px 30px;
transition: all 0.3s ease; background-color: transparent; -webkit-appearance: none; -moz-appearance: none;
appearance: none;
-webkit-tap-highlight-color: transparent; outline: none; }
.more-btn:hover {
background-color: #333;
color: #fff;
} .more-btn:active,
.more-btn:focus {
background-color: #333 !important; color: #fff !important; outline: none;
} .about {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
.about-container {
display: flex;
align-items: center;
gap: 60px;
}
.about-text {
flex: 1;
}
.about-text h3 {
font-size: 24px;
margin-bottom: 24px;
color: #111;
}
.about-text p {
font-size: 16px;
line-height: 1.8;
color: #444;
margin-bottom: 20px;
}
.about-image {
flex: 1;
}
.about-image img {
width: 100%; height: auto; object-fit: cover; border-radius: 8px;
box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08);
} .about-action {
margin-top: 40px;
text-align: left; }
.about-btn {
text-decoration: none;
color: #333;
font-weight: bold;
border: 1px solid #333; padding: 10px 30px;
transition: all 0.3s ease; background-color: transparent; -webkit-appearance: none; -moz-appearance: none;
appearance: none;
-webkit-tap-highlight-color: transparent; outline: none; }
.about-btn:hover {
background-color: #333;
color: #fff;
} #contact {
margin-top: 200px;
}
.contact {
max-width: 1200px;
margin: 0 auto 120px;
padding: 0 20px;
text-align: center;
}
.contact-message {
font-size: 18px;
line-height: 1.8;
color: #333;
margin-bottom: 30px;
}
.contact-button {
background-color: #000;
border-radius: 5px;
color: #fff;
border: none;
padding: 12px 35px;
font-size: 15px;
cursor: pointer;
transition: opacity 0.3s;
text-decoration: none;
display: inline-block; -webkit-tap-highlight-color: transparent; outline: none;
} .cyber-form {
max-width: 600px;
margin: 0 auto;
text-align: left;
}
.form-group {
margin-bottom: 25px;
}
.cyber-form input:not([type="submit"]),
.cyber-form textarea {
width: 100%;
padding: 12px 0;
background: transparent;
border: none;
border-bottom: 1px solid #333; outline: none;
font-family: inherit;
font-size: 16px;
transition: border-bottom-color 0.3s ease;
}
.cyber-form input:focus,
.cyber-form textarea:focus {
border-bottom-color: #000; } .spam-prevention {
margin: 25px 0;
display: flex;
justify-content: center;
width: 100%;
} .spam-prevention .wpcf7-form-control-wrap {
display: flex !important;
flex-direction: column !important; align-items: center !important; }
.spam-prevention .wpcf7-not-valid-tip {
display: block !important;
width: 100%;
text-align: center; margin-top: 10px !important; font-size: 13px;
color: #ff0000;
} .spam-prevention .wpcf7-list-item {
display: flex !important;
align-items: center !important;
margin: 0 !important;
}
.spam-prevention label {
display: flex !important; align-items: center !important; cursor: pointer;
font-size: 14px;
color: #666;
line-height: 1 !important; white-space: nowrap;
}
.spam-prevention input[type="checkbox"] {
margin: 0 10px 0 0 !important;
width: 16px;
height: 16px;
flex-shrink: 0;
cursor: pointer; vertical-align: middle;
position: relative;
top: -1px; }
.form-submit {
width: 100% !important;
display: flex !important;
justify-content: center !important; align-items: center !important;
margin: 40px 0 0 !important;
padding: 0 !important;
position: relative !important;
background-color: transparent !important; } .form-submit .wpcf7-form-control-wrap {
display: contents !important;
} .form-submit .ajax-loader {
position: absolute !important;
visibility: hidden !important;
width: 0 !important;
height: 0 !important;
margin: 0 !important;
padding: 0 !important;
} .cyber-form .more-btn,
#submit-btn {
margin: 0 !important; display: block !important; min-width: 240px;
padding: 12px 40px !important; background-color: #000 !important;
color: #fff !important;
border: 1px solid #333 !important;
font-weight: bold;
text-decoration: none;
cursor: pointer;
-webkit-appearance: none;
appearance: none;
border-radius: 0;
transition: opacity 0.3s;
} .cyber-form .more-btn:hover,
#submit-btn:hover {
opacity: 0.8 !important;
} #expanded-form {
display: none; margin-top: 50px;
} #form-thanks {
display: none; text-align: center;
padding: 40px 0;
}
#form-thanks h3 {
font-size: 24px;
margin-bottom: 20px;
}
#form-thanks p {
color: #666;
line-height: 1.8;
}  .cyber-form p {
margin: 0;
padding: 0;
display: block !important; }
.cyber-form br {
display: none; } .wpcf7-form-control-wrap {
display: block;
width: 100%;
margin-bottom: 20px; } .wpcf7-not-valid-tip {
font-size: 12px;
color: #ff0000;
margin-top: 5px;
display: block;
}  .wpcf7-response-output {
display: none !important;
}  .wpcf7-spinner,
.ajax-loader {
display: none !important;
}  button.more-btn.is-sending {
position: relative !important;
overflow: hidden !important;
opacity: 0.8;
pointer-events: none; color: rgba(255, 255, 255, 0.8) !important; } button.more-btn.is-sending::after {
content: "";
position: absolute;
bottom: 0;
left: 0; width: 100%;
height: 3px;  background: linear-gradient(
90deg,
transparent,
rgba(0, 195, 255, 0.8), #fff,
rgba(0, 195, 255, 0.8),
transparent
);
box-shadow: 0 0 10px rgba(0, 195, 255, 0.8); animation: cyber-scan-internal 1.3s infinite linear;
} @keyframes cyber-scan-internal {
0% {
transform: translateX(-100%);
}
100% {
transform: translateX(100%);
}
}  .archive-section {
padding-top: 0; padding-bottom: 0;
} .archive-section-wrapper .privacy-hero {
margin-bottom: 30px; } .pagination {
grid-column: 1 / -1;
display: flex;
justify-content: center;
gap: 20px;
margin-top: 60px;
}
.pagination .page-numbers {
padding: 8px 16px;
border: 1px solid #333;
text-decoration: none;
color: #333;
font-size: 14px;
transition: all 0.3s;
}
.pagination .page-numbers.current,
.pagination .page-numbers:hover {
background: #000;
color: #fff;
}  @media (max-width: 992px) {
.work {
grid-template-columns: repeat(2, 1fr);
}
.more-container { grid-column: 1 / -1 !important; justify-content: flex-start; margin-top: 20px;
}
.about-container {
gap: 40px;
}
.about-text h3 {
font-size: 20px;
}
} @media (max-width: 768px) { .container {
min-height: 56vh;
padding: 0 20px 40px 20px;
}
.main-title {
font-size: clamp(28px, 8vw, 48px);
}
.main-title .small-lines {
font-size: 0.65em;
}
.more-container {
margin-top: 5px !important;
} .section-title {
margin: 60px 0 20px !important; } .filter-group {
gap: 15px 20px; flex-wrap: wrap; margin-bottom: 30px;
}
#about.section-title {
margin-top: 120px !important;
}
.about {
margin-bottom: 10px !important;
}
.about-container {
flex-direction: column-reverse !important;
gap: 0 !important; align-items: center !important;
} .about-text,
.about-image {
flex: none !important; width: 100% !important;
}
.about-text h3 {
margin-top: 10px !important; margin-bottom: 12px !important;
font-size: 18px !important;
}
.about-text p {
font-size: 14px !important;
margin-bottom: 15px !important;
}
.about-image img {
margin-bottom: 10px !important;
display: block;
}
#contact.section-title {
margin-top: 120px !important;
}
.contact-message {
font-size: 15px;
}
.contact-button {
padding: 12px 25px;
font-size: 13px;
}
} @media (max-width: 480px) {
.cta-button {
padding: 12px 30px; font-size: 14px; background-color: rgba(0, 0, 0, 0.7); border: 1px solid rgba(255, 255, 255, 0.3); }
.work { display: grid !important;
grid-template-columns: repeat(2, 1fr) !important; gap: 20px 12px !important;
padding: 0 15px !important;
}  .work-img {
width: 100%;
aspect-ratio: 1 / 1 !important;
overflow: hidden;
background-color: #000;
border-radius: 4px;
}
.work-img img {
width: 100%;
height: 100%;
object-fit: cover; }  .work-item h3 {
font-size: 13px !important; line-height: 1.3;
margin-top: 10px;
min-height: 2.6em; display: -webkit-box;
-webkit-line-clamp: 2; line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
} .work-item p {
font-size: 11px !important;
line-height: 1.4;
color: #666;
margin-top: 4px; } .filter-btn {
font-size: 13px !important;
padding: 4px 0;
}
.more-container {
grid-column: 1 / -1 !important; justify-content: flex-start; padding: 0 !important;
}
} .modal {
display: none;
position: fixed;
z-index: 2000; left: 0;
top: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.9);
backdrop-filter: blur(8px); overflow: hidden;
} .modal-content {
margin: auto;
display: block;
width: auto;
max-width: 90%;
max-height: 85%;
min-width: 200px; min-height: 200px; position: relative;
top: 50%;
transform: translateY(-50%);
border: 1px solid rgba(255, 255, 255, 0.1);
box-shadow: 0 0 30px rgba(0, 0, 0, 0.5);
object-fit: contain; }
.modal-close {
position: absolute;
top: 30px;
right: 40px;
color: #fff;
font-size: 40px;
font-weight: bold;
cursor: pointer;
z-index: 2100;
}
#modal-caption {
margin: auto;
display: block;
width: 80%;
text-align: center;
color: #ccc;
padding: 10px 0;
height: 50px;
position: absolute;
bottom: 20px;
left: 10%;
font-size: 14px;
letter-spacing: 0.1em;
}  body:not(.home) main {
padding-top: 85px; } @media (max-width: 768px) {
body:not(.home) main {
padding-top: 70px; }
}  .pagination .nav-links {
display: flex !important; flex-direction: row !important; justify-content: center !important; align-items: center !important;
gap: 10px !important;  position: static !important;
width: auto !important;
height: auto !important;
background: none !important;
opacity: 1 !important;
visibility: visible !important;
padding: 0 !important;
margin: 0 auto !important;
} .pagination {
width: 100%;
text-align: center;
margin: 60px 0 40px;
} .pagination .page-numbers {
text-decoration: none;
padding: 8px 14px;
background: #fff;
border: 1px solid #ddd;
color: #333;
font-size: 14px;
}
.pagination .page-numbers.current {
background: #000;
color: #fff;
border-color: #000;
}
@media (max-width: 480px) {
.pagination {
margin-top: 40px;
}
.pagination .page-numbers {
padding: 8px 12px;
font-size: 13px;
}
}
.contact-sns-wrapper {
margin-top: 40px;
}
.sns-sub-message {
font-size: 14px;
color: #666;
margin-bottom: 20px;
letter-spacing: 0.05em;
}
.contact-sns-btns {
display: flex;
justify-content: center;
align-items: center;
gap: 20px;
flex-wrap: wrap; }
.sns-item {
display: flex;
align-items: center;
gap: 8px;
padding: 10px 20px;
border-radius: 30px;
text-decoration: none;
font-size: 14px;
font-weight: 600;
transition: all 0.3s ease;
border: 1px solid transparent;
} .sns-item.line {
background-color: #f0fdf4;
color: #06c755;
border-color: #06c755;
}
.sns-item.instagram {
background-color: #fff5f8;
color: #e1306c;
border-color: #e1306c;
}
.sns-item.x-twitter {
background-color: #f8f8f8;
color: #000;
border-color: #000;
} .sns-item:hover {
transform: translateY(-3px);
box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}
.sns-item.line:hover {
background-color: #06c755;
color: #fff;
}
.sns-item.instagram:hover {
background-color: #e1306c;
color: #fff;
}
.sns-item.x-twitter:hover {
background-color: #000;
color: #fff;
} @media (max-width: 480px) {
.contact-sns-btns {
gap: 10px;
}
.sns-item {
padding: 8px 15px;
font-size: 13px;
}
}  .service {
max-width: 1200px;
margin: 0 auto 80px;
padding: 0 20px;
}
.service-container {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 30px;
}
.service-card {
background: rgba(255, 255, 255, 0.85);
backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); padding: 40px 30px;
border-radius: 12px; border: 1px solid rgba(255, 255, 255, 0.6);
text-align: center;
transition: transform 0.3s ease; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.05);
}
.service-card:hover {
transform: translateY(-10px);
background: rgba(255, 255, 255, 0.8);
}
.service-icon {
width: 100px; height: 100px; margin: 0 auto -30px !important; overflow: hidden; border-radius: 8px; background-color: #eee; }
.service-icon img {
width: 100%;
height: 100%;
object-fit: cover; display: block;
}
.service-card h3 {
font-size: 20px;
margin-bottom: 10px;
letter-spacing: 0.1em;
}
.service-card p {
font-size: 14px;
color: #555;
line-height: 1.6;
margin-bottom: 5px;
min-height: 4.8em;
}
.service-price {
font-weight: 700;
font-size: 18px;
border-top: 1px solid #eee;
padding-top: 20px;
}
.service-price span {
font-size: 12px;
font-weight: 400;
color: #888;
}
.service-note {
text-align: center; margin-top: 40px; font-size: 13px; color: #666; letter-spacing: 0.05em; } @media (max-width: 768px) {
#service.section-title {
margin-top: 120px !important;
}
.service-container {
grid-template-columns: 1fr;
}
.service-note {
margin-top: 30px;
font-size: 12px;
padding: 0 10px; line-height: 1.6;
}
} .select-wrapper select {
font-size: 16px; padding: 12px 10px; height: auto; border-radius: 4px; cursor: pointer; } .select-wrapper option {
font-size: 16px;
}  .form-submit {
text-align: center;
margin-top: 40px; } .cyber-form input[type="submit"] {
background-color: #000; color: #fff; font-size: 16px;
font-weight: 700; letter-spacing: 0.15em; padding: 18px 80px; border: 1px solid #000; cursor: pointer; transition: all 0.3s ease; border-radius: 0; -webkit-appearance: none; appearance: none;
} .cyber-form input[type="submit"]:hover {
background-color: transparent; color: #00c3ff; border-color: #00c3ff; box-shadow: 0 0 15px rgba(0, 195, 255, 0.4); } @media (max-width: 768px) {
.cyber-form input[type="submit"] {
width: 100%; padding: 15px 0; }
} #faq {
background-color: #0a0a0a !important; padding: 0; margin: 0;
} #faq .container {
display: flex !important;
flex-direction: column !important;
align-items: center !important; justify-content: center;
} #faq .section-title {
color: #fff !important;
text-align: center !important;
width: 100%;
margin-top: 50px !important; margin-bottom: 30px !important; } .faq-wrapper {
width: 100%; max-width: 800px;  } .faq-item {
margin-bottom: 15px;
border: 1px solid #333;
background: rgba(20, 20, 20, 0.8);
transition: all 0.3s ease;
width: 100%; } .faq-item.active {
border-color: #00c3ff;
box-shadow: 0 0 15px rgba(0, 195, 255, 0.3);
} .faq-question {
width: 100%;
text-align: left; padding: 20px 25px;
background: none;
border: none;
color: #fff;
font-size: 18px;
font-weight: 700;
cursor: pointer !important;
display: flex;
justify-content: space-between;
align-items: center;
position: relative !important;
transition: color 0.3s ease;
z-index: 1 !important; } .faq-question::before {
content: "";
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 4px;
background: #00c3ff;
transform: scaleY(0);
transition: transform 0.3s ease;
}
.faq-item.active .faq-question::before {
transform: scaleY(1);
}
.faq-item.active .faq-question {
color: #00c3ff;
} .faq-icon {
position: relative;
width: 16px;
height: 16px;
flex-shrink: 0;
}
.faq-icon::before,
.faq-icon::after {
content: "";
position: absolute;
background-color: #fff;
transition: all 0.3s ease;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.faq-icon::before {
width: 16px;
height: 2px;
}
.faq-icon::after {
width: 2px;
height: 16px;
}
.faq-item.active .faq-icon::after {
transform: translate(-50%, -50%) rotate(90deg);
background-color: #00c3ff;
}
.faq-item.active .faq-icon::before {
background-color: #00c3ff;
} .faq-answer {
display: none;
padding: 0 25px 30px;
background: none; } .faq-answer p {
color: #fff !important; line-height: 1.8;
font-size: 16px;
text-align: left;
margin: 0; } @media (max-width: 768px) {
#faq {
padding: 20px 0;
}
.faq-question {
font-size: 16px;
padding: 15px 20px;
}
.faq-answer {
padding: 0 20px 25px;
font-size: 15px;
}
}  #faq .section-title::after,
#faq .section-title::before {
display: none !important;
content: none !important;
border: none !important;
background: none !important;
} #faq .section-title {
border: none !important;
border-bottom: none !important;
box-shadow: none !important;
text-decoration: none !important;
} #faq.cyber-section {
border: none !important;
box-shadow: none !important;
}  .fade-in {
opacity: 0; transform: translateY(30px); transition: all 0.8s ease; } .animate-title {
opacity: 0; transform: translateX(-30px); transition: all 0.8s ease;
} .visible {
opacity: 1 !important; transform: translate(0, 0) !important; } .faq-wrapper.visible { transform: none !important;
transition: opacity 0.8s ease; }  *::before,
*::after {
pointer-events: none; } .faq-icon::before,
.faq-icon::after {
pointer-events: auto; } @media (max-width: 768px) { .fade-in,
.animate-title,
.work-item {
opacity: 1 !important;
transform: none !important;
transition: none !important;
}
} #faq .section-title {
color: #ffffff !important; opacity: 1 !important; text-shadow: none !important; background: none !important; mix-blend-mode: normal !important; filter: none !important; -webkit-text-fill-color: #ffffff !important; z-index: 20 !important; position: relative !important;
} #faq .section-title::before,
#faq .section-title::after {
display: none !important;
content: none !important;
}.privacy-container {
background-color: #f2f2f2; min-height: 100vh;
padding-bottom: 30px;
} .privacy-hero {
background-color: #000;
height: 300px;
display: flex;
justify-content: center;
align-items: center;
margin-bottom: 60px;
}
.privacy-hero h1 {
color: #fff;
font-size: clamp(32px, 6vw, 54px);
letter-spacing: 0.25em;
font-weight: 700;
text-transform: uppercase;
} .privacy-wrapper {
max-width: 800px;
margin: 0 auto;
padding: 0 20px;
text-align: left;
} main section h2 {
font-size: 24px;
margin-bottom: 40px;
padding-bottom: 15px;
border-bottom: 2px solid #000;
display: inline-block;
letter-spacing: 0.1em;
}
main section h3 {
font-size: 18px;
margin: 50px 0 20px;
font-weight: 700;
color: #000;
}
main section p {
font-size: 15px;
line-height: 1.9;
color: #333;
margin-bottom: 24px;
}
main section ul {
list-style: none;
padding: 0;
margin-bottom: 40px;
}
main section li {
font-size: 15px;
line-height: 1.8;
color: #444;
margin-bottom: 15px;
padding-left: 1.5em;
position: relative;
} main section li::before {
content: "";
position: absolute;
left: 0;
top: 0.7em;
width: 6px;
height: 6px;
background-color: #000;
}
main section strong {
color: #000;
font-weight: 700;
} @media (max-width: 768px) {
.privacy-hero { height: 130px; }
.privacy-hero h1 { 
font-size: 25px;
letter-spacing: 0.15em;
}
main section h2 { font-size: 20px; }
}.profile-table {
width: 100%;
border-collapse: collapse;
margin-bottom: 60px;
}
.profile-table tr {
border-bottom: 1px solid #ddd;
}
.profile-table th {
width: 30%;
text-align: left;
padding: 20px 0;
font-size: 14px;
font-weight: 700;
color: #888;
letter-spacing: 0.1em;
vertical-align: top;
}
.profile-table td {
padding: 20px 0;
font-size: 15px;
line-height: 1.8;
color: #111;
} .service-detail h3 {
font-size: 18px;
margin-top: 40px;
color: #000;
border-left: 3px solid #000;
padding-left: 15px;
}
.service-detail p {
margin-top: 10px;
font-size: 14px;
color: #444;
} @media (max-width: 768px) {
.profile-table th {
width: 100%;
display: block;
padding-bottom: 5px;
}
.profile-table td {
width: 100%;
display: block;
padding-top: 0;
padding-bottom: 20px;
}
} .service-list {
list-style: none !important; padding-left: 0 !important;
margin: 0 !important;
}
.service-list li {
list-style-type: none !important; position: relative !important;
padding-left: 1.2em !important; text-indent: 0 !important;
margin-bottom: 0.8em !important;
line-height: 1.6 !important;
} .service-list li::before {
content: "・" !important;
position: absolute !important;
left: 0 !important;
top: 0 !important; background: none !important;
width: auto !important;
height: auto !important;
border: none !important;
border-radius: 0 !important;
transform: none !important;
color: #333 !important; font-weight: bold !important;
} .service-list li::after {
content: none !important;
display: none !important;
}.site-footer {
background-color: #000;
color: #fff;
padding: 80px 50px 30px;
margin-top: 100px;
}
.footer-container {
display: grid;
grid-template-columns: 2fr 1fr 1fr;
gap: 40px;
max-width: 1200px;
margin: 0 auto;
}
.footer-column h3 {
font-size: 14px;
margin-bottom: 20px;
color: #888;
}
.footer-logo {
margin-bottom: 10px;
} .footer-logo img {
height: 50px; width: auto;
display: block;
}
.footer-logo a {
display: flex; align-items: center; gap: 15px; text-decoration: none;
} .footer-logo-text {
color: #fff;
font-size: 22px;
font-weight: 700;
letter-spacing: 0.1em;
text-transform: uppercase;
line-height: 1;
}
.footer-column ul {
list-style: none;
}
.footer-column ul li {
margin-bottom: 10px;
}
.footer-column ul li a {
text-decoration: none;
color: #fff;
font-weight: 600;
}
.footer-bottom {
border-top: 1px solid #333;
margin-top: 60px;
padding-top: 30px;
text-align: center;
font-size: 12px;
color: #666;
}
.footer-legal {
display: flex;
justify-content: center;
gap: 25px;
margin-bottom: 15px;
}
.footer-legal a {
color: #888;
text-decoration: none;
} .line-fixed-btn,
.line-tooltip,
.line-bubble,
.line-inner {
display: none; 
}  @media (max-width: 768px) {
.site-footer {
padding: 60px 20px 20px;
}
.footer-container {
grid-template-columns: 1fr;
}
.footer-logo {
margin-bottom: 0;
}
.footer-logo a {
justify-content: flex-start; }
.footer-logo-text {
font-size: 18px; }
} @media (max-width: 480px) {
.footer-legal {
flex-direction: column;
gap: 12px;
}
.footer-container p {
font-size: 14px;
}
}  @media (max-width: 768px) { .line-fixed-btn {
display: flex !important; position: fixed;
bottom: 25px;
right: 20px;
width: 72px;
height: 72px;
background-color: #06c755;
border-radius: 50%;
justify-content: center;
align-items: center;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
z-index: 9999;
text-decoration: none;
transition: transform 0.3s ease;
}
.line-inner {
display: flex !important; flex-direction: column;
align-items: center;
justify-content: center;
}
.line-fixed-btn:active {
transform: scale(0.95);
} .line-bubble-icon {
width: 32px;
height: 32px;
margin-bottom: 2px;
display: block;
}
.line-bubble-icon svg {
width: 100%;
height: 100%;
display: block;
} .line-label {
color: #ffffff;
font-size: 10px;
font-weight: bold;
white-space: nowrap;
line-height: 1;
display: block;
}
}