/*
Theme Name: Samantha
Theme URI: https://example.com/samantha
Author: Elson Oliveira
Author URI: https://openai.com
Description: Tema WordPress inspirado no layout enviado por Elson para o site Samantha Iris.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: samantha
*/

:root{
  --bg:#f5f3f5;
  --bg-soft:#fbf9fb;
  --text:#13111a;
  --muted:#66606d;
  --pink:#ef3b9c;
  --pink-strong:#ff4aa9;
  --navy:#081128;
  --navy-2:#101a32;
  --white:#fff;
  --border:#ebe4ea;
  --shadow:0 18px 40px rgba(13,14,26,.08);
  --radius:24px;
  --radius-sm:16px;
  --container:1200px;
  --header-height:64px;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  margin:0;
  padding:0;
}

body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:var(--bg);
  color:var(--text);
  padding-top:var(--header-height);
}

body.home,
body.front-page{
  padding-top:var(--header-height);
  margin:0 !important;
}

.front-page-main,
.front-page-main article,
.front-page-main .entry-content.page-builder-content{
  margin:0;
  padding:0;
}

.front-page-main .entry-content.page-builder-content > :first-child{
  margin-top:0 !important;
}

/* Keep fixed header offset on internal pages, but glue home sections to the menu */
.home .front-page-main,
.front-page .front-page-main{
  margin-top:0;
}

.home body{
  padding-top:0;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}

.container{
  width:min(calc(100% - 48px),var(--container));
  margin:0 auto;
}

.section{padding:76px 0}

.section-header{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:28px;
}

.kicker{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--pink);
  font-weight:700;
  margin-bottom:8px;
}

.section-title{
  font-size:clamp(28px,3vw,44px);
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.03em;
  margin:0;
}

.section-link{
  font-size:14px;
  color:#55506b;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 24px;
  border-radius:999px;
  font-weight:700;
  border:1px solid transparent;
  transition:.2s ease;
  cursor:pointer;
}

.btn:hover{transform:translateY(-1px)}

.btn-primary{
  background:linear-gradient(135deg,var(--pink),#ff65b7);
  color:#fff;
  box-shadow:0 12px 30px rgba(239,59,156,.26);
}

.btn-dark{
  background:#121521;
  color:#fff;
  border-color:rgba(255,255,255,.16);
}

.btn-outline{
  background:#fff;
  border-color:#d8d2db;
  color:#0f1020;
}

/* HEADER */

.site-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:100;
  background:#000;
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 12px 28px rgba(0,0,0,.22);
  margin:0;
  padding:0;
  transition:background .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.site-header.is-scrolled{
  background:#000;
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 12px 28px rgba(0,0,0,.22);
}

body.admin-bar .site-header{
  top:32px;
}

@media screen and (max-width: 782px){
  body.admin-bar .site-header{
    top:46px;
  }
}

.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-height:64px;
  padding:0 18px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  color:var(--text);
  letter-spacing:-.03em;
}

.brand-text{
  font-size:26px;
  font-weight:900;
  letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--pink),#ff65b7);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.brand-mark{
  display:none;
}

.primary-nav ul{
  display:flex;
  gap:28px;
  list-style:none;
  padding:0;
  margin:0;
}

.primary-nav a{
  font-size:14px;
  color:#fff;
  font-weight:700;
}

.primary-nav .current-menu-item a,
.primary-nav a:hover{
  color:var(--pink);
}

.menu-toggle{
  display:none;
  color:var(--text);
  background:#fff;
  border:1px solid rgba(8,17,40,.14);
}

.header-cta{
  display:flex;
  align-items:center;
  gap:14px;
}

.header-cta .btn{
  color:#fff;
}

.header-social{
  display:flex;
  align-items:center;
  gap:12px;
}

.social-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;
  height:24px;
  color:#fff;
  transition:opacity .25s ease, transform .25s ease;
}

.social-link:hover{
  opacity:.8;
  transform:scale(1.1);
}

.social-link svg{
  width:100%;
  height:100%;
}

.theme-toggle{
  width:34px;
  height:34px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#fff;
  border:1px solid var(--border);
}

.hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(90deg,#24162a 0%,#2d1b2d 38%,#cfa18f 100%);
  height:680px !important;
  min-height:680px !important;
  max-height:680px !important;
  margin:0 !important;
  padding:0 !important;
}

.hero::before{
  display:none;
  content:none;
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.14);
  z-index:1;
}

.hero-slider{
  position:relative;
  height:calc(100vh - var(--header-height)) !important;
  min-height:760px !important;
  max-height:none !important;
  overflow:hidden;
  margin:0 !important;
  margin-top:-20px !important;
  padding:0 !important;
}

.hero-slider .hero-slides{
  position:relative;
  height:calc(100vh - var(--header-height)) !important;
  min-height:760px !important;
  max-height:none !important;
  overflow:hidden;
}

.hero-slider .hero-slides > .hero-slide{
  position:absolute !important;
  inset:0;
  display:block !important;
  width:100%;
  height:calc(100vh - var(--header-height)) !important;
  min-height:760px !important;
  max-height:none !important;
  background-position:center center;
  background-size:cover;
  background-repeat:no-repeat;
  overflow:hidden;
  opacity:0;
  visibility:hidden;
  transform:translateX(7%);
  transition:transform .55s ease, opacity .55s ease, visibility .55s ease;
  z-index:1;
}

.hero-slider .hero-slides > .hero-slide.is-prev{
  transform:translateX(-7%);
}

.hero-slider .hero-slides > .hero-slide.is-active{
  opacity:1;
  visibility:visible;
  transform:translateX(0);
  z-index:2;
}

.hero-overlay{
  position:absolute;
  inset:0;
  background:#000;
  z-index:1;
}

.hero-inner{
  position:relative;
  z-index:2;
}

.hero-nav{
  position:absolute;
  inset:0;
  z-index:6;
  pointer-events:none;
}

.hero-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:52px;
  height:52px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.82);
  background:rgba(9,12,22,.52);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 12px 26px rgba(0,0,0,.25);
  pointer-events:auto;
  transition:all .22s ease;
}

.hero-arrow-prev{
  left:24px;
}

.hero-arrow-next{
  right:24px;
}

.hero-arrow:hover{
  background:rgba(239,59,156,.88);
  border-color:rgba(255,255,255,.96);
  transform:translateY(-50%) scale(1.04);
}

.hero-dots{
  position:absolute;
  left:50%;
  bottom:24px;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  gap:10px;
  pointer-events:auto;
}

.hero-dot{
  width:11px;
  height:11px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,.55);
  padding:0;
  cursor:pointer;
  transition:all .2s ease;
}

.hero-dot.is-active{
  background:#fff;
  transform:scale(1.22);
}

.hero-portrait{
  position:absolute;
  right:0;
  bottom:0;
  top:0;
  width:min(52vw,690px);
  z-index:0;
  background:url('assets/images/hero-portrait.png') center bottom/contain no-repeat;
  mix-blend-mode:normal;
  opacity:1;
}

.hero .container{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  height:100%;
  min-height:0;
  padding-top:72px;
  padding-bottom:0;
  padding-left:72px;
  padding-right:24px;
}

.hero-content{
  max-width:560px;
  color:#fff;
  padding:32px 0 42px;
  margin:0;
}

.hero-badge{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin:0 0 24px;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}

.hero-title{
  font-size:clamp(44px,7vw,84px);
  line-height:.96;
  letter-spacing:-.05em;
  margin:0 0 20px;
  font-weight:900;
  text-shadow:0 4px 12px rgba(0,0,0,.25);
}

.hero-title .accent{
  color:var(--pink-strong);
  display:block;
  font-style:italic;
}

.hero-text{
  max-width:500px;
  color:rgba(255,255,255,.92);
  font-size:18px;
  line-height:1.6;
  margin:0 0 28px;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin:0 0 26px;
}

.hero-quote{
  max-width:310px;
  padding:18px 18px;
  border-radius:22px;
  background:rgba(15,12,25,.48);
  font-size:14px;
  line-height:1.5;
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}

.hero-subtitle{
  color:rgba(255,255,255,.8);
  font-size:16px;
  line-height:1.5;
  margin:0 0 16px;
  font-weight:500;
}

.hero-quote cite{
  display:block;
  color:rgba(255,255,255,.6);
  font-size:12px;
  font-style:normal;
  margin-top:4px;
  text-transform:uppercase;
  letter-spacing:.1em;
}

/* Hero text color variations */
.hero-slide.text-dark .hero-content{
  color:var(--text);
}

.hero-slide.text-dark .hero-badge{
  background:rgba(0,0,0,.1);
  color:var(--text);
}

.hero-slide.text-dark .hero-title{
  text-shadow:0 2px 8px rgba(255,255,255,.8);
  color:var(--text);
}

.hero-slide.text-dark .hero-subtitle{
  color:rgba(19,17,26,.8);
}

.hero-slide.text-dark .hero-text{
  color:rgba(19,17,26,.9);
}

.hero-slide.text-dark .hero-quote{
  background:rgba(255,255,255,.9);
  border-color:rgba(0,0,0,.1);
  color:var(--text);
}

.hero-slide.text-dark .hero-quote strong{
  color:var(--pink);
}

.hero-slide.text-dark .hero-quote cite{
  color:rgba(19,17,26,.6);
}

/* Hero layout variations */
.hero-slide.layout-center .hero-inner{
  text-align:center;
}

.hero-slide.layout-center .hero-content{
  margin:0 auto;
}

.hero-slide.layout-center .hero-actions{
  justify-content:center;
}

.hero-slide.layout-right .hero-inner{
  text-align:right;
}

.hero-slide.layout-right .hero-content{
  margin-left:auto;
}

.hero-slide.layout-right .hero-actions{
  justify-content:flex-end;
}

/* Third button style */
.btn-outline{
  background:transparent;
  color:#fff;
  border-color:#fff;
}

.btn-outline:hover{
  background:#fff;
  color:var(--text);
}

.hero-slide.text-dark .btn-outline{
  color:var(--text);
  border-color:var(--text);
}

.hero-slide.text-dark .btn-outline:hover{
  background:var(--text);
  color:#fff;
}

/* ABOUT */

.about-grid{
  display:grid;
  grid-template-columns:minmax(320px,440px) 1.2fr;
  gap:40px;
  align-items:center;
}

.about-gallery{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:24px;
}

.about-card-image{
  background:#ead3c6;
  border-radius:34px;
  box-shadow:var(--shadow);
  overflow:hidden;
  min-height:320px;
}

.about-card-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.about-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.about-copy p{
  color:var(--muted);
  font-size:16px;
  line-height:1.8;
  margin:0 0 14px;
}

.about-more{
  color:var(--pink);
  font-weight:700;
}

/* PROJECTS */

#projetos{
  position:relative;
  padding:92px 0 98px;
  background:
    radial-gradient(1200px 380px at 50% -120px, rgba(239,59,156,.08), transparent 65%),
    linear-gradient(180deg,#f8f6fa 0%, #f3f0f5 100%);
}

#projetos .container{
  width:min(calc(100% - 120px),1320px);
}

#projetos .section-header{
  margin-bottom:38px;
  align-items:flex-end;
  padding:0 6px;
}

#projetos .kicker{
  letter-spacing:.24em;
  color:#e73690;
}

#projetos .section-title{
  font-size:clamp(38px,4.2vw,60px);
  line-height:.95;
}

#projetos .section-link{
  font-weight:700;
  color:#241b33;
  padding:10px 16px;
  border-radius:999px;
  border:1px solid rgba(36,27,51,.14);
  background:#fff;
  box-shadow:0 8px 18px rgba(15,10,22,.06);
  white-space:nowrap;
  transition:all .22s ease;
}

#projetos .section-link:hover{
  border-color:rgba(231,54,144,.35);
  color:#e73690;
  transform:translateY(-1px);
}

.project-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  align-items:stretch;
}

#projetos .project-card{
  background:linear-gradient(180deg,#ffffff 0%, #fcfbff 100%);
  border:1px solid #e6dfeb;
  border-radius:24px;
  padding:30px 28px 24px;
  min-height:300px;
  box-shadow:
    0 20px 44px rgba(19,14,27,.06),
    0 2px 0 rgba(255,255,255,.85) inset;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

#projetos .project-card:hover{
  transform:translateY(-6px);
  border-color:rgba(231,54,144,.28);
  box-shadow:
    0 24px 56px rgba(19,14,27,.11),
    0 2px 0 rgba(255,255,255,.9) inset;
}

#projetos .project-card-link{
  display:flex !important;
  flex-direction:column;
  align-items:flex-start;
  min-height:100%;
  color:inherit;
  text-decoration:none;
}

#projetos .project-icon{
  width:52px;
  height:52px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#ffe3f2 0%, #ffd4ec 100%);
  color:#e73690;
  font-weight:900;
  margin-bottom:20px;
  box-shadow:0 10px 24px rgba(231,54,144,.2);
}

#projetos .project-card h3{
  font-size:22px;
  letter-spacing:-.04em;
  line-height:1.08;
  margin:0 0 14px;
}

#projetos .project-card p{
  color:#4f4760;
  line-height:1.72;
  font-size:16px;
  margin:0 0 20px;
}

#projetos .project-card .pill{
  margin-top:auto;
  padding:7px 14px;
  font-size:11px;
  letter-spacing:.1em;
}

.pill{
  display:inline-flex;
  padding:6px 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.pill.green{background:#e2f7e8;color:#2b8a57}
.pill.blue{background:#e0ecff;color:#3c66d6}
.pill.yellow{background:#fff1c7;color:#a98712}

/* NEWS */

#noticias{
  position:relative;
  padding:92px 0 96px;
  background:
    radial-gradient(900px 320px at 86% -120px, rgba(49,85,176,.1), transparent 68%),
    linear-gradient(180deg,#f8f7fb 0%, #f1eef5 100%);
}

#noticias .container{
  width:min(calc(100% - 112px),1320px);
}

#noticias .section-header{
  margin-bottom:34px;
  padding:0 4px;
}

#noticias .kicker{
  letter-spacing:.24em;
  color:#e73690;
}

#noticias .section-title{
  font-size:clamp(40px,4.4vw,64px);
  line-height:.95;
}

.news-grid{
  display:grid;
  grid-template-columns:minmax(0,1.42fr) minmax(0,.88fr);
  gap:28px;
  align-items:stretch;
}

.news-featured{
  background:linear-gradient(180deg,#ffffff 0%, #fbfaff 100%);
  border:1px solid #e8e1ef;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 20px 48px rgba(16,13,28,.08);
  display:flex;
  flex-direction:column;
}

.news-featured .thumb{
  display:block;
  width:100%;
  overflow:hidden;
  background:#ece8f2;
}

.news-featured .thumb img{
  width:100%;
  height:420px;
  object-fit:cover;
  transition:transform .36s ease;
}

.news-featured:hover .thumb img{
  transform:scale(1.03);
}

.news-featured-body{
  padding:40px 36px 44px;
}

.news-category-pill{
  display:inline-block;
  padding:8px 16px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  margin-bottom:0;
}

.news-meta-row,
.news-item-meta{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  color:#878296;
  font-size:13px;
  margin-bottom:18px;
}

.news-date,
.news-views,
.news-comments{
  display:inline-flex;
  align-items:center;
  gap:7px;
}

.news-featured h3{
  font-size:43px;
  letter-spacing:-.04em;
  line-height:1.02;
  margin:0 0 18px;
}

.news-featured h3 a{
  color:#110f1d;
}

.news-featured p{
  color:#4f4861;
  font-size:17px;
  line-height:1.8;
  margin:0;
  letter-spacing:.3px;
}

.news-list{
  display:flex;
  flex-direction:column;
  gap:20px;
}

.news-item{
  display:grid;
  grid-template-columns:96px 1fr;
  gap:20px;
  align-items:start;
  padding:22px;
  background:#fff;
  border:1px solid #e7e0ed;
  border-radius:22px;
  box-shadow:0 12px 28px rgba(17,13,28,.06);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.news-item:hover{
  transform:translateY(-3px);
  border-color:rgba(231,54,144,.22);
  box-shadow:0 16px 36px rgba(17,13,28,.1);
}

.news-item-thumb{
  width:96px;
  height:96px;
  border-radius:20px;
  background:#ece8f2;
  overflow:hidden;
  box-shadow:0 10px 24px rgba(17,13,28,.12);
}

.news-item-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.news-item-content{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.news-item .cat{
  display:none;
}

.news-item h4{
  font-size:18px;
  line-height:1.26;
  letter-spacing:-.02em;
  margin:0;
}

.news-item h4 a{
  color:#141123;
}

.news-item .meta{
  display:none;
}

.news-more{
  margin-top:22px;
  display:flex;
  justify-content:flex-end;
}

.news-more .btn{
  min-width:232px;
}

/* NEWS ARCHIVE PAGE */

.news-archive-main{
  padding:22px 0 74px;
}

.news-archive-section{
  position:relative;
}

.news-archive-container{
  width:min(calc(100% - 112px),1280px);
}

.news-archive-header{
  margin-bottom:26px;
}

.news-archive-title{
  margin:0 0 10px;
  font-size:clamp(40px,4.4vw,64px);
  letter-spacing:-.04em;
  line-height:.95;
}

.news-archive-header p{
  margin:0;
  max-width:760px;
  color:#544d67;
  font-size:17px;
  line-height:1.65;
}

.news-archive-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;
}

.news-archive-card{
  background:linear-gradient(180deg,#ffffff 0%, #fbfaff 100%);
  border:1px solid #e7e0ed;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 16px 36px rgba(17,13,28,.06);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  min-height:100%;
}

.news-archive-card:hover{
  transform:translateY(-4px);
  border-color:rgba(231,54,144,.25);
  box-shadow:0 22px 46px rgba(17,13,28,.11);
}

.news-archive-thumb{
  display:block;
  width:100%;
  background:#ece8f2;
  overflow:hidden;
}

.news-archive-thumb img,
.news-archive-thumb-fallback{
  width:100%;
  aspect-ratio:16/10;
  display:block;
}

.news-archive-thumb img{
  object-fit:cover;
  transition:transform .35s ease;
}

.news-archive-card:hover .news-archive-thumb img{
  transform:scale(1.03);
}

.news-archive-thumb-fallback{
  background:
    radial-gradient(220px 120px at 76% 12%, rgba(239,59,156,.24), transparent 70%),
    linear-gradient(135deg,#efe9f5 0%, #e6deef 100%);
}

.news-archive-card-body{
  padding:16px 16px 18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.news-archive-card-title{
  margin:0;
  font-size:24px;
  line-height:1.24;
  letter-spacing:-.02em;
}

.news-archive-card-title a{
  color:#131027;
  text-decoration:none;
}

.news-archive-card-body p{
  margin:0;
  color:#575067;
  line-height:1.64;
}

.news-archive-empty{
  color:#4f4861;
}

.news-archive-main .navigation.pagination{
  margin-top:28px;
}

.news-archive-main .nav-links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.news-archive-main .page-numbers{
  min-width:42px;
  height:42px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid #e0d8ea;
  background:#fff;
  color:#2d2540;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:700;
  transition:all .2s ease;
}

.news-archive-main .page-numbers.current,
.news-archive-main .page-numbers:hover{
  background:#ef3b9c;
  color:#fff;
  border-color:#ef3b9c;
}

/* IDEAS */

#ideias{
  position:relative;
  padding:0;
  background:
    radial-gradient(900px 280px at 18% -110px, rgba(255,255,255,.26), transparent 62%),
    linear-gradient(145deg,#f148ab 0%, #e63392 56%, #cf2b82 100%);
}

#ideias .container{
  width:min(calc(100% - 112px),1260px);
}

#ideias .idea-box{
  position:relative;
  color:#fff;
  border-radius:34px;
  padding:58px 34px 38px;
  border:none;
  background:transparent;
  box-shadow:none;
  overflow:hidden;
}

#ideias .idea-box::before{
  content:"";
  position:absolute;
  inset:-30% -20% auto auto;
  width:420px;
  height:420px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.22) 0%, rgba(255,255,255,0) 68%);
  pointer-events:none;
}

#ideias .idea-box h2{
  font-size:clamp(40px,5.4vw,70px);
  letter-spacing:-.05em;
  line-height:.93;
  text-align:center;
  margin:0 0 12px;
}

#ideias .idea-box p{
  text-align:center;
  max-width:820px;
  margin:0 auto 34px;
  color:rgba(255,255,255,.92);
  font-size:18px;
  line-height:1.6;
}

#ideias .idea-form{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}

#ideias .field-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}

#ideias .field-group label{
  font-size:12px;
  font-weight:800;
  letter-spacing:.11em;
  text-transform:uppercase;
  color:#fff;
}

#ideias .field-group input,
#ideias .field-group select,
#ideias .field-group textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.35);
  border-radius:18px;
  padding:17px 18px;
  background:rgba(255,255,255,.94);
  color:#171522;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

#ideias .field-group input{
  border-radius:999px;
}

#ideias .field-group input:focus,
#ideias .field-group select:focus,
#ideias .field-group textarea:focus{
  border-color:#fff;
  background:#fff;
  box-shadow:0 0 0 4px rgba(255,255,255,.26);
}

#ideias .field-group select{
  border-radius:999px;
  appearance:none;
  -webkit-appearance:none;
  background-image:linear-gradient(45deg, transparent 50%, #606075 50%), linear-gradient(135deg, #606075 50%, transparent 50%);
  background-position:calc(100% - 22px) calc(50% - 3px), calc(100% - 16px) calc(50% - 3px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
  padding-right:44px;
}

#ideias .field-group textarea{
  border-radius:20px;
  min-height:142px;
  resize:vertical;
}

#ideias .field-span-2{grid-column:1/-1}

#ideias .idea-actions{
  display:flex;
  justify-content:center;
  margin-top:20px;
}

#ideias .idea-actions .btn{
  min-width:286px;
  height:54px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.48);
  background:linear-gradient(135deg,#0a1630 0%, #131d38 100%);
  color:#fff;
  box-shadow:0 14px 28px rgba(9,13,30,.35);
}

#ideias .idea-actions .btn:hover{
  transform:translateY(-1px) scale(1.01);
}

#ideias .samantha-form-response{
  margin-top:2px;
  font-weight:600;
  text-align:center;
  min-height:24px;
  color:rgba(255,255,255,.95);
}

.samantha-form-response.is-success{
  color:#0f8c4a !important;
}

.samantha-form-response.is-error{
  color:#c1345f !important;
}

/* CONTACT PAGE */

.contact-page-main{
  padding:34px 0 76px;
}

.contact-page-container{
  width:min(calc(100% - 112px),1240px);
}

.contact-page-intro{
  margin-bottom:24px;
}

.contact-page-title{
  margin:0 0 12px;
  font-size:clamp(38px,4.4vw,64px);
  line-height:.94;
  letter-spacing:-.04em;
}

.contact-page-intro p{
  margin:0;
  max-width:820px;
  color:#4c4660;
  font-size:18px;
  line-height:1.65;
}

.contact-page-grid{
  display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(0,1.4fr);
  gap:26px;
  align-items:start;
}

.contact-info-panel{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.contact-info-card,
.contact-social-card,
.contact-form-panel{
  background:#fff;
  border:1px solid #e7e1ee;
  border-radius:24px;
  box-shadow:0 18px 40px rgba(15,12,25,.06);
}

.contact-info-card{
  padding:24px 22px;
}

.contact-info-card h2{
  margin:0 0 12px;
  font-size:30px;
}

.contact-info-card p{
  margin:0 0 10px;
  color:#2a2537;
  line-height:1.6;
}

.contact-info-card p:last-child{
  margin-bottom:0;
}

.contact-info-card a{
  color:#201a31;
}

.contact-social-card{
  padding:20px 18px;
}

.contact-social-card h3{
  margin:0 0 12px;
  font-size:30px;
}

.contact-social-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.contact-social-link{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid #e5ddee;
  border-radius:14px;
  background:#fff;
  color:#261f38;
  font-weight:600;
  text-decoration:none;
  transition:all .2s ease;
}

.contact-social-link:hover{
  border-color:rgba(231,54,144,.32);
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(231,54,144,.12);
}

.contact-social-icon{
  width:30px;
  height:30px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#f148ab 0%, #df2f8e 100%);
  color:#fff;
  font-size:11px;
  font-weight:800;
  letter-spacing:.04em;
}

.contact-form-panel{
  padding:30px 28px 26px;
}

.contact-form-panel h2{
  margin:0 0 8px;
  font-size:36px;
  letter-spacing:-.03em;
}

.contact-form-subtitle{
  margin:0 0 18px;
  color:#5e5871;
}

.contact-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

.contact-form-grid .field-span-2{
  grid-column:1/-1;
}

.contact-form-grid .field-group{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.contact-form-grid .field-group label{
  color:#2f2940;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:800;
}

.contact-form-grid .field-group input,
.contact-form-grid .field-group textarea{
  width:100%;
  border:1px solid #dcd3e7;
  border-radius:14px;
  background:#fff;
  color:#1c1728;
  padding:14px 14px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.contact-form-grid .field-group input:focus,
.contact-form-grid .field-group textarea:focus{
  border-color:#e73690;
  box-shadow:0 0 0 4px rgba(231,54,144,.12);
}

.contact-form-grid .field-group textarea{
  min-height:130px;
  resize:vertical;
}

.contact-submit-row{
  margin-top:6px;
  display:flex;
  justify-content:flex-start;
}

.contact-submit-row .btn{
  min-width:180px;
  padding:14px 24px;
  height:auto;
  border-radius:999px;
}

/* PROFILE PAGE */

.profile-page-main{
  padding:24px 0 78px;
}

.profile-container{
  width:min(calc(100% - 112px),1240px);
}

.profile-hero-section{
  position:relative;
}

.profile-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:28px;
  align-items:stretch;
}

.profile-photo-wrap{
  border-radius:30px;
  overflow:hidden;
  border:1px solid #e7dfee;
  box-shadow:0 22px 52px rgba(15,12,25,.12);
  min-height:580px;
  background:#ece8f2;
}

.profile-photo-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.profile-hero-content{
  background:linear-gradient(180deg,#ffffff 0%, #fbfaff 100%);
  border:1px solid #e7dfee;
  border-radius:30px;
  padding:30px 28px 26px;
  box-shadow:0 16px 38px rgba(15,12,25,.07);
}

.profile-title{
  margin:0 0 8px;
  font-size:clamp(40px,5vw,70px);
  letter-spacing:-.05em;
  line-height:.92;
}

.profile-subtitle{
  margin:0 0 16px;
  font-size:32px;
  letter-spacing:-.02em;
}

.profile-hero-content p{
  margin:0 0 14px;
  color:#4e4761;
  font-size:17px;
  line-height:1.7;
}

.profile-tags{
  margin-top:12px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.profile-tags span{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:#f5e2ef;
  color:#ac1f6e;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.profile-highlights-grid{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.profile-highlight-card{
  background:#fff;
  border:1px solid #e6dfeb;
  border-radius:18px;
  padding:18px 16px;
  box-shadow:0 10px 24px rgba(15,12,25,.05);
}

.profile-highlight-card h3{
  margin:0 0 8px;
  font-size:19px;
}

.profile-highlight-card p{
  margin:0;
  color:#554e67;
  line-height:1.65;
}

.profile-content-panel{
  margin-top:20px;
  background:#fff;
  border:1px solid #e6dfeb;
  border-radius:20px;
  padding:20px 20px 14px;
  box-shadow:0 12px 30px rgba(15,12,25,.06);
}

.profile-content-panel h3{
  margin:0 0 12px;
  font-size:30px;
}

.profile-content-body{
  color:#4f4861;
  line-height:1.75;
}

.profile-content-body > *:first-child{
  margin-top:0;
}

.profile-content-body > *:last-child{
  margin-bottom:0;
}

/* FOOTER */

.site-footer{
  background:var(--navy);
  color:#fff;
  margin-top:0;
  padding-top:80px;
}

.site-footer .container{
  padding:0 0 16px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.4fr .9fr .9fr 1fr;
  gap:30px;
  padding-bottom:30px;
}

.site-footer h3{
  margin:0 0 14px;
  font-size:33px;
  letter-spacing:-.01em;
}

.site-footer p,
.site-footer li,
.site-footer a{
  color:rgba(255,255,255,.86);
}

.footer-brand p,
.footer-col p,
.footer-col li,
.footer-col a{
  color:rgba(255,255,255,.72);
  font-size:14px;
  line-height:1.8;
}

.footer-col h4{
  margin:0 0 14px;
  font-size:17px;
}

.footer-col ul{
  list-style:none;
  margin:0;
  padding:0;
}

.footer-menu{
  list-style:none;
  margin:0;
  padding:0;
}

.footer-menu li{
  margin:0 0 8px;
}

.footer-menu a{
  color:rgba(255,255,255,.72);
  font-size:14px;
  line-height:1.8;
  transition:color .25s ease;
}

.footer-menu a:hover{
  color:rgba(255,255,255,.95);
}

.footer-social{
  display:flex;
  gap:10px;
  margin-top:14px;
}

.footer-social a{
  width:36px;
  height:36px;
  border-radius:50%;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}

.newsletter-form{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.newsletter-response{
  font-size:13px;
  font-weight:600;
  margin:0 0 8px;
}

.newsletter-response.is-success{
  color:#7ff2a6;
}

.newsletter-response.is-error{
  color:#ff9ab4;
}

.newsletter-form input{
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#fff;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.newsletter-form input::placeholder{
  color:rgba(255,255,255,.72);
}

.newsletter-form input:focus{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.62);
  box-shadow:0 0 0 4px rgba(255,255,255,.12);
}

.newsletter-form button{
  height:45px;
  border:none;
  border-radius:999px;
  cursor:pointer;
  font-weight:700;
  color:#fff;
  background:linear-gradient(135deg,#ef3b9c 0%, #ff62b6 100%);
  box-shadow:0 12px 28px rgba(239,59,156,.35);
  transition:transform .22s ease, box-shadow .22s ease, filter .22s ease;
}

.newsletter-form button:hover{
  transform:translateY(-1px);
  filter:brightness(1.05);
  box-shadow:0 16px 34px rgba(239,59,156,.42);
}

.footer-grid > div:last-child{
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  padding:18px 16px 16px;
  background:
    radial-gradient(320px 140px at 82% -40px, rgba(255,255,255,.14), transparent 70%),
    rgba(255,255,255,.04);
  box-shadow:0 14px 30px rgba(0,0,0,.22);
}

.footer-grid > div:last-child p{
  margin:0 0 14px;
  color:rgba(255,255,255,.9);
  line-height:1.6;
}

.footer-grid > div:last-child h3{
  margin-bottom:10px;
}

.footer-bottom{
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}

.footer-bottom p,
.footer-bottom a{
  font-size:13px;
  color:rgba(255,255,255,.62);
}

.whatsapp-float{
  position:fixed;
  right:22px;
  bottom:24px;
  width:54px;
  height:54px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#25d366;
  color:#fff;
  font-size:28px;
  box-shadow:0 18px 30px rgba(0,0,0,.18);
  z-index:80;
}

.screen-reader-text{
  position:absolute;
  left:-9999px;
}

@media (max-width: 1100px){
  .hero-title{font-size:64px}
  .about-grid,
  .news-grid,
  .footer-grid{
    grid-template-columns:1fr;
  }

  #projetos .container{
    width:min(calc(100% - 72px),1080px);
  }

  #projetos .project-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  #projetos .project-card h3{
    font-size:21px;
  }

  #projetos .project-card p{
    font-size:16px;
  }

  #noticias .container{
    width:min(calc(100% - 72px),1080px);
  }

  .news-featured .thumb img{
    height:360px;
  }

  .news-featured h3{
    font-size:34px;
  }

  .news-archive-container{
    width:min(calc(100% - 72px),1080px);
  }

  .news-archive-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .contact-page-container{
    width:min(calc(100% - 72px),1080px);
  }

  .contact-page-grid{
    grid-template-columns:1fr;
  }

  .profile-container{
    width:min(calc(100% - 72px),1080px);
  }

  .profile-hero-grid{
    grid-template-columns:1fr;
  }

  .profile-photo-wrap{
    min-height:500px;
  }

  .profile-highlights-grid{
    grid-template-columns:1fr;
  }

  .footer-grid > div:last-child{
    max-width:460px;
  }

  #ideias .container{
    width:min(calc(100% - 72px),1080px);
  }

  #ideias .idea-box h2{
    font-size:clamp(34px,4.8vw,56px);
  }

  .hero-portrait{
    width:48vw;
    opacity:.8;
  }

  .hero .container{
    padding-left:48px;
  }
}

@media (max-width: 820px){
  :root{
    --header-height:120px;
  }

  .site-header .container{
    flex-wrap:wrap;
    padding:10px 0;
  }

  .primary-nav{
    order:3;
    width:100%;
  }

  .primary-nav ul{
    justify-content:center;
    flex-wrap:wrap;
    gap:18px;
    padding-bottom:10px;
  }

  .menu-toggle{
    display:block;
  }

  .hero{
    height:auto !important;
    min-height:560px !important;
    max-height:none !important;
  }

  .hero .container{
    min-height:560px;
    padding:32px 0 90px;
    padding-left:0;
    padding-right:0;
  }

  .hero-arrow{
    width:44px;
    height:44px;
    font-size:24px;
  }

  .hero-arrow-prev{
    left:12px;
  }

  .hero-arrow-next{
    right:12px;
  }

  .hero-slider{
    height:auto !important;
    min-height:560px !important;
    max-height:none !important;
  }

  .hero-slider .hero-slides,
  .hero-slider .hero-slides > .hero-slide{
    height:auto !important;
    min-height:560px !important;
    max-height:none !important;
  }

  .hero-portrait{
    position:absolute;
    inset:auto 0 0 auto;
    width:72vw;
    height:72vw;
    opacity:.42;
  }

  .project-grid,
  .idea-form{
    grid-template-columns:1fr;
  }

  #projetos .container{
    width:min(calc(100% - 40px),var(--container));
  }

  #projetos .section-header{
    padding:0;
  }

  #projetos .section-link{
    padding:8px 14px;
  }

  #projetos .project-card{
    min-height:unset;
    padding:24px 22px 20px;
  }

  #projetos .project-card h3{
    font-size:20px;
  }

  #projetos .project-card p{
    font-size:15px;
  }

  #noticias{
    padding:72px 0 78px;
  }

  #noticias .container{
    width:min(calc(100% - 40px),var(--container));
  }

  #noticias .section-header{
    padding:0;
    margin-bottom:24px;
  }

  .news-featured{
    border-radius:22px;
  }

  .news-featured .thumb img{
    height:290px;
  }

  .news-featured-body{
    padding:20px;
  }

  .news-item{
    grid-template-columns:78px 1fr;
    gap:12px;
    border-radius:18px;
    padding:14px;
  }

  .news-item-thumb{
    width:78px;
    height:78px;
    border-radius:16px;
  }

  .news-item h4{
    font-size:16px;
  }

  .news-more{
    justify-content:stretch;
  }

  .news-more .btn{
    width:100%;
  }

  .news-archive-main{
    padding:16px 0 54px;
  }

  .news-archive-container{
    width:min(calc(100% - 40px),var(--container));
  }

  .news-archive-grid{
    grid-template-columns:1fr;
    gap:16px;
  }

  .news-archive-card-title{
    font-size:20px;
  }

  .contact-page-main{
    padding:22px 0 52px;
  }

  .contact-page-container{
    width:min(calc(100% - 40px),var(--container));
  }

  .contact-page-title{
    font-size:clamp(32px,10vw,44px);
  }

  .contact-page-intro p{
    font-size:16px;
  }

  .contact-info-card,
  .contact-social-card,
  .contact-form-panel{
    border-radius:18px;
  }

  .contact-form-panel{
    padding:20px 16px 16px;
  }

  .contact-form-grid{
    grid-template-columns:1fr;
  }

  .contact-social-grid{
    grid-template-columns:1fr;
  }

  .contact-submit-row .btn{
    width:100%;
    min-width:0;
  }

  .profile-page-main{
    padding:18px 0 54px;
  }

  .profile-container{
    width:min(calc(100% - 40px),var(--container));
  }

  .profile-hero-content{
    padding:22px 16px 18px;
    border-radius:20px;
  }

  .profile-title{
    font-size:clamp(32px,10vw,46px);
  }

  .profile-subtitle{
    font-size:26px;
  }

  .profile-hero-content p{
    font-size:16px;
  }

  .profile-photo-wrap{
    border-radius:20px;
    min-height:380px;
  }

  .profile-content-panel{
    padding:16px 14px 12px;
    border-radius:16px;
  }

  .footer-grid > div:last-child{
    max-width:none;
    padding:16px 14px 14px;
    border-radius:16px;
  }

  #ideias{
    padding:0;
  }

  #ideias .container{
    width:min(calc(100% - 40px),var(--container));
  }

  #ideias .idea-box{
    border-radius:24px;
    padding:34px 18px 24px;
  }

  #ideias .idea-box h2{
    font-size:clamp(30px,9vw,42px);
    margin-bottom:10px;
  }

  #ideias .idea-box p{
    font-size:16px;
    margin-bottom:24px;
  }

  #ideias .idea-form{
    gap:14px;
  }

  #ideias .field-group input,
  #ideias .field-group select,
  #ideias .field-group textarea{
    padding:14px 15px;
  }

  #ideias .field-group textarea{
    min-height:128px;
  }

  #ideias .idea-actions .btn{
    width:100%;
    min-width:0;
    height:50px;
  }

  .section{padding:54px 0}
  .hero-title{font-size:48px}
  .news-featured h3{font-size:28px}
}

/* CADASTRO PAGE */

.cadastro-page-main{
  padding:48px 0 78px;
}

.cadastro-page-container{
  width:min(calc(100% - 48px),820px);
  margin:0 auto;
}

.cadastro-page-section{
  background:linear-gradient(135deg,#fff 0%, #fbfaff 100%);
  border-radius:28px;
  border:1px solid #e8e1ed;
  padding:48px;
  box-shadow:0 20px 48px rgba(16,13,28,.08);
}

.cadastro-page-intro{
  margin-bottom:40px;
  text-align:center;
}

.cadastro-page-intro .kicker{
  margin-bottom:12px;
}

.cadastro-page-title{
  font-size:clamp(32px,5vw,56px);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.1;
  margin:0 0 16px;
  color:#110f1d;
}

.cadastro-page-intro p{
  font-size:17px;
  color:#66606d;
  margin:0;
  line-height:1.6;
}

.cadastro-box{
  background:#fff;
  border-radius:24px;
  border:1px solid #ebe4ea;
  padding:36px;
  box-shadow:0 12px 28px rgba(17,13,28,.06);
}

.cadastro-form{
  display:flex;
  flex-direction:column;
  gap:32px;
}

.form-section h3{
  font-size:16px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#2f2940;
  margin:0 0 16px;
  padding-bottom:12px;
  border-bottom:2px solid #f0ecf5;
}

.form-section{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:18px;
}

.form-section .field-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.form-section label{
  color:#2f2940;
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.form-section input,
.form-section select,
.form-section textarea{
  width:100%;
  border:1px solid #dcd3e7;
  border-radius:12px;
  background:#fff;
  color:#1c1728;
  padding:12px 14px;
  font-size:15px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.form-section input:focus,
.form-section select:focus,
.form-section textarea:focus{
  border-color:#e73690;
  box-shadow:0 0 0 3px rgba(231,54,144,.12);
}

.form-section textarea{
  min-height:120px;
  resize:vertical;
  font-family:inherit;
}

.form-section select{
  cursor:pointer;
}

.form-actions{
  display:flex;
  gap:12px;
  margin-top:8px;
}

.form-actions .btn{
  min-width:200px;
  padding:14px 32px;
  border-radius:999px;
}

.samantha-form-response{
  padding:16px;
  border-radius:12px;
  display:none;
  font-size:15px;
  font-weight:500;
}

.samantha-form-response.success{
  display:block;
  background:#e8f8ef;
  color:#2a8b48;
  border:1px solid #c0e6ce;
}

.samantha-form-response.error{
  display:block;
  background:#fde8ed;
  color:#d72f58;
  border:1px solid #f4b8d0;
}

@media (max-width: 768px){
  .cadastro-page-section{
    padding:32px 24px;
  }

  .cadastro-box{
    padding:24px;
  }

  .form-section{
    grid-template-columns:1fr;
  }

  .cadastro-page-title{
    font-size:32px;
  }

  .form-actions .btn{
    min-width:100%;
  }
}

/* COLABORADORES PAGE */

.colaboradores-page-main{
  padding:48px 0 78px;
}

.colaboradores-page-container{
  width:min(calc(100% - 48px),900px);
  margin:0 auto;
}

.colaboradores-page-section{
  background:linear-gradient(135deg,#fff 0%, #fbfaff 100%);
  border-radius:28px;
  border:1px solid #e8e1ed;
  padding:48px;
  box-shadow:0 20px 48px rgba(16,13,28,.08);
}

.colaboradores-page-intro{
  margin-bottom:40px;
  text-align:center;
}

.colaboradores-page-intro .kicker{
  margin-bottom:12px;
}

.colaboradores-page-title{
  font-size:clamp(32px,5vw,56px);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.1;
  margin:0 0 16px;
  color:#110f1d;
}

.colaboradores-page-intro p{
  font-size:17px;
  color:#66606d;
  margin:0;
  line-height:1.6;
}

.colaboradores-box{
  background:#fff;
  border-radius:24px;
  border:1px solid #ebe4ea;
  padding:36px;
  box-shadow:0 12px 28px rgba(17,13,28,.06);
  margin-bottom:40px;
}

.colaboradores-form{
  display:flex;
  flex-direction:column;
  gap:24px;
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.form-row .field-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.form-row label{
  color:#2f2940;
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.form-row input,
.form-row select{
  width:100%;
  border:1px solid #dcd3e7;
  border-radius:12px;
  background:#fff;
  color:#1c1728;
  padding:12px 14px;
  font-size:15px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.form-row input:focus,
.form-row select:focus{
  border-color:#e73690;
  box-shadow:0 0 0 3px rgba(231,54,144,.12);
}

.form-row select{
  cursor:pointer;
}

.form-actions{
  display:flex;
  gap:12px;
  margin-top:8px;
}

.form-actions .btn{
  min-width:200px;
  padding:14px 32px;
  border-radius:999px;
}

.recent-cadastros{
  background:#fff;
  border-radius:24px;
  border:1px solid #ebe4ea;
  padding:24px;
  box-shadow:0 12px 28px rgba(17,13,28,.06);
}

.recent-cadastros h3{
  margin:0 0 20px;
  font-size:18px;
  color:#110f1d;
}

.recent-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.recent-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 16px;
  background:#f8f7fa;
  border-radius:12px;
  border:1px solid #f0ecf5;
}

.recent-info{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.recent-info strong{
  font-size:15px;
  color:#110f1d;
}

.recent-info span{
  font-size:13px;
  color:#66606d;
}

.recent-date{
  font-size:12px;
  color:#878296;
  font-weight:500;
}

.no-recent{
  text-align:center;
  color:#878296;
  font-style:italic;
  padding:20px;
}

@media (max-width: 768px){
  .colaboradores-page-section{
    padding:32px 24px;
  }

  .colaboradores-box{
    padding:24px;
  }

  .form-row{
    grid-template-columns:1fr;
  }

  .colaboradores-page-title{
    font-size:32px;
  }

  .form-actions .btn{
    min-width:100%;
  }

  .recent-item{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }
}
