/**
 * Contact page — matches html/style.css + contact.html layout.
 */

body.oc365-html-contact{
--oc365-contact-font-heading:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
--oc365-contact-font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

body.oc365-html-contact .contact-hero{
padding:60px 0 100px;
background:var(--oc365-color-bg, #fafafa);
}

body.oc365-html-contact .contact-hero > .container.contact-grid{
max-width:1280px;
padding-left:24px;
padding-right:24px;
margin-left:auto;
margin-right:auto;
box-sizing:border-box;
}

body.oc365-html-contact .contact-grid{
display:grid;
grid-template-columns:0.9fr 1.1fr;
gap:80px;
align-items:start;
}

body.oc365-html-contact .contact-info-col{
display:flex;
flex-direction:column;
}

body.oc365-html-contact .contact-title{
font-family:var(--oc365-contact-font-heading);
font-size:2.5rem;
font-weight:800;
letter-spacing:-0.02em;
line-height:1.25;
color:var(--oc365-color-text, #111827);
margin:0 0 12px;
}

body.oc365-html-contact .contact-subtitle{
font-family:var(--oc365-contact-font-body);
font-size:1.1rem;
font-weight:400;
letter-spacing:normal;
line-height:1.6;
color:var(--oc365-color-text-muted, #6b7280);
margin:0 0 48px;
}

body.oc365-html-contact .contact-channels{
display:flex;
flex-direction:column;
gap:32px;
}

body.oc365-html-contact .channel-card{
display:flex;
gap:20px;
align-items:flex-start;
}

body.oc365-html-contact .channel-icon{
width:44px;
height:44px;
border-radius:6px;
border:1px solid var(--oc365-color-border, #e5e7eb);
background-color:var(--oc365-color-card, #fff);
display:flex;
align-items:center;
justify-content:center;
color:var(--oc365-color-text, #111827);
flex-shrink:0;
}

body.oc365-html-contact .channel-details{
display:flex;
flex-direction:column;
}

body.oc365-html-contact .channel-name{
font-family:var(--oc365-contact-font-heading);
font-weight:600;
font-size:0.95rem;
letter-spacing:normal;
line-height:1.4;
color:var(--oc365-color-text, #111827);
margin-bottom:4px;
}

body.oc365-html-contact .channel-val{
font-family:var(--oc365-contact-font-body);
font-size:0.95rem;
font-weight:400;
letter-spacing:normal;
line-height:1.5;
color:var(--oc365-color-text-muted, #6b7280);
}

body.oc365-html-contact .channel-val a{
color:inherit;
text-decoration:none;
}

body.oc365-html-contact .channel-val a:hover{
color:var(--oc365-color-text, #111827);
text-decoration:underline;
}

body.oc365-html-contact .contact-page-content{
margin-top:32px;
max-width:36rem;
}

body.oc365-html-contact .contact-form-col{
width:100%;
}

body.oc365-html-contact .contact-form-card{
background-color:var(--oc365-color-card, #fff);
border:1px solid var(--oc365-color-border, #e5e7eb);
border-radius:10px;
padding:40px;
box-shadow:0 1px 2px rgba(0, 0, 0, 0.04);
}

body.oc365-html-contact .contact-form-card .form-notice{
margin-bottom:24px;
padding:12px 16px;
border-radius:6px;
font-family:var(--oc365-contact-font-body);
font-size:0.9rem;
line-height:1.5;
}

body.oc365-html-contact .contact-form-card .form-notice--success{
background:#ecfdf5;
border:1px solid #a7f3d0;
color:#065f46;
}

body.oc365-html-contact .contact-form-card .form-notice--error{
background:#fef2f2;
border:1px solid #fecaca;
color:#991b1b;
}

body.oc365-html-contact .contact-form .form-group{
margin-bottom:24px;
position:relative;
}

body.oc365-html-contact .contact-form .form-label{
display:block;
font-family:var(--oc365-contact-font-heading);
font-weight:600;
font-size:0.9rem;
letter-spacing:normal;
line-height:1.4;
color:var(--oc365-color-text, #111827);
margin-bottom:8px;
}

body.oc365-html-contact .contact-form .required-star{
color:#f43f5e;
margin-left:2px;
}

body.oc365-html-contact .contact-form .form-control{
display:block;
width:100%;
padding:12px 16px;
border:1px solid var(--oc365-color-border, #e5e7eb);
border-radius:6px;
font-family:var(--oc365-contact-font-body);
font-size:0.95rem;
font-weight:400;
letter-spacing:normal;
line-height:1.4;
color:var(--oc365-color-text, #111827);
background-color:var(--oc365-color-bg, #fafafa);
box-sizing:border-box;
transition:0.25s cubic-bezier(0.4, 0, 0.2, 1);
-webkit-appearance:none;
appearance:none;
}

body.oc365-html-contact .contact-form .form-control:focus{
outline:none;
border-color:var(--oc365-color-text, #111827);
background-color:var(--oc365-color-card, #fff);
box-shadow:0 0 0 3px rgba(17, 24, 39, 0.05);
}

body.oc365-html-contact .contact-form textarea.form-control{
resize:vertical;
min-height:120px;
height:auto;
}

body.oc365-html-contact .contact-form .form-submit-btn{
margin-top:12px;
width:100%;
}

/* Buttons (html .btn) — hero + form card */
body.oc365-html-contact .contact-hero .btn,
body.oc365-html-contact .contact-form-card .btn{
display:inline-flex;
align-items:center;
justify-content:center;
padding:10px 20px;
font-family:var(--oc365-contact-font-heading);
font-weight:600;
font-size:0.95rem;
line-height:1.2;
letter-spacing:normal;
border-radius:6px;
transition:0.25s cubic-bezier(0.4, 0, 0.2, 1);
cursor:pointer;
border:1px solid transparent;
text-decoration:none;
box-sizing:border-box;
}

body.oc365-html-contact .contact-hero .btn-primary,
body.oc365-html-contact .contact-form-card .btn-primary{
background-color:#0f172a;
color:#fff;
}

body.oc365-html-contact .contact-hero .btn-primary:hover,
body.oc365-html-contact .contact-form-card .btn-primary:hover{
background-color:#1e293b;
transform:translateY(-1px);
box-shadow:0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
color:#fff;
}

body.oc365-html-contact .contact-hero .btn-primary:active,
body.oc365-html-contact .contact-form-card .btn-primary:active{
transform:scale(0.98);
}

body.oc365-html-contact .contact-form-card .btn-secondary{
background-color:var(--oc365-color-card, #fff);
color:var(--oc365-color-text, #111827);
border-color:var(--oc365-color-border, #e5e7eb);
}

body.oc365-html-contact .contact-form-card .btn-secondary:hover{
border-color:var(--oc365-color-text-muted, #9ca3af);
background-color:#fcfcfc;
color:var(--oc365-color-text, #111827);
transform:translateY(-1px);
box-shadow:0 1px 2px rgba(0, 0, 0, 0.05);
}

body.oc365-html-contact .contact-form-card .error-404-card-title{
font-family:var(--oc365-contact-font-heading);
font-size:1.25rem;
font-weight:700;
letter-spacing:-0.02em;
color:var(--oc365-color-text, #111827);
margin:0 0 8px;
}

body.oc365-html-contact .contact-form-card .error-404-card-lead{
font-family:var(--oc365-contact-font-body);
font-size:0.95rem;
line-height:1.5;
color:var(--oc365-color-text-muted, #6b7280);
margin:0 0 24px;
}

body.oc365-html-contact .contact-form-card .error-404-home-btn{
margin-top:12px;
}

body.oc365-html-contact .contact-form-col.reveal{
transition-delay:0.15s;
}

/* Reveal (home-html-effects.js) */
body.oc365-html-contact .reveal{
opacity:0;
transform:translateY(24px);
transition:opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

body.oc365-html-contact .reveal.active{
opacity:1;
transform:translateY(0);
}

@media (max-width:1024px){
body.oc365-html-contact .contact-grid{
grid-template-columns:1fr;
gap:60px;
}
}

@media (max-width:768px){
body.oc365-html-contact .contact-hero{
padding:48px 0 72px;
}

body.oc365-html-contact .contact-title{
font-size:2rem;
}

body.oc365-html-contact .contact-subtitle{
margin-bottom:36px;
}

body.oc365-html-contact .contact-form-card{
padding:28px 24px;
}

body.oc365-html-contact .contact-form .form-control{
font-size:16px;
}
}
