278 lines
10 KiB
CSS

:root {
--brand: #1db7ae;
--brand-600: #12968f;
--brand-100: #e7f7f6;
--ink: #24323f;
--muted: #6b7a88;
--line: #e6eaef;
--bg: #ffffff;
--danger: #e55353;
--warning: #f59e0b;
--success: #22c55e;
--shadow: 0 10px 20px rgba(15, 23, 42, .06);
--radius: 14px;
}
*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji"; color: var(--ink); background: #f6f8fb; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
.topbar { background: var(--brand); color: #fff; font-size: .9rem; }
.topbar .wrap { max-width: 1200px; margin: 0 auto; padding: .5rem 1rem; display: flex; gap: 1rem; align-items: center; justify-content: space-between; }
.topbar small { opacity: .95; }
header { box-shadow: var(--shadow); position: sticky; top: 0; z-index: 30; width: 100%; background: #fff; box-shadow: var(--shadow); position: sticky; top: 0; z-index: 30; display: flex; align-items: center;justify-content: space-between; }
.logo-link img {
height: 100px; /* Defina a altura da sua logo aqui */
width: auto; /* Mantém a proporção da imagem */
display: block; /* Remove espaços extras abaixo da imagem */
}
.wrap { max-width: 1200px; margin: 0 auto; padding: .9rem 1rem; display: flex; align-items: center; justify-content: space-between; }
.brand {display: flex; margin-left: 200px; align-items: center; gap: .6rem; font-weight: 800; letter-spacing: .4px; }
.logo { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, var(--brand), #4dd7cf); display: grid; place-items: center; color: #fff; font-weight: 700; box-shadow: 0 6px 14px rgba(29,183,174,.35); }
nav { display: flex; gap: 1.2rem; color: var(--muted); font-weight: 600; }
.cta { background: var(--brand); color: #fff; padding: .6rem 1rem; border-radius: 999px; box-shadow: 0 10px 18px rgba(29,183,174,.25); transition: .2s ease; }
.cta:hover { background: var(--brand-600); transform: translateY(-1px); }
.container { max-width: 1200px; margin: 28px auto; padding: 0 1rem 4rem; }
.card { background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
.card .head { padding: 1rem 1.2rem; border-bottom: 1px solid var(--line); display: flex; gap: 1rem; align-items: center; justify-content: space-between; }
.title { display: flex; gap: .8rem; align-items: center; }
.title h1 { margin: 0; font-size: 1.25rem; }
.badge { background: var(--brand-100); color: var(--brand-600); font-weight: 700; padding: .2rem .5rem; border-radius: 6px; font-size: .75rem; }
.toolbar { display: grid; grid-template-columns: 1fr auto; gap: .8rem; width: 100%; }
.search { display: flex; align-items: center; gap: .6rem; background: #f9fbfd; border: 1px solid var(--line); padding: .55rem .8rem; border-radius: 999px; }
.search input { all: unset; width: 100%; color: var(--ink); }
.btn { display: inline-flex; gap: .5rem; align-items: center; border: 1px solid transparent; border-radius: 999px; padding: .65rem 1rem; font-weight: 700; cursor: pointer; transition: .2s ease; }
.btn.primary { background: var(--brand); color: #fff; box-shadow: 0 10px 18px rgba(29,183,174,.25); }
.btn.primary:hover { background: var(--brand-600); transform: translateY(-1px); }
.table { width: 100%; border-collapse: collapse; }
.table thead th { text-align: left; font-size: .8rem; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); background: #fbfdff; border-bottom: 1px solid var(--line); padding: .9rem .9rem; }
.table tbody td { padding: .9rem .9rem; border-bottom: 1px solid var(--line); vertical-align: middle; }
.table tbody tr:hover { background: #fcfefe; }
.actions { display: inline-flex; gap: .35rem; }
.icon-btn { --bg: #f2f6fb; --bd: var(--line); display: inline-grid; place-items: center; width: 34px; height: 34px; border-radius: 10px; border: 1px solid var(--bd); background: var(--bg); transition: .2s ease; }
.icon-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.table-footer { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.2rem; }
.pagination { display: inline-flex; gap: .4rem; }
.page-btn, .page { min-width: 36px; height: 36px; border-radius: 10px; border: 1px solid var(--line); display: grid; place-items: center; padding: 0 .6rem; background:#fff; cursor:pointer }
.page-btn.active, .page.is-active { background: var(--brand); color: #fff; border-color: transparent; box-shadow: 0 10px 18px rgba(29,183,174,.25); }
.col-actions{ text-align:right }
@media (max-width: 900px) {
.toolbar { grid-template-columns: 1fr; }
.table thead { display: none; }
.table, .table tbody, .table tr, .table td { display: block; width: 100%; }
.table tbody tr { border-bottom: 1px solid var(--line); padding: .6rem 0; }
.table tbody td { border-bottom: none; display: grid; grid-template-columns: 30% 1fr; gap: .6rem; padding: .5rem .9rem; }
.actions { justify-content: flex-end; }
}
:root{
--brand: #1db7ae;
--brand-600:#12968f;
--brand-100:#e7f7f6;
--ink:#24323f;
--muted:#6b7a88;
--line:#e6eaef;
--bg:#ffffff;
--shadow: 0 20px 60px rgba(18,150,143,.22);
}
.overlay{
position: fixed; inset: 0;
background: rgba(14, 23, 29, .56);
display: none; align-items: center; justify-content: center;
padding: 24px;
z-index: 999;
}
.overlay[aria-hidden="false"]{ display:flex; }
.carteirinha-wrap{
width: min(820px, 96vw);
perspective: 1400px;
position: relative;
animation: overlayIn .18s ease-out;
}
@keyframes overlayIn {
from{ transform: translateY(8px); opacity:.0}
to{ transform: translateY(0); opacity:1}
}
.close-btn{
position: absolute;
top: -14px;
right: -14px;
width: 40px; height: 40px;
border: none; border-radius: 12px;
background: #fff;
box-shadow: 0 8px 20px rgba(0,0,0,.18);
font-size: 28px; line-height: 40px;
color: #6b7a88; cursor: pointer;
z-index: 1010; }
.close-btn:hover{ transform: translateY(-1px); }
.carteirinha{
background: var(--bg);
border-radius: 20px;
box-shadow: var(--shadow);
overflow: hidden;
transform: rotateX(14deg) rotateY(-8deg) scale(.96);
transform-origin: 50% 60%;
animation: cardEnter .35s cubic-bezier(.22,.9,.27,1.05) forwards;
}
@keyframes cardEnter{
to { transform: rotateX(0) rotateY(0) scale(1); }
}
.cart-header{
display:flex; align-items:center; gap:12px;
background: linear-gradient(135deg, var(--brand), #15a6a0);
color:#fff; padding: 20px 22px;
}
.logo-dot{ width:12px; height:12px; border-radius:50%; background:#fff; opacity:.9 }
.cart-header h3{ margin:0; font-weight:700; letter-spacing:.3px }
.tag{
margin-left:auto; background: rgba(255,255,255,.18);
border:1px solid rgba(255,255,255,.35);
padding:6px 10px; border-radius:999px; font-size:12px
}
.cart-body{ padding: 20px 22px; display:grid; grid-template-columns: 120px 1fr; gap: 18px; }
.avatar{
position: relative; width:110px; height:110px; border-radius:16px;
background: var(--brand-100);
display:grid; place-items:center; font-weight:700; color:var(--brand-600);
isolation:isolate;
}
.avatar-ring{
position:absolute; inset:-6px;
border-radius:20px; border: 2px dashed var(--brand-600);
opacity:.25; animation: spin 10s linear infinite;
z-index: -1;
}
@keyframes spin { to{ transform: rotate(360deg); } }
.avatar-iniciais{ font-size:28px }
.grid{
display:grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 14px;
}
.field label{
display:block; font-size:12px; color: var(--muted); margin-bottom:4px
}
.field p{
background:#fff; border:1px solid var(--line);
border-radius:12px; padding:10px 12px; margin:0; color:var(--ink);
}
.obs{ grid-column: 1/-1; }
.obs label{ display:block; font-size:12px; color:var(--muted); margin:10px 0 6px; }
.obs p{
margin:0; background:#fff; border:1px dashed var(--line);
border-radius:12px; padding:12px; min-height:56px; color:var(--ink)
}
.cart-footer{
display:flex; align-items:center; gap:16px; justify-content:space-between;
padding: 12px 18px 18px;
border-top:1px solid var(--line);
background: #fafdfd;
}
.chips{ display:flex; gap:10px; flex-wrap:wrap }
.chip{
background: var(--brand-100); color: var(--brand-600);
border:1px solid #cbeeed; padding:6px 10px; border-radius:999px; font-size:12px;
}
.chip.outline{
background: #fff; border:1px dashed #cbeeed; color: var(--brand-600);
}
.actions{ display:flex; gap:10px }
button.primary, button.ghost{
border-radius:12px; padding:10px 14px; border:1px solid var(--line);
cursor:pointer; font-weight:600;
}
button.primary{ background: var(--brand); color:#fff; border-color: transparent; }
button.primary:hover{ background: var(--brand-600); }
button.ghost{ background:#fff; color: var(--ink); }
button.ghost:hover{ border-color: var(--brand-600); color: var(--brand-600); }
/* Responsivo */
@media (max-width: 720px){
.cart-body{ grid-template-columns: 1fr; }
.grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 440px){
.grid{ grid-template-columns: 1fr; }
}
.navbar {
gap: 10px;
border-bottom:1px solid #e6eaef;
padding:12px 24px;
display:flex;
align-items:center;
gap:24px;
font-size:15px;
}
.navbar a{
color:var(--muted);
text-decoration:none;
font-weight:500;
}
.navbar a:hover{
color:var(--brand-600);
}
.navbar .active{
background:var(--brand);
color:#fff;
padding:8px 18px;
border-radius:999px;
font-weight:600;
box-shadow:0 3px 8px rgba(18,150,143,.25);
}
.nav-links {
display: flex;
gap: 20px;
align-items: center;
}
.nav-links a {
text-decoration: none;
color: #555;
font-weight: 500;
padding: 10px 18px;
border-radius: 20px;
transition: background 0.3s ease;
}
.nav-links a.active {
background: #26bdbd;
color: white;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
font-weight: bold;
}
.btn-navbar {
background: none;
color: #555;
border: none;
padding: 10px 18px;
border-radius: 20px;
font-weight: 500;
cursor: pointer;
transition: background 0.3s ease;
}
.btn-navbar:hover {
background: #f0f0f0;
}