/* =========================================================
   DENDEV — design tokens
   ========================================================= */
:root{
  --ink-950:#0A0E14;
  --ink-900:#10151D;
  --ink-850:#141a23;
  --ink-800:#1C232E;
  --ink-700:#2A3340;
  --ink-600:#3A4452;

  --paper:#ECE8DF;
  --slate-300:#A7AEB8;
  --slate-400:#838B97;

  --dende-500:#E08A2C;
  --dende-400:#F2A94E;
  --dende-900:#2E1E10;

  --teal-400:#4FB8A8;

  --font-display:'Space Grotesk', sans-serif;
  --font-body:'IBM Plex Sans', sans-serif;
  --font-mono:'IBM Plex Mono', monospace;

  --radius-lg:16px;
  --radius-md:10px;
  --radius-sm:6px;

  --border:1px solid var(--ink-700);
  --wrap:1180px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* =========================================================
   Reset
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}

body{
  background:var(--ink-950);
  color:var(--paper);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  background-image:
    linear-gradient(var(--ink-800) 1px, transparent 1px),
    linear-gradient(90deg, var(--ink-800) 1px, transparent 1px);
  background-size:64px 64px;
  background-position:center top;
  background-attachment:fixed;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important;}
}

:focus-visible{
  outline:2px solid var(--dende-400);
  outline-offset:3px;
  border-radius:4px;
}

.wrap{
  max-width:var(--wrap);
  margin-inline:auto;
  padding-inline:20px;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:0;
  background:var(--dende-500);
  color:var(--ink-950);
  padding:10px 16px;
  z-index:200;
  font-family:var(--font-mono);
  font-size:.85rem;
}
.skip-link:focus{left:12px;top:12px;}

/* =========================================================
   Type scale
   ========================================================= */
h1,h2,h3{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:-0.01em;
  line-height:1.1;
}
h1{font-size:clamp(2.1rem, 5.4vw, 3.6rem); font-weight:700;}
h2{font-size:clamp(1.6rem, 3.6vw, 2.5rem);}
h3{font-size:1.3rem;}

p{color:var(--slate-300);}

.eyebrow{
  font-family:var(--font-mono);
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--dende-400);
  margin-bottom:14px;
}

.section-sub{
  margin-top:10px;
  max-width:46ch;
}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:13px 22px;
  border-radius:var(--radius-md);
  font-weight:500;
  font-size:.95rem;
  transition:transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}
.btn-primary{
  background:var(--dende-500);
  color:var(--ink-950);
}
.btn-primary:hover{background:var(--dende-400); transform:translateY(-2px);}
.btn-ghost{
  border:1px solid var(--ink-700);
  color:var(--paper);
}
.btn-ghost:hover{border-color:var(--dende-500); transform:translateY(-2px);}

/* =========================================================
   Header
   ========================================================= */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(10,14,20,.82);
  backdrop-filter:blur(10px);
  border-bottom:var(--border);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:72px;
}
.logo{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.15rem;
  letter-spacing:.02em;
}
.logo-mark{
  width:26px;
  height:26px;
}
.logo-mark polygon{
  fill:var(--ink-900);
  stroke:var(--dende-500);
  stroke-width:2;
}
.logo-mark circle{fill:var(--dende-500);}

.main-nav{
  display:flex;
  gap:32px;
}
.main-nav a{
  font-size:.95rem;
  color:var(--slate-300);
  transition:color .15s var(--ease);
}
.main-nav a:hover{color:var(--paper);}

.nav-toggle{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:36px;
  height:36px;
}
.nav-toggle span{
  display:block;
  height:2px;
  width:100%;
  background:var(--paper);
  transition:transform .25s var(--ease), opacity .25s var(--ease);
}
.nav-toggle{display:none;}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  padding-block:64px 80px;
  position:relative;
}
.hero-grid{
  display:grid;
  gap:48px;
}
.hero-sub{
  margin-top:18px;
  max-width:50ch;
  font-size:1.05rem;
}
.hero-actions{
  margin-top:32px;
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}

/* status panel — signature element */
.status-panel{
  background:var(--ink-900);
  border:var(--border);
  border-radius:var(--radius-lg);
  padding:22px;
  font-family:var(--font-mono);
  box-shadow:0 30px 60px -30px rgba(0,0,0,.6);
}
.status-head{
  display:flex;
  align-items:center;
  gap:10px;
  padding-bottom:16px;
  margin-bottom:16px;
  border-bottom:var(--border);
}
.status-pulse{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--teal-400);
  box-shadow:0 0 0 0 rgba(79,184,168,.6);
  animation:pulse 2.4s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(79,184,168,.55);}
  70%{box-shadow:0 0 0 8px rgba(79,184,168,0);}
  100%{box-shadow:0 0 0 0 rgba(79,184,168,0);}
}
.status-title{
  font-size:.72rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--slate-300);
  flex:1;
}
.status-clock{
  font-size:.78rem;
  color:var(--slate-400);
}
.status-list{display:flex; flex-direction:column; gap:14px;}
.status-list li{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.86rem;
}
.status-dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--dende-500);
  flex-shrink:0;
}
.status-name{color:var(--paper); font-weight:500;}
.status-tag{
  color:var(--slate-400);
  font-size:.78rem;
}
.status-state{
  margin-left:auto;
  color:var(--teal-400);
  font-size:.76rem;
}
.status-foot{
  margin-top:18px;
  padding-top:16px;
  border-top:var(--border);
  font-size:.72rem;
  color:var(--slate-400);
}

/* =========================================================
   Sobre
   ========================================================= */
.sobre{
  padding-block:72px;
  border-top:var(--border);
}
.sobre-grid{
  display:grid;
  gap:32px;
}
.sobre p + p{margin-top:14px;}
.tag-list{
  margin-top:28px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.tag-list li{
  font-family:var(--font-mono);
  font-size:.78rem;
  color:var(--slate-300);
  border:var(--border);
  border-radius:999px;
  padding:8px 14px;
}

/* =========================================================
   Portfolio
   ========================================================= */
.portfolio{
  padding-block:72px;
  border-top:var(--border);
}
.section-head{margin-bottom:40px;}

.card-grid{
  display:grid;
  gap:22px;
  grid-template-columns:1fr;
}
.card{
  background:var(--ink-900);
  border:var(--border);
  border-radius:var(--radius-lg);
  padding:28px;
  display:flex;
  flex-direction:column;
  transition:transform .22s var(--ease), border-color .22s var(--ease), box-shadow .22s var(--ease);
}
.card:hover{
  transform:translateY(-4px);
  border-color:var(--dende-500);
  box-shadow:0 24px 48px -28px rgba(224,138,44,.25);
}
.card-top{margin-bottom:18px;}
.card-status{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--teal-400);
  border:1px solid var(--ink-700);
  border-radius:999px;
  padding:5px 11px;
}
.card h3{margin-bottom:12px;}
.card-desc{font-size:.94rem; flex:1;}
.feature-list{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.feature-list li{
  font-size:.86rem;
  color:var(--slate-300);
  padding-left:18px;
  position:relative;
}
.feature-list li::before{
  content:'›';
  position:absolute;
  left:0;
  color:var(--dende-500);
  font-family:var(--font-mono);
}
.card-cta{
  margin-top:24px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:500;
  font-size:.92rem;
  color:var(--dende-400);
  transition:gap .18s var(--ease);
}
.card-cta:hover{gap:13px;}

/* =========================================================
   Visão futura
   ========================================================= */
.futuro{
  position:relative;
  padding-block:72px;
  border-top:var(--border);
  background:var(--ink-900);
  overflow:hidden;
}
.pipeline{
  position:absolute;
  top:0; left:0;
  width:100%;
  opacity:.6;
}
.pipeline svg{width:100%; height:2px;}
.pipeline line{
  stroke:var(--dende-500);
  stroke-width:2;
  stroke-dasharray:10 8;
  animation:dash 6s linear infinite;
}
@keyframes dash{to{stroke-dashoffset:-180;}}

.futuro h2{margin-bottom:16px;}
.futuro p{max-width:58ch;}

/* =========================================================
   Contato
   ========================================================= */
.contato{
  padding-block:72px;
  border-top:var(--border);
}
.contato-grid{
  display:grid;
  gap:32px;
}
.contato-links{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.contato-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  border:var(--border);
  border-radius:var(--radius-md);
  padding:18px 20px;
  transition:border-color .18s var(--ease), transform .18s var(--ease);
}
.contato-item:hover{border-color:var(--dende-500); transform:translateY(-2px);}
.contato-label{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--slate-400);
}
.contato-value{
  font-family:var(--font-mono);
  font-size:.92rem;
  color:var(--paper);
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  border-top:var(--border);
  padding-block:32px;
}
.footer-inner{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:10px;
}
.footer-brand .logo-mark{width:22px; height:22px;}
.footer-name{
  display:block;
  font-family:var(--font-display);
  font-weight:600;
  font-size:.95rem;
}
.footer-origin{
  display:block;
  font-family:var(--font-mono);
  font-size:.7rem;
  color:var(--slate-400);
}
.footer-nav{display:flex; gap:22px;}
.footer-nav a{font-size:.88rem; color:var(--slate-300);}
.footer-nav a:hover{color:var(--paper);}
.footer-copy{
  font-size:.8rem;
  color:var(--slate-400);
  width:100%;
  order:3;
  margin-top:8px;
}

/* =========================================================
   Scroll reveal
   ========================================================= */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:760px){
  .main-nav{
    position:absolute;
    top:72px;
    left:0;
    right:0;
    background:var(--ink-900);
    border-bottom:var(--border);
    flex-direction:column;
    gap:0;
    max-height:0;
    overflow:hidden;
    transition:max-height .3s var(--ease);
  }
  .main-nav.is-open{max-height:240px;}
  .main-nav a{
    padding:16px 20px;
    border-top:var(--border);
  }
  .nav-toggle{display:flex;}
  .footer-copy{order:0;}
}

@media (min-width:561px){
  .card-grid{grid-template-columns:repeat(2,1fr);}
}

@media (min-width:761px){
  .sobre-grid{grid-template-columns:1fr 1.3fr;}
  .contato-grid{grid-template-columns:1.2fr 1fr; align-items:center;}
}

@media (min-width:980px){
  .hero-grid{grid-template-columns:1.15fr .85fr; align-items:center;}
  .card-grid{grid-template-columns:repeat(3,1fr);}
}
