/* =========================================================================
   Deokate Ortho & Pain Care — main.css
   Layout, components, and design system. Mobile-first, CWV-conscious.
   ========================================================================= */

/* ---- Base ---- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--text-body);background:var(--white);line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--font-head);color:var(--brand-dark);line-height:1.25;margin:0 0 .6em}
h1{font-size:clamp(1.8rem,4vw,2.6rem)}
h2{font-size:clamp(1.45rem,3vw,2rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
a{color:var(--brand-primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
ul,ol{padding-left:1.2rem}
.container{width:min(var(--container),92%);margin-inline:auto}
.container.narrow{max-width:820px}
.center{text-align:center}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}

/* ---- Buttons ---- */
.btn{display:inline-block;border-radius:8px;padding:.75rem 1.4rem;font-weight:600;font-family:var(--font-head);text-decoration:none;border:2px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;text-align:center}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--brand-primary);color:#fff}
.btn-secondary{background:var(--brand-secondary);color:#fff}
.btn-accent{background:var(--brand-accent);color:#3a2600}
.btn-outline{background:transparent;border-color:var(--brand-primary);color:var(--brand-primary)}
.btn-block{display:block;width:100%;margin-bottom:.6rem}

/* ---- Header ---- */
.topbar a:hover{text-decoration:underline}
.topbar .sep{opacity:.4;margin:0 .4rem}
.header-cta{display:flex;align-items:center;gap:.6rem}
.primary-nav .nav-menu{display:flex;gap:1.2rem;list-style:none;margin:0;padding:0;align-items:center}
.primary-nav .nav-menu li{position:relative}
.primary-nav a{color:var(--brand-dark);font-weight:500;font-family:var(--font-head);padding:.6rem .2rem;display:block}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:var(--brand-primary);text-decoration:none}
.primary-nav .sub-menu{position:absolute;top:100%;left:0;min-width:240px;background:#fff;box-shadow:var(--shadow);border-radius:10px;padding:.5rem 0;display:none;z-index:50}
.primary-nav .menu-item-has-children:hover>.sub-menu{display:block}
.primary-nav .sub-menu a{padding:.55rem 1.1rem}
.primary-nav .sub-menu .sub-menu{top:0;left:100%}

/* ---- Breadcrumbs ---- */
.breadcrumbs{background:var(--brand-light);font-size:.85rem;border-bottom:1px solid #e6eef4}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;margin:0;padding:.6rem 0}
.breadcrumbs li:not(:last-child)::after{content:"›";margin-left:.4rem;color:var(--text-muted)}
.breadcrumbs li[aria-current]{color:var(--text-muted)}

/* ---- Hero ---- */
.hero{background:linear-gradient(135deg,#eaf3f9 0%,#f4f8fb 60%);padding:3rem 0}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem;align-items:center}
.hero .eyebrow{color:var(--brand-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;margin-bottom:.5rem}
.hero h1{margin-bottom:1rem}
.hero-sub{font-size:1.08rem;color:var(--text-muted);max-width:46ch}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.4rem 0}
.hero-trust{list-style:none;padding:0;display:flex;gap:1.2rem;flex-wrap:wrap;font-size:.9rem;color:var(--brand-dark);font-weight:500}
.hero-media img{border-radius:18px;box-shadow:var(--shadow);object-fit:cover}

/* ---- Sections ---- */
.home-section{padding:3.5rem 0}
.home-section:nth-child(even){background:var(--brand-light)}
.section-head{text-align:center;max-width:640px;margin:0 auto 2rem}
.section-head p{color:var(--text-muted)}

/* ---- Cards / grids ---- */
.card-grid{display:grid;gap:1.4rem}
.card-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.card-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.service-card{display:block;background:#fff;border:1px solid #e6eef4;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease;color:inherit}
.service-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(13,36,56,.12);text-decoration:none}
.service-card h3{color:var(--brand-primary);margin-bottom:.4rem}
.service-card p{color:var(--text-muted);font-size:.95rem;margin-bottom:.8rem}
.link-arrow{color:var(--brand-secondary);font-weight:600}
.service-thumb img{border-radius:8px;margin-bottom:.9rem}

/* ---- Why us ---- */
.why-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center}
.why-list{list-style:none;padding:0}
.why-list li{padding:.6rem 0 .6rem 1.8rem;position:relative}
.why-list li::before{content:"✓";position:absolute;left:0;top:.55rem;color:#fff;background:var(--brand-secondary);width:1.2rem;height:1.2rem;border-radius:50%;font-size:.8rem;display:grid;place-items:center}
.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.why-stats .stat{background:#fff;border-radius:var(--radius);padding:1.4rem;text-align:center;box-shadow:var(--shadow);font-size:.9rem;color:var(--text-muted)}
.why-stats .stat span{display:block;font-family:var(--font-head);font-size:2rem;font-weight:700;color:var(--brand-primary)}

/* ---- Testimonials ---- */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.testimonial-card{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);margin:0}
.testimonial-card .stars{color:var(--brand-accent);margin-bottom:.6rem;letter-spacing:2px}
.testimonial-card blockquote{margin:0 0 1rem;font-style:italic;color:var(--text-body)}
.testimonial-card figcaption strong{display:block;color:var(--brand-dark)}
.testimonial-card figcaption span{font-size:.85rem;color:var(--text-muted)}

/* ---- FAQ accordion ---- */
.faq-accordion{display:flex;flex-direction:column;gap:.7rem}
.faq-item{background:#fff;border:1px solid #e6eef4;border-radius:var(--radius);overflow:hidden}
.faq-item summary{cursor:pointer;padding:1rem 1.2rem;font-weight:600;font-family:var(--font-head);color:var(--brand-dark);list-style:none;position:relative}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:1.2rem;color:var(--brand-primary);font-size:1.3rem}
.faq-item[open] summary::after{content:"−"}
.faq-answer{padding:0 1.2rem 1.1rem;color:var(--text-muted)}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(135deg,var(--brand-primary),var(--brand-secondary));color:#fff;padding:2.4rem 0}
.cta-inner{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap}
.cta-text{font-family:var(--font-head);font-size:1.3rem;font-weight:600;margin:0}
.cta-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.cta-band .btn-outline{border-color:#fff;color:#fff}

/* ---- Content area / single ---- */
.content-area{padding:2.5rem 0 3rem}
.content-area.with-sidebar{display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:start}
.entry-title{margin-bottom:1rem}
.entry-thumb img{border-radius:var(--radius);margin-bottom:1.5rem}
.entry-content h2{margin-top:2rem}
.entry-content h3{margin-top:1.5rem}
.entry-content img{border-radius:var(--radius)}
.entry-content ul,.entry-content ol{margin-bottom:1.2rem}
.entry-content blockquote{border-left:4px solid var(--brand-secondary);background:var(--brand-light);margin:1.5rem 0;padding:1rem 1.4rem;border-radius:0 8px 8px 0}
.post-meta{display:flex;gap:1rem;color:var(--text-muted);font-size:.9rem;margin-bottom:1rem;flex-wrap:wrap}
.author-box{background:var(--brand-light);border-radius:var(--radius);padding:1.4rem;margin-top:1.5rem}
.entry-footer{margin-top:1.5rem}

/* ---- Sidebar ---- */
.sidebar .widget{background:#fff;border:1px solid #e6eef4;border-radius:var(--radius);padding:1.3rem;margin-bottom:1.4rem;box-shadow:var(--shadow)}
.sidebar .widget-cta-card{background:linear-gradient(135deg,#eaf3f9,#f4f8fb)}
.widget-title{margin-bottom:.9rem;font-size:1.05rem}
.sidebar ul{list-style:none;padding:0;margin:0}
.sidebar ul li{padding:.4rem 0;border-bottom:1px solid #eef3f7}

/* ---- Post list / cards ---- */
.post-list{display:grid;gap:1.6rem}
.post-card{display:grid;grid-template-columns:240px 1fr;gap:1.4rem;background:#fff;border:1px solid #e6eef4;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.post-card .card-thumb img{height:100%;object-fit:cover}
.post-card .card-body{padding:1.2rem 1.4rem}
.card-meta{color:var(--text-muted);font-size:.82rem;margin-bottom:.4rem}
.card-title{font-size:1.25rem;margin-bottom:.5rem}

/* ---- Forms ---- */
.deokate-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.deokate-form .field{margin:0 0 1rem;display:flex;flex-direction:column}
.deokate-form .field-full{grid-column:1/-1}
.deokate-form label{font-weight:600;font-size:.9rem;margin-bottom:.35rem;color:var(--brand-dark)}
.deokate-form input,.deokate-form select,.deokate-form textarea{padding:.7rem .85rem;border:1px solid #cdd9e2;border-radius:8px;font:inherit;width:100%;background:#fff}
.deokate-form input:focus,.deokate-form select:focus,.deokate-form textarea:focus{outline:2px solid var(--brand-secondary);border-color:var(--brand-secondary)}
.deokate-hp{position:absolute;left:-9999px}
.form-response{margin-top:.8rem;font-weight:600}
.form-response.ok{color:#1c7c54}
.form-response.err{color:#b3261e}

/* ---- Layouts for templates ---- */
.contact-layout,.appointment-layout{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-top:1.5rem}
.contact-list{list-style:none;padding:0}
.contact-list li{padding:.5rem 0;border-bottom:1px solid #eef3f7}
.appointment-points{list-style:none;padding:0}
.appointment-points li{padding:.45rem 0}
.service-group{margin-top:2.5rem}
.service-group-title{border-left:5px solid var(--brand-secondary);padding-left:.7rem;margin-bottom:1.2rem}

/* ---- Footer ---- */
.site-footer{background:var(--brand-dark);color:#cdd9e2;margin-top:0;padding-top:3rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2rem;padding-bottom:2rem}
.site-footer h4{color:#fff}
.site-footer a{color:#cdd9e2}
.site-footer a:hover{color:#fff}
.footer-menu{list-style:none;padding:0;margin:0}
.footer-menu li{padding:.3rem 0}
.social-links{display:flex;gap:.5rem;margin-top:1rem}
.social-links a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center;font-weight:700}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:1.2rem 0;font-size:.82rem}
.footer-bottom p{margin:.2rem 0}
.footer-disclaimer{opacity:.7}

/* ---- 404 ---- */
.error-404{text-align:center;max-width:640px;margin:2rem auto}
.error-404 .error-code{font-size:5rem;font-weight:700;color:var(--brand-secondary);font-family:var(--font-head);margin:0}
.error-links{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin:1.4rem 0}

/* ---- Pagination ---- */
.pagination{display:flex;gap:.4rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}
.pagination .page-numbers{padding:.5rem .85rem;border:1px solid #cdd9e2;border-radius:8px;color:var(--brand-primary)}
.pagination .current{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}

/* ---- Mobile action bar (hidden on desktop) ---- */
.mobile-actionbar{display:none}

/* ---- Elementor full-width canvas ---- */
.fullwidth-canvas{width:100%}
