/* ============================================
   NAMESEE — Premium Domain Brokerage
   style.css — Main Stylesheet
   ============================================ */

/* ---- 1. CSS Custom Properties ---- */
:root {
  --bg-primary:      #0a0a0a;
  --bg-secondary:    #111111;
  --bg-tertiary:     #1a1a1a;
  --bg-card:         #141414;
  --bg-input:        #0f0f0f;
  --text-primary:    #f5f0eb;
  --text-secondary:  #b8afa5;
  --text-muted:      #8a8279;
  --accent:          #c9a96e;
  --accent-light:    #d4b97d;
  --accent-dark:     #b8944f;
  --accent-glow:     rgba(201,169,110,.15);
  --border:          rgba(201,169,110,.15);
  --border-light:    rgba(201,169,110,.08);
  --gold-gradient:   linear-gradient(135deg,#c9a96e,#e8d5a3,#c9a96e);
  --shadow-sm:       0 2px 8px  rgba(0,0,0,.3);
  --shadow-md:       0 4px 20px rgba(0,0,0,.4);
  --shadow-lg:       0 8px 40px rgba(0,0,0,.5);
  --ease-out:        cubic-bezier(.16,1,.3,1);
  --t-slow:  .8s var(--ease-out);
  --t-med:   .5s var(--ease-out);
  --t-fast:  .3s var(--ease-out);
  --r-sm:    4px;
  --r-md:    8px;
  --r-lg:    12px;
  --max-w:   1200px;
  --sec-pad: 8rem;
  --nav-h:   80px;
}

/* ---- 2. Reset ---- */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  line-height: 1.6;
  overflow-x: hidden;
  min-height: 100vh;
}

img,svg { max-width:100%; height:auto; display:block; }
a       { color:inherit; text-decoration:none; }
ul      { list-style:none; }

/* ---- 3. Accessibility ---- */
.skip-link {
  position:absolute; top:-100%; left:50%;
  transform:translateX(-50%);
  background:var(--accent); color:var(--bg-primary);
  padding:.8rem 1.5rem; border-radius:var(--r-sm);
  font-weight:500; z-index:10001;
  transition:top .3s ease;
}
.skip-link:focus { top:1rem; outline:2px solid var(--accent-light); outline-offset:2px; }

.sr-only {
  position:absolute; width:1px; height:1px;
  padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

*:focus-visible                                       { outline:2px solid var(--accent); outline-offset:3px; }
input:focus-visible,textarea:focus-visible,
select:focus-visible,button:focus-visible             { outline:2px solid var(--accent); outline-offset:2px;
                                                        box-shadow:0 0 0 4px rgba(201,169,110,.15); }

/* ---- 4. Keyframes ---- */
@keyframes fadeInUp  { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn    { from{opacity:0} to{opacity:1} }
@keyframes float     { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes slideInR  { from{opacity:0;transform:translateX(30px)}  to{opacity:1;transform:translateX(0)} }
@keyframes slideInL  { from{opacity:0;transform:translateX(-30px)} to{opacity:1;transform:translateX(0)} }
@keyframes scrollDn  { 0%{top:-100%} 100%{top:100%} }
@keyframes loadBar   { to{width:100%} }
@keyframes spin      { to{transform:rotate(360deg)} }
@keyframes pulse     { 0%,100%{opacity:1} 50%{opacity:.5} }

/* ---- 5. Preloader ---- */
.preloader {
  position:fixed; inset:0; background:var(--bg-primary);
  z-index:10000; display:flex; align-items:center;
  justify-content:center; flex-direction:column;
  transition:opacity .6s ease,visibility .6s ease;
}
.preloader.hidden { opacity:0; visibility:hidden; pointer-events:none; }

.preloader-logo {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(1.5rem,4vw,2.5rem); font-weight:300;
  letter-spacing:.3em; color:var(--accent);
  margin-bottom:2rem; opacity:0;
  animation:fadeInUp 1s .2s forwards;
}

.preloader-bar {
  width:120px; height:1px; background:var(--border);
  position:relative; overflow:hidden;
}
.preloader-bar::after {
  content:''; position:absolute; left:0; top:0;
  height:100%; width:0; background:var(--accent);
  animation:loadBar 1.5s .5s forwards;
}

/* ---- 6. Navigation ---- */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:0 3rem; height:var(--nav-h);
  display:flex; align-items:center; justify-content:space-between;
  transition:all var(--t-med); background:transparent;
}
.nav.scrolled {
  background:rgba(10,10,10,.95);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border-light); height:70px;
}

.nav-logo {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.6rem; font-weight:400; letter-spacing:.2em;
  color:var(--text-primary); display:flex; align-items:center;
  gap:.5rem; transition:color var(--t-fast); z-index:1001;
}
.nav-logo:hover { color:var(--accent); }
.nav-logo-dot  { width:6px; height:6px; background:var(--accent); border-radius:50%; display:inline-block; }

.nav-links { display:flex; align-items:center; gap:2.5rem; }

.nav-link {
  font-size:.8rem; font-weight:400; letter-spacing:.15em;
  text-transform:uppercase; color:var(--text-secondary);
  transition:color var(--t-fast); position:relative; padding:.25rem 0;
}
.nav-link::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:1px; background:var(--accent);
  transition:width var(--t-fast);
}
.nav-link:hover,.nav-link.active                 { color:var(--text-primary); }
.nav-link:hover::after,.nav-link.active::after   { width:100%; }

.nav-cta {
  font-size:.75rem; font-weight:500; letter-spacing:.15em;
  text-transform:uppercase; color:var(--bg-primary);
  background:var(--accent); padding:.65rem 1.8rem;
  border:none; cursor:pointer; transition:all var(--t-fast);
  border-radius:var(--r-sm);
}
.nav-cta:hover { background:var(--accent-light); transform:translateY(-1px); }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:5px; z-index:1001;
  background:none; border:none;
}
.hamburger span {
  width:24px; height:1px; background:var(--text-primary);
  transition:all var(--t-fast); transform-origin:center;
}
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(4px,4px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

/* Mobile Menu */
.mobile-menu {
  position:fixed; inset:0;
  background:rgba(10,10,10,.98);
  backdrop-filter:blur(30px); -webkit-backdrop-filter:blur(30px);
  z-index:999; display:flex; align-items:center;
  justify-content:center; flex-direction:column; gap:2rem;
  opacity:0; visibility:hidden; transition:all var(--t-med);
}
.mobile-menu.active { opacity:1; visibility:visible; }
.mobile-menu a {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:2rem; font-weight:300; color:var(--text-secondary);
  transition:color var(--t-fast);
}
.mobile-menu a:hover   { color:var(--accent); }
.mobile-menu .mobile-cta {
  color:var(--accent) !important; border:1px solid var(--accent);
  padding:.8rem 2rem; font-size:1.2rem; border-radius:var(--r-sm);
}

/* ---- 7. Buttons ---- */
.btn-primary {
  font-size:.75rem; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--bg-primary);
  background:var(--accent); padding:1rem 2.5rem;
  border:none; cursor:pointer; transition:all var(--t-fast);
  display:inline-block; border-radius:var(--r-sm);
  position:relative; overflow:hidden;
}
.btn-primary::before {
  content:''; position:absolute; top:0; left:-100%;
  width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transition:left .5s;
}
.btn-primary:hover::before { left:100%; }
.btn-primary:hover {
  background:var(--accent-light); transform:translateY(-2px);
  box-shadow:0 4px 20px rgba(201,169,110,.3);
}

.btn-secondary {
  font-size:.75rem; font-weight:400; letter-spacing:.2em;
  text-transform:uppercase; color:var(--text-secondary);
  background:transparent; padding:1rem 2.5rem;
  border:1px solid var(--border); cursor:pointer;
  transition:all var(--t-fast); display:inline-block;
  border-radius:var(--r-sm);
}
.btn-secondary:hover { border-color:var(--accent); color:var(--accent); transform:translateY(-2px); }

.btn-whatsapp {
  display:inline-flex; align-items:center; gap:.8rem;
  font-size:.85rem; font-weight:400; color:#fff;
  background:#25D366; padding:1rem 2rem;
  border-radius:var(--r-md); transition:all var(--t-fast);
}
.btn-whatsapp:hover {
  background:#20BD5A; transform:translateY(-2px);
  box-shadow:0 4px 20px rgba(37,211,102,.3);
}

/* ---- 8. Section Scaffolding ---- */
.section   { padding:var(--sec-pad) 3rem; position:relative; }
.container { max-width:var(--max-w); margin:0 auto; padding:0 3rem; }
.divider   { width:60px; height:1px; background:var(--accent); margin:0 auto; opacity:.5; }

.section-header { text-align:center; max-width:700px; margin:0 auto 5rem; }
.section-eyebrow {
  font-size:.7rem; font-weight:500; letter-spacing:.35em;
  text-transform:uppercase; color:var(--accent);
  margin-bottom:1.5rem; display:block;
}
.section-title {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(2rem,4vw,3rem); font-weight:300;
  line-height:1.2; color:var(--text-primary); margin-bottom:1.5rem;
}
.section-desc { font-size:.95rem; font-weight:300; color:var(--text-secondary); line-height:1.8; }

/* ---- 9. Hero ---- */
.hero {
  min-height:100vh; display:flex; align-items:center;
  justify-content:center; position:relative; overflow:hidden;
  padding:calc(var(--nav-h) + 2rem) 3rem 4rem;
  background:
    radial-gradient(ellipse at 50% 20%,rgba(201,169,110,.06) 0%,transparent 60%),
    linear-gradient(180deg,#0f0f0f 0%,var(--bg-primary) 100%);
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(circle at 20% 80%,rgba(201,169,110,.03) 0%,transparent 50%),
    radial-gradient(circle at 80% 20%,rgba(201,169,110,.03) 0%,transparent 50%);
  pointer-events:none;
}
.hero-glow {
  position:absolute; top:10%; left:50%; transform:translateX(-50%);
  width:600px; height:600px;
  background:radial-gradient(circle,rgba(201,169,110,.04) 0%,transparent 70%);
  pointer-events:none; animation:float 8s ease-in-out infinite;
}
.hero-content { position:relative; z-index:1; text-align:center; max-width:900px; }

.hero-eyebrow {
  font-size:.7rem; font-weight:500; letter-spacing:.35em;
  text-transform:uppercase; color:var(--accent); margin-bottom:2rem;
}
.hero-title {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(2.2rem,6vw,5rem); font-weight:300;
  line-height:1.1; letter-spacing:-.01em;
  color:var(--text-primary); margin-bottom:2rem;
}
.hero-title em { font-style:italic; color:var(--accent); }
.hero-subtitle {
  font-size:clamp(.9rem,1.5vw,1.05rem); font-weight:300;
  color:var(--text-secondary); max-width:560px;
  margin:0 auto 3rem; line-height:1.8;
}
.hero-actions { display:flex; align-items:center; justify-content:center; gap:1.5rem; flex-wrap:wrap; }

.hero-scroll {
  position:absolute; bottom:3rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.75rem;
  font-size:.65rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--text-muted);
}
.hero-scroll-line {
  width:1px; height:40px; background:var(--accent); position:relative; overflow:hidden;
}
.hero-scroll-line::after {
  content:''; position:absolute; top:-100%; left:0;
  width:100%; height:100%; background:var(--bg-primary);
  animation:scrollDn 1.5s ease-in-out infinite;
}

/* ---- 10. Methodology ---- */
.methodology { background:var(--bg-secondary); }
.methodology-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:2rem;
  max-width:var(--max-w); margin:0 auto;
}
.methodology-card {
  padding:3rem; border:1px solid var(--border-light); border-radius:var(--r-lg);
  background:var(--bg-card); transition:all var(--t-fast); position:relative; overflow:hidden;
}
.methodology-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--gold-gradient); opacity:0; transition:opacity var(--t-fast);
}
.methodology-card:hover { border-color:var(--border); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.methodology-card:hover::before { opacity:1; }

.methodology-number {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:3.5rem; font-weight:300; color:var(--accent);
  opacity:.3; line-height:1; margin-bottom:1.5rem;
}
.methodology-card h3 {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.4rem; font-weight:400; color:var(--text-primary);
  margin-bottom:1rem; letter-spacing:.02em;
}
.methodology-card p {
  font-size:.9rem; font-weight:300; color:var(--text-secondary); line-height:1.8;
}

/* ---- 11. Domain Cards ---- */
.domains-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem;
  max-width:var(--max-w); margin:0 auto;
}
.domain-card {
  padding:2.5rem; border:1px solid var(--border-light); border-radius:var(--r-lg);
  background:var(--bg-card); transition:all var(--t-fast); position:relative;
  display:flex; flex-direction:column; gap:1rem;
}
.domain-card:hover { border-color:var(--accent); transform:translateY(-4px); box-shadow:0 8px 30px rgba(201,169,110,.1); }

.domain-badge {
  font-size:.6rem; font-weight:500; letter-spacing:.2em; text-transform:uppercase;
  color:var(--accent); border:1px solid var(--accent); padding:.3rem .8rem;
  border-radius:var(--r-sm); display:inline-block; width:fit-content;
}
.domain-name {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.8rem; font-weight:300; color:var(--text-primary);
}
.domain-meta { font-size:.78rem; color:var(--text-muted); letter-spacing:.05em; }
.domain-price {
  font-size:.75rem; font-weight:500; letter-spacing:.15em; text-transform:uppercase;
  color:var(--accent); margin-top:auto; display:inline-flex; align-items:center;
  gap:.5rem; transition:gap var(--t-fast);
}
.domain-price:hover { gap:.75rem; }
.domain-price::after { content:'→'; }

/* ---- 12. Stats ---- */
.stats { background:var(--bg-secondary); }
.stats-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:3rem;
  max-width:var(--max-w); margin:0 auto; padding:0 3rem;
}
.stat-item { text-align:center; }
.stat-number {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(2.5rem,5vw,4rem); font-weight:300;
  color:var(--accent); line-height:1; margin-bottom:.75rem;
  background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.stat-label {
  font-size:.75rem; font-weight:400; letter-spacing:.15em;
  text-transform:uppercase; color:var(--text-muted);
}

/* ---- 13. Testimonial ---- */
.testimonial { text-align:center; }
.testimonial-quote {
  max-width:680px; margin:3rem auto 2rem;
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(1.2rem,2.5vw,1.6rem); font-weight:300; font-style:italic;
  line-height:1.6; color:var(--text-primary);
}
.testimonial-author {
  display:block; font-size:.85rem; font-weight:500; letter-spacing:.1em;
  color:var(--accent); font-style:normal; margin-bottom:.5rem;
}
.testimonial-role { font-size:.75rem; color:var(--text-muted); letter-spacing:.05em; }

/* ---- 14. CTA Section ---- */
.cta-section {
  text-align:center; padding:10rem 3rem;
  background:
    radial-gradient(ellipse at 50% 50%,rgba(201,169,110,.08) 0%,transparent 70%),
    var(--bg-secondary);
}
.cta-title {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(2rem,4vw,3.5rem); font-weight:300; line-height:1.2;
  color:var(--text-primary); margin-bottom:1.5rem;
}
.cta-desc { font-size:1rem; color:var(--text-secondary); max-width:500px; margin:0 auto 3rem; line-height:1.8; }

/* ---- 15. Footer ---- */
.footer { padding:5rem 3rem 3rem; border-top:1px solid var(--border-light); }
.footer-content {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:4rem; max-width:var(--max-w); margin:0 auto 4rem;
}
.footer-logo {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.4rem; font-weight:400; letter-spacing:.2em;
  color:var(--text-primary); margin-bottom:1.5rem;
  display:flex; align-items:center; gap:.5rem;
}
.footer-brand p { font-size:.85rem; color:var(--text-muted); line-height:1.8; max-width:280px; }
.footer-col h4 {
  font-size:.7rem; font-weight:500; letter-spacing:.25em; text-transform:uppercase;
  color:var(--accent); margin-bottom:1.5rem;
}
.footer-col a {
  display:block; font-size:.85rem; color:var(--text-muted);
  margin-bottom:.75rem; transition:color var(--t-fast);
}
.footer-col a:hover { color:var(--text-primary); }
.footer-bottom {
  max-width:var(--max-w); margin:0 auto;
  padding-top:2rem; border-top:1px solid var(--border-light);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
}
.footer-bottom p { font-size:.78rem; color:var(--text-muted); }

/* ---- 16. Page Hero (About / Contact inner pages) ---- */
.page-hero {
  min-height:50vh; display:flex; align-items:center; justify-content:center;
  padding:calc(var(--nav-h) + 4rem) 3rem 4rem; text-align:center;
  background:
    radial-gradient(ellipse at 50% 30%,rgba(201,169,110,.06) 0%,transparent 60%),
    var(--bg-primary);
}
.page-hero-content { max-width:700px; }
.page-hero-title {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(2rem,5vw,4rem); font-weight:300; line-height:1.1;
  color:var(--text-primary); margin:1.5rem 0;
}
.page-hero-desc { font-size:1rem; color:var(--text-secondary); line-height:1.8; max-width:550px; margin:0 auto; }

/* ---- 17. About Page ---- */
.about-narrative { padding:var(--sec-pad) 3rem; }
.about-narrative-content {
  display:grid; grid-template-columns:1fr 1fr; gap:6rem;
  max-width:var(--max-w); margin:0 auto; align-items:center;
}
.about-narrative-text p {
  font-size:.95rem; color:var(--text-secondary); line-height:1.9; margin-bottom:1.5rem;
}
.drop-cap::first-letter {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:3.5em; float:left; line-height:.75; margin:0 .1em -.1em 0;
  color:var(--accent); font-weight:300;
}
.about-image-block { position:relative; height:400px; }
.about-image-placeholder {
  width:100%; height:100%; background:var(--bg-card);
  border:1px solid var(--border-light); border-radius:var(--r-lg);
}
.about-image-overlay {
  position:absolute; top:2rem; right:-2rem; width:100%; height:100%;
  border:1px solid var(--border); border-radius:var(--r-lg);
  pointer-events:none;
}

.about-values { background:var(--bg-secondary); }
.values-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:2rem;
  max-width:var(--max-w); margin:0 auto;
}
.value-item {
  padding:3rem; border:1px solid var(--border-light);
  border-radius:var(--r-lg); background:var(--bg-card);
  transition:all var(--t-fast);
}
.value-item:hover { border-color:var(--border); }
.value-item h3 {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.3rem; font-weight:400; color:var(--text-primary);
  margin-bottom:1rem;
}
.value-item p { font-size:.9rem; color:var(--text-secondary); line-height:1.8; }

/* ---- 18. Contact Page ---- */
.contact-section { padding:var(--sec-pad) 3rem; }
.contact-grid {
  display:grid; grid-template-columns:1fr 1.4fr; gap:6rem;
  max-width:var(--max-w); margin:0 auto; align-items:start;
}
.contact-info h3 {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.8rem; font-weight:300; color:var(--text-primary);
  line-height:1.3; margin-bottom:3rem;
}
.contact-detail { margin-bottom:2rem; }
.contact-detail-label {
  font-size:.65rem; font-weight:500; letter-spacing:.25em;
  text-transform:uppercase; color:var(--accent); margin-bottom:.5rem;
}
.contact-detail-value { font-size:.9rem; color:var(--text-secondary); line-height:1.7; }
.contact-detail-value a { color:var(--text-primary); transition:color var(--t-fast); }
.contact-detail-value a:hover { color:var(--accent); }
.contact-whatsapp-btn { margin-top:3rem; }

/* ---- 19. Form ---- */
.contact-form-wrapper { position:relative; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.form-group { margin-bottom:1.5rem; }
.form-label {
  display:block; font-size:.7rem; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--text-muted); margin-bottom:.75rem;
}
.form-input,.form-textarea {
  width:100%; background:var(--bg-input); border:1px solid var(--border-light);
  color:var(--text-primary); padding:1rem 1.25rem; border-radius:var(--r-sm);
  font-family:inherit; font-size:.9rem; transition:all var(--t-fast);
  -webkit-appearance:none; appearance:none;
}
.form-input:focus,.form-textarea:focus {
  outline:none; border-color:var(--accent); background:var(--bg-secondary);
}
.form-input.error { border-color:#e05252; }
.form-input::placeholder,.form-textarea::placeholder { color:var(--text-muted); opacity:.6; }
.form-textarea { resize:vertical; min-height:140px; }

select.form-input { cursor:pointer; }
select.form-input option { background:var(--bg-secondary); color:var(--text-primary); }

/* Radio options */
.contact-method-options { display:flex; gap:1.5rem; flex-wrap:wrap; }
.radio-option {
  display:flex; align-items:center; gap:.6rem; cursor:pointer;
  font-size:.85rem; color:var(--text-secondary); transition:color var(--t-fast);
}
.radio-option:hover { color:var(--text-primary); }
.radio-option input[type="radio"] { accent-color:var(--accent); width:16px; height:16px; cursor:pointer; }
.radio-label { font-size:.85rem; }

/* Submit button */
.form-submit {
  width:100%; padding:1.1rem; background:var(--accent); color:var(--bg-primary);
  border:none; border-radius:var(--r-sm); font-family:inherit;
  font-size:.75rem; font-weight:500; letter-spacing:.2em; text-transform:uppercase;
  cursor:pointer; transition:all var(--t-fast); position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center; gap:.75rem;
  margin-top:2rem;
}
.form-submit::before {
  content:''; position:absolute; top:0; left:-100%;
  width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transition:left .5s;
}
.form-submit:hover::before { left:100%; }
.form-submit:hover { background:var(--accent-light); }
.form-submit:disabled { opacity:.7; cursor:not-allowed; }

.btn-loading { display:flex; align-items:center; gap:.5rem; }
.btn-loading svg { animation:spin 1.5s linear infinite; }

/* ---- 20. Form States (Success / Error) ---- */
.form-success,.form-error {
  display:none; text-align:center; padding:4rem 2rem;
  border:1px solid var(--border-light); border-radius:var(--r-lg);
  background:var(--bg-card);
}
.form-success.visible,.form-error.visible { display:block; }

.success-icon,.error-icon {
  width:72px; height:72px; border-radius:50%; margin:0 auto 2rem;
  display:flex; align-items:center; justify-content:center;
}
.success-icon { background:rgba(201,169,110,.1); color:var(--accent); }
.error-icon   { background:rgba(224,82,82,.1);   color:#e05252; }

.form-success h4,.form-error h4 {
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.5rem; font-weight:400; color:var(--text-primary); margin-bottom:1rem;
}
.form-success p,.form-error p { font-size:.9rem; color:var(--text-secondary); line-height:1.7; }

/* ---- 21. WhatsApp Float Button ---- */
.whatsapp-float {
  position:fixed; bottom:2rem; right:2rem;
  width:52px; height:52px;
  background:#25D366; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:white; z-index:800;
  box-shadow:0 4px 20px rgba(37,211,102,.35);
  transition:all .3s ease;
}
.whatsapp-float:hover {
  transform:scale(1.1) translateY(-2px);
  box-shadow:0 8px 30px rgba(37,211,102,.45);
}
.whatsapp-float svg { flex-shrink:0; }

/* WhatsApp tooltip */
.whatsapp-float::before {
  content:'Chat with us';
  position:absolute; right:calc(100% + .75rem);
  background:var(--bg-tertiary); color:var(--text-primary);
  font-size:.7rem; font-weight:500; letter-spacing:.05em;
  white-space:nowrap; padding:.4rem .9rem; border-radius:var(--r-sm);
  border:1px solid var(--border-light);
  opacity:0; transform:translateX(6px);
  transition:all .25s ease; pointer-events:none;
}
.whatsapp-float:hover::before { opacity:1; transform:translateX(0); }

/* ---- 22. Scroll Animations ---- */
[data-animate] {
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);
}
[data-animate].animated {
  opacity:1;
  transform:translateY(0);
}

/* ---- 23. Responsive ---- */
@media (max-width: 1024px) {
  .footer-content { grid-template-columns:1fr 1fr; }
  .contact-grid   { grid-template-columns:1fr; gap:4rem; }
  .about-narrative-content { grid-template-columns:1fr; gap:3rem; }
  .about-image-block { height:280px; }
}

@media (max-width: 768px) {
  :root { --sec-pad:5rem; --nav-h:70px; }

  .nav { padding:0 1.5rem; }
  .nav-links { display:none; }
  .hamburger { display:flex; }

  .section   { padding:var(--sec-pad) 1.5rem; }
  .container { padding:0 1.5rem; }
  .stats     { padding:var(--sec-pad) 1.5rem; }
  .stats-grid { padding:0; }

  .form-row { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr; }
  .domains-grid { grid-template-columns:1fr; }
  .footer-content { grid-template-columns:1fr 1fr; gap:2.5rem; }
  .footer-bottom  { flex-direction:column; text-align:center; }

  .hero { padding:calc(var(--nav-h) + 1rem) 1.5rem 3rem; }
  .cta-section    { padding:6rem 1.5rem; }
  .contact-section { padding:var(--sec-pad) 1.5rem; }
}

@media (max-width: 480px) {
  .footer-content { grid-template-columns:1fr; }
  .hero-actions   { flex-direction:column; align-items:center; }
  .about-narrative-content { gap:2rem; }
  .whatsapp-float::before { display:none; }
}

/* ---- 24. Reduced Motion ---- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
}
