/*
Theme Name: Ótica Premium Elementor
Theme URI: https://teknora.com.br/
Author: Teknora
Author URI: https://teknora.com.br/
Description: Tema leve e premium para óticas, criado para Elementor Free, WooCommerce, Contact Form 7, Qi Addons e Teknora DNP para Ótica.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: otica-premium-elementor
Tags: custom-logo, ecommerce, one-column, two-columns, custom-menu, featured-images, block-styles
*/

:root{
  --op-bg:#f7f3ec;
  --op-bg-soft:#fffaf3;
  --op-text:#191714;
  --op-muted:#6f675c;
  --op-gold:#b88a44;
  --op-gold-dark:#8c642e;
  --op-black:#101010;
  --op-border:rgba(25,23,20,.12);
  --op-radius:24px;
  --op-shadow:0 24px 70px rgba(0,0,0,.10);
  --op-font-title:'Playfair Display', Georgia, serif;
  --op-font-body:'Inter', Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--op-bg);
  color:var(--op-text);
  font-family:var(--op-font-body);
  line-height:1.6;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

.op-container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.op-btn,.button,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border-radius:999px;border:1px solid transparent;
  padding:14px 24px;font-weight:700;letter-spacing:.02em;
  background:var(--op-black);color:#fff;transition:.25s ease;cursor:pointer;
}
.op-btn:hover,.button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover{transform:translateY(-2px);box-shadow:0 14px 35px rgba(0,0,0,.18)}
.op-btn--gold{background:var(--op-gold);color:#fff}
.op-btn--outline{background:transparent;color:var(--op-text);border-color:var(--op-border)}
.op-eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.18em;font-weight:800;color:var(--op-gold);margin-bottom:12px}
.op-title{font-family:var(--op-font-title);font-size:clamp(42px,7vw,88px);line-height:.95;letter-spacing:-.04em;margin:0 0 22px}
.op-section-title{font-family:var(--op-font-title);font-size:clamp(32px,4vw,58px);line-height:1;margin:0 0 18px;letter-spacing:-.03em}
.op-lead{font-size:clamp(17px,2vw,22px);color:var(--op-muted);max-width:720px}

.site-header{position:sticky;top:0;z-index:50;background:rgba(247,243,236,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--op-border)}
.site-header .op-container{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:24px}
.site-branding{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}
.site-branding img{max-height:46px;width:auto}
.main-navigation ul{list-style:none;display:flex;gap:28px;margin:0;padding:0;align-items:center}
.main-navigation a{font-size:14px;font-weight:700;color:var(--op-text);opacity:.88}
.main-navigation a:hover{color:var(--op-gold)}
.op-menu-toggle{display:none;background:transparent;border:0;font-size:28px;cursor:pointer}

.op-hero{min-height:calc(100vh - 78px);display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(110deg,#f7f3ec 0%,#f1e5d4 55%,#d9c0a0 100%)}
.op-hero:after{content:"";position:absolute;inset:auto -15% -30% 35%;height:70%;background:radial-gradient(circle,rgba(184,138,68,.32),transparent 60%)}
.op-hero-grid{display:grid;grid-template-columns:1.02fr .98fr;align-items:center;gap:40px;position:relative;z-index:1;padding:70px 0}
.op-hero-card{background:rgba(255,250,243,.62);border:1px solid rgba(255,255,255,.7);border-radius:36px;padding:42px;box-shadow:var(--op-shadow);backdrop-filter:blur(16px)}
.op-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.op-hero-media{position:relative;min-height:560px;border-radius:44px;overflow:hidden;background:#ddd;box-shadow:var(--op-shadow)}
.op-hero-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.op-floating{position:absolute;right:22px;bottom:22px;background:#fff;border-radius:24px;padding:18px 20px;box-shadow:0 20px 50px rgba(0,0,0,.16);max-width:260px;font-weight:700}

.op-section{padding:96px 0}
.op-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.op-card{background:var(--op-bg-soft);border:1px solid var(--op-border);border-radius:var(--op-radius);padding:30px;box-shadow:0 12px 36px rgba(0,0,0,.04);transition:.25s ease}
.op-card:hover{transform:translateY(-6px);box-shadow:var(--op-shadow)}
.op-card h3{font-family:var(--op-font-title);font-size:30px;line-height:1.05;margin:12px 0;color:var(--op-text)}
.op-card p{color:var(--op-muted);margin:0}
.op-icon{width:52px;height:52px;border-radius:18px;background:rgba(184,138,68,.14);display:flex;align-items:center;justify-content:center;color:var(--op-gold);font-weight:900;font-size:24px}

.op-split{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.op-image-round{border-radius:36px;overflow:hidden;box-shadow:var(--op-shadow);min-height:520px;background:#ddd}
.op-image-round img{width:100%;height:100%;object-fit:cover}
.op-list{display:grid;gap:14px;margin-top:28px}
.op-list div{display:flex;gap:12px;align-items:flex-start;color:var(--op-muted)}
.op-list strong{color:var(--op-text)}

.op-dark{background:var(--op-black);color:#fff}
.op-dark .op-lead,.op-dark .op-card p{color:rgba(255,255,255,.68)}
.op-dark .op-card{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}
.op-dark .op-card h3{color:#fff}

.op-products .products{display:grid!important;grid-template-columns:repeat(4,1fr);gap:24px!important}
.woocommerce ul.products li.product{width:auto!important;float:none!important;background:#fff;border-radius:24px;padding:16px!important;box-shadow:0 12px 36px rgba(0,0,0,.06);transition:.25s ease;overflow:hidden}
.woocommerce ul.products li.product:hover{transform:translateY(-5px)}
.woocommerce ul.products li.product a img{border-radius:18px;margin-bottom:14px!important}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-size:17px!important;font-weight:800;color:var(--op-text)}
.woocommerce ul.products li.product .price{color:var(--op-gold)!important;font-weight:900!important}

.op-dnp-box{border-radius:32px;background:linear-gradient(135deg,#191714,#3a2b1a);color:#fff;padding:40px;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;box-shadow:var(--op-shadow)}
.op-dnp-box p{color:rgba(255,255,255,.72);margin:0}

.site-footer{background:#0f0f0f;color:#fff;padding:54px 0 28px}
.site-footer .op-container{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.site-footer p,.site-footer a{color:rgba(255,255,255,.68)}
.site-footer h3{font-family:var(--op-font-title);font-size:28px;margin:0 0 12px;color:#fff}
.op-footer-bottom{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;font-size:13px;color:rgba(255,255,255,.55)}

.wpcf7 input,.wpcf7 textarea,.wpcf7 select{width:100%;border:1px solid var(--op-border);border-radius:18px;padding:14px 16px;background:#fff;font:inherit;margin-bottom:12px}
.wpcf7-submit{background:var(--op-black)!important;color:#fff!important;border:0!important;border-radius:999px!important;padding:14px 24px!important;font-weight:800!important}

@media(max-width:900px){
  .main-navigation{display:none;position:absolute;top:78px;left:0;right:0;background:var(--op-bg);padding:18px 24px;border-bottom:1px solid var(--op-border)}
  .main-navigation.is-open{display:block}
  .main-navigation ul{flex-direction:column;align-items:flex-start;gap:16px}
  .op-menu-toggle{display:block}
  .op-hero-grid,.op-split,.op-dnp-box{grid-template-columns:1fr}
  .op-hero-media{min-height:420px}
  .op-grid-3,.op-products .products{grid-template-columns:1fr 1fr!important}
  .site-footer .op-container{grid-template-columns:1fr}
}
@media(max-width:560px){
  .op-container{width:min(100% - 26px,1180px)}
  .op-section{padding:64px 0}
  .op-hero-card{padding:28px;border-radius:28px}
  .op-grid-3,.op-products .products{grid-template-columns:1fr!important}
  .op-hero-media{min-height:360px;border-radius:30px}
}
