:root{
  --bg:#0f1724; /* deep slate */
  --card:#0b1220;
  --muted:#9aa6bb;
  --accent:#6ee7b7; /* mint */
  --accent-2:#60a5fa; /* blue */
  --glass: rgba(255,255,255,0.03);
  --radius:14px;
  --shadow: 0 6px 18px rgba(2,6,23,0.6);
  --max-width:1100px;
  color-scheme: dark;
  color: #e6eef8;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;padding:40px; 
  background-color: #03172a;
  /* background:linear-gradient(180deg,var(--bg),#071025 60%); */
  display:flex;align-items:flex-start;justify-content:center;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}

.wrap{width:100%;max-width:var(--max-width)}

/* Header */
header{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;
}
.brand{display:flex;gap:14px;align-items:center}
.logo{
  width:46px;height:46px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:grid;place-items:center;font-weight:800;color:#052128;font-size:18px;box-shadow:0 6px 18px rgba(6,22,30,0.5);
}
.title{line-height:1}
h1{font-size:20px;margin:0}
p.lead{margin:0;color:var(--muted);font-size:13px}

.actions{display:flex;gap:10px;align-items:center}
.btn{padding:10px 14px;border-radius:10px;background:var(--glass);border:1px solid rgba(255,255,255,0.03);cursor:pointer;font-weight:600}
.btn.primary{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#052128;border:none;box-shadow:0 8px 28px rgba(96,165,250,0.08)}

/* Search / Filters */
.controls{display:flex;gap:12px;align-items:center;margin-bottom:20px}
.search{flex:1;display:flex;align-items:center;background:#071426;padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,0.03)}
.search input{background:transparent;border:none;outline:none;color:inherit;font-size:14px;margin-left:10px;width:100%}
.filter{display:flex;gap:8px}
.chip{padding:8px 10px;border-radius:999px;background:transparent;border:1px solid rgba(255,255,255,0.04);font-size:13px;color:var(--muted);cursor:pointer}
.chip.active{background:rgba(96,165,250,0.12);border-color:rgba(96,165,250,0.2);color:var(--accent-2)}

/* Grid */
/* Grid as flex container */
.grid {
  display: flex;
  flex-wrap: wrap;          /* allow multiple rows */
  gap: 18px;                /* space between cards */
  justify-content: flex-start; /* always align left, cards sit next to each other */
}

/* Card */
/* Card */
.card {
  flex: 0 0 330px;          /* fixed width */
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius: var(--radius);
  padding: 12px;
  border: 1px solid rgba(255,255,255,0.03);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 300px;

  /* IMPORTANT for ribbon */
  position: relative;
}



.card:hover{transform:translateY(-6px);box-shadow:0 12px 30px rgba(2,6,23,0.6)}

.template-preview{
  flex:1;
  border-radius:10px;
  background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  /* padding:12px; */
  display:flex;
  flex-direction:column;
  gap:8px;
}

.tp-top{display:flex;gap:12px;align-items:center;margin: auto;}
.avatar{width:44px;height:44px;border-radius:8px;background:linear-gradient(135deg,var(--accent-2),var(--accent));display:grid;place-items:center;font-weight:700;color:#03172a}
.tp-title{font-weight:700}
.tp-meta{font-size:12px;color:var(--muted)}

.tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:12px;padding:6px 8px;border-radius:8px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.02);color:var(--muted)}

.card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}
.preview-btn{padding:8px 12px;border-radius:10px;background:transparent;border:1px solid rgba(255,255,255,0.04);font-weight:600;cursor:pointer}
.use-btn{padding:8px 12px;border-radius:10px;background:linear-gradient(90deg,var(--accent),var(--accent-2));border:none;color:#052128;font-weight:700;cursor:pointer}

/* Ribbon */
/* Ribbon */
.ribbon {
  display: none;
    position: absolute;
    top: 12px;
    left: 0; /* align with card edge */
    transform: rotate(-20deg);
    background: linear-gradient(90deg,#f59e0b,#ef4444);
    padding: 6px 40px; /* adjust width */
    color: #061019;
    font-weight: 800;
    font-size: 14px;
    border-radius: 6px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.6);
    z-index: 10; /* ensure it sits on top of card content */
}

/* Empty state / footer */
.empty{padding:36px;border-radius:12px;background:linear-gradient(180deg, rgba(255,255,255,0.01), transparent);border:1px dashed rgba(255,255,255,0.03);text-align:center;color:var(--muted)}

/* Card Preview Image */
.preview-image {
    width: 100%;
    height: 100%; /* fixed height for uniform cards */
    overflow: hidden;
    border-radius: 8px;
    margin-bottom: 10px;
}
.preview-image img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* keeps image proportion */
    display: block;
}


@media (max-width:768px){
  .grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
  .card{min-height:260px;padding:14px}
}

@media (max-width:480px){
  body{padding:18px}
  .logo{width:40px;height:40px;font-size:16px}
  h1{font-size:18px}
  .grid{grid-template-columns:1fr;gap:12px}
  .card{min-height:220px;padding:12px}
}
